/* This file is part of the KDE project Copyright (C) 2001 Ian Reinhart Geiser (geiseri@kde.org) This library 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 library 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 library; see the file COPYING.LIB. If not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ /** * \section Generic interface for building scripting engines * * This interface will create a generic API for implementing script engines. * These engines can then be accessed from any application that supports this interface. * * **/ #ifndef __scriptinterface_h__ #define __scriptinterface_h__ #include #include #include //#include class TQString; class TQObject; class KScriptClientInterface; //namespace KScriptInterface //{ /** * This class is the base for all script engines. * @author Ian Reinhart Geiser * **/ class KDE_EXPORT KScriptInterface : public TQObject { Q_OBJECT public: /** * Return the current script code data * @returns TQString containing the currenly runable code **/ virtual TQString script() const = 0; /** * Sets the path to the script library that we are going to embed. **/ virtual void setScript( const TQString &scriptFile ) = 0; /** * Sets the path to the script library that we are going to embed. * The second argument is the function from the script library that * we wish to call. **/ virtual void setScript( const TQString &scriptLibFile, const TQString &method ) = 0; /** * Run the actual script code * This can both take a context object that will be shared between the * main application and a variant that will contain the arguments. **/ virtual void run(TQObject *context = 0, const TQVariant &arg = 0) = 0; /** * Abort the scripts run **/ virtual void kill() =0; public: /** * This is the method for sending feedback to applications. * example of how this works: * \code * ScriptClientInterface->error( message_to_send_back_to_the_main_application ); * \endcode * Will send the error message back to the main application. **/ KScriptClientInterface *ScriptClientInterface; }; //}; #endif