summaryrefslogtreecommitdiffstats
path: root/lib/kross/main/scriptguiclient.h
diff options
context:
space:
mode:
Diffstat (limited to 'lib/kross/main/scriptguiclient.h')
-rw-r--r--lib/kross/main/scriptguiclient.h217
1 files changed, 217 insertions, 0 deletions
diff --git a/lib/kross/main/scriptguiclient.h b/lib/kross/main/scriptguiclient.h
new file mode 100644
index 00000000..955b55d9
--- /dev/null
+++ b/lib/kross/main/scriptguiclient.h
@@ -0,0 +1,217 @@
+/***************************************************************************
+ * scriptguiclient.h
+ * This file is part of the KDE project
+ * copyright (C) 2005 by Sebastian Sauer (mail@dipe.org)
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Library General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Library General Public License for more details.
+ * You should have received a copy of the GNU Library General Public License
+ * along with this program; see the file COPYING. If not, write to
+ * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+ ***************************************************************************/
+
+#ifndef KROSS_API_SCRIPTGUICLIENT_H
+#define KROSS_API_SCRIPTGUICLIENT_H
+
+#include "scriptcontainer.h"
+#include "scriptaction.h"
+
+#include <qobject.h>
+#include <qdom.h>
+#include <kurl.h>
+#include <kxmlguiclient.h>
+
+class QWdiget;
+
+namespace Kross { namespace Api {
+
+ // Forward declarations.
+ class ScriptAction;
+ class ScriptGUIClientPrivate;
+
+ /**
+ * The ScriptGUIClient class provides abstract access to
+ * scripting code used to extend an applications functionality.
+ */
+ class KDE_EXPORT ScriptGUIClient
+ : public QObject
+ , public KXMLGUIClient
+ {
+ Q_OBJECT
+ //Q_PROPERTY(QString configfile READ getConfigFile WRITE setConfigFile)
+
+ public:
+
+ /// List of KAction instances.
+ typedef QPtrList<KAction> List;
+
+ /**
+ * Constructor.
+ *
+ * \param guiclient The KXMLGUIClient this \a ScriptGUIClient
+ * is a child of.
+ * \param parent The parent QWidget. If defined Qt will handle
+ * freeing this \a ScriptGUIClient instance else the
+ * caller has to take care of freeing this instance
+ * if not needed any longer.
+ */
+ explicit ScriptGUIClient(KXMLGUIClient* guiclient, QWidget* parent = 0);
+
+ /**
+ * Destructor.
+ */
+ virtual ~ScriptGUIClient();
+
+ /**
+ * \return true if this \a ScriptGUIClient has a \a ScriptActionCollection
+ * with the name \p name else false is returned.
+ */
+ bool hasActionCollection(const QString& name);
+
+ /**
+ * \return the \a ScriptActionCollection which has the name \p name
+ * or NULL if there exists no such \a ScriptActionCollection .
+ */
+ ScriptActionCollection* getActionCollection(const QString& name);
+
+ /**
+ * \return a map of all avaiable \a ScriptActionCollection instances
+ * this \a ScriptGUIClient knows about.
+ * Per default there are 2 collections avaiable;
+ * 1. "installedscripts" The installed collection of scripts.
+ * 2. "loadedscripts" The loaded scripts.
+ */
+ QMap<QString, ScriptActionCollection*> getActionCollections();
+
+ /**
+ * Add a new \a ScriptActionCollection with the name \p name to
+ * our map of actioncollections.
+ */
+ void addActionCollection(const QString& name, ScriptActionCollection* collection);
+
+ /**
+ * Remove the \a ScriptActionCollection defined with name \p name.
+ */
+ bool removeActionCollection(const QString& name);
+
+ /**
+ * Reload the list of installed scripts.
+ */
+ void reloadInstalledScripts();
+
+ /**
+ * Install the packagefile \p scriptpackagefile . Those
+ * packagefile should be a tar.gz-archive which will be
+ * extracted and to the users script-directory.
+ */
+ bool installScriptPackage(const QString& scriptpackagefile);
+
+ /**
+ * Uninstall the scriptpackage located in the path
+ * \p scriptpackagepath . This just deletes the whole
+ * directory.
+ */
+ bool uninstallScriptPackage(const QString& scriptpackagepath);
+
+ /**
+ * Load the scriptpackage's configurationfile
+ * \p scriptconfigfile and add the defined \a ScriptAction
+ * instances to the list of installed scripts.
+ */
+ bool loadScriptConfigFile(const QString& scriptconfigfile);
+
+ /**
+ * Load the \p document DOM-document from the scriptpackage's
+ * XML-configfile \p scriptconfigfile and add the defined
+ * \a ScriptAction instances to the list of installed scripts.
+ */
+ bool loadScriptConfigDocument(const QString& scriptconfigfile, const QDomDocument &document);
+
+ /// KXMLGUIClient overloaded method to set the XML file.
+ virtual void setXMLFile(const QString& file, bool merge = false, bool setXMLDoc = true);
+ /// KXMLGUIClient overloaded method to set the XML DOM-document.
+ virtual void setDOMDocument(const QDomDocument &document, bool merge = false);
+
+ public slots:
+
+ /**
+ * A KFileDialog will be displayed to let the user choose
+ * a scriptfile. The choosen file will be returned as KURL.
+ */
+ KURL openScriptFile(const QString& caption = QString::null);
+
+ /**
+ * A KFileDialog will be displayed to let the user choose
+ * a scriptfile that should be loaded.
+ * Those loaded \a ScriptAction will be added to the
+ * \a ScriptActionCollection of loaded scripts.
+ */
+ bool loadScriptFile();
+
+ /**
+ * A KFileDialog will be displayed to let the user choose
+ * the scriptfile that should be executed.
+ * The executed \a ScriptAction will be added to the
+ * \a ScriptActionCollection of executed scripts.
+ */
+ bool executeScriptFile();
+
+ /**
+ * Execute the scriptfile \p file . Internaly we try to use
+ * the defined filename to auto-detect the \a Interpreter which
+ * should be used for the execution.
+ */
+ bool executeScriptFile(const QString& file);
+
+ /**
+ * This method executes the \a ScriptAction \p action .
+ * Internaly we just call \a ScriptAction::activate and
+ * redirect the success/failed signals to our internal slots.
+ */
+ bool executeScriptAction(ScriptAction::Ptr action);
+
+ /**
+ * The \a ScriptManagerGUI dialog will be displayed to
+ * let the user manage the scriptfiles.
+ */
+ void showScriptManager();
+
+ private slots:
+
+ /**
+ * Called if execution of this \a ScriptAction failed and
+ * displays an errormessage-dialog.
+ */
+ void executionFailed(const QString& errormessage, const QString& tracedetails);
+
+ /**
+ * Called if execution of this \a ScriptAction was
+ * successfully. The \a ScriptAction will be added
+ * to the history-collection of successfully executed
+ * \a ScriptAction instances.
+ */
+ void successfullyExecuted();
+
+ signals:
+ /// Emitted if a \a ScriptActionCollection instances changed.
+ void collectionChanged(ScriptActionCollection*);
+ /// This signal is emited when the execution of a script is started
+ void executionStarted(const Kross::Api::ScriptAction* );
+ /// This signal is emited when the execution of a script is finished
+ void executionFinished(const Kross::Api::ScriptAction* );
+ private:
+ /// Internaly used private d-pointer.
+ ScriptGUIClientPrivate* d;
+ };
+
+}}
+
+#endif
+