< Development‎ | Tutorials
Revision as of 02:43, 6 May 2007 by Dipesh (talk | contribs) (Added initial "Scripts as Plugins with Kross" tutorial)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)



This tutorial provides a step-by-step introduction how to integrate scripts as plugins into an application.

The C++ code

The following C++ code demonstrates how to execute scripting code in C++ and how to let scripting code deal with QObject instances.

#include <QObject>
#include <QTimer>
#include <kross/core/action.h>

// This is our QObject our scripting code will access
class MyObject : public QObject
    MyObject(QObject* parent)
      : QObject(parent), m_timer(new QTimer(this))
      // Calls the init() scripting function if available.
      emit init();
      // On timeout call the update() scripting function
      // if available.
      connect(m_timer, SIGNAL(timeout()), SIGNAL(update()));
      // Start the timer.
    virtual ~MyObject() {}

    // Return the timers interval in milliseconds
    int interval() const { return m_timer.interval(); }
    // Set the timers interval in milliseconds
    void setInterval(int ms) { m_timer.setInterval(ms); }

    // If emitted calls the init() scripting function
    // if available.
    void init();
    // If emitted calls the update() scripting function
    // if available.
    void update();

    Q_Timer* m_timer;

// Execute a script file.
static void execScriptFile(MyObject* myobject, const QString& file)
  // Create the script container. myobject is the parent QObject,
  // so that our action instance will be destroyed once the myobject
  // is destroyed.
  Kross::Action* action = new Kross::Action(myobject, file);
  // Publish our myobject instance and connect signals with
  // scripting functions.
    myobject, "myobject",
  // Set the file we like to execute.
  // Execute the script.

The execScriptFile function does create an instance of Kross::Action that is used as abstract container to deal with scripts / script files.

We then add our myobject instance to the action. That way scripting code is able to access the publish QObject instance, call it slots and connect with the signals.

Cause Kross::ChildrenInterface::AutoConnectSignals is defined, the init() and the update() signals the myobject instance provides will be automaticaly connected to matching scripting functions.

Then the script file that should be executed is set. The used interpreter will be determinated by the file-extension like e.g. *.py for Python or or *.rb for Ruby. You are also able to set the interpreter explicit with e.g. action->setInterpreter("python") or action->setInterpreter("ruby"). You are also able to use action->setCode("print 'hello world'") to set the scripting code direct.

Finally the script is executed. This is done by triggering the action. Once executed you are also able to use Kross::ErrorInterface to check if the action was executed successfully like demonstrate below.

  if( action->hadError() )
    kDebug() << action->errorMessage() << endl;

The Kross::Manager provides also the option to connect with the started and finished signals that got emitted if a script got executed.

connect(&Kross::Manager::self(), SIGNAL( started(Kross::Action*) ),
        this, SLOT( started(Kross::Action*) ));
connect(&Kross::Manager::self(), SIGNAL( finished(Kross::Action*) ),
        this, SLOT( finished(Kross::Action*) ));

The Kross::ActionCollection class manages collections of Kross::Action instances, enables hierachies and implements serializing from/to XML.

The Python scripting code

The following Python script demonstrates how a Python plugin looks like. The init() and the update() functions will be called if the matching signals at the myobject instance are emitted.

import myobject

def init():

def update():
  print "interval=%i" % myobject.interval()

The Ruby scripting code

The following Ruby script does the same as the Python scripting code above except by using the Ruby scripting language. This shows, that the same rich API functionality is accessible independend of the used scripting language.

require 'myobject'

def init()

def update()
  puts "interval=%i" % Myobject.interval()

Content is available under Creative Commons License SA 4.0 unless otherwise noted.