From 7a533c24fb0ccb86b089cb37f402b49a8ae96da3 Mon Sep 17 00:00:00 2001 From: "Aaron J. Seigo" Date: Sat, 4 Sep 2010 22:51:48 +0000 Subject: [PATCH] support finding paths from the current context svn path=/trunk/KDE/kdebase/runtime/; revision=1171722 --- scriptengines/javascript/runner/javascriptrunner.cpp | 12 +++++++++++- scriptengines/javascript/runner/javascriptrunner.h | 4 ++-- 2 files changed, 13 insertions(+), 3 deletions(-) diff --git a/scriptengines/javascript/runner/javascriptrunner.cpp b/scriptengines/javascript/runner/javascriptrunner.cpp index c101dfc6f..6c6f1b669 100644 --- a/scriptengines/javascript/runner/javascriptrunner.cpp +++ b/scriptengines/javascript/runner/javascriptrunner.cpp @@ -147,9 +147,19 @@ void JavaScriptRunner::reportError(ScriptEnv *env, bool fatal) kDebug() << env->engine()->uncaughtExceptionBacktrace(); } +QString JavaScriptRunner::filePath(const char *type, const QString &file) const +{ + const QString path = m_env->filePathFromScriptContext(type, file); + if (path.isEmpty()) { + return path; + } + + return package()->filePath(type, file); +} + bool JavaScriptRunner::include(const QString &script) { - const QString path = package()->filePath("scripts", script); + const QString path = filePath("scripts", script); if (path.isEmpty()) { return false; } diff --git a/scriptengines/javascript/runner/javascriptrunner.h b/scriptengines/javascript/runner/javascriptrunner.h index 7ae38e8c2..4d84390c0 100644 --- a/scriptengines/javascript/runner/javascriptrunner.h +++ b/scriptengines/javascript/runner/javascriptrunner.h @@ -51,12 +51,12 @@ public: public Q_SLOTS: bool include(const QString &script); -protected: +private: void setupObjects(); void importExtensions(); void reportError(ScriptEnv *engine, bool fatal); + QString filePath(const char *type, const QString &file) const; -private: QScriptEngine *m_engine; ScriptEnv *m_env; QScriptValue m_self;