From 90825e2392b2d70e43c7a25b8a3752299a933894 Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features. BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdebindings@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- kjsembed/jsbindingplugin.h | 66 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 66 insertions(+) create mode 100644 kjsembed/jsbindingplugin.h (limited to 'kjsembed/jsbindingplugin.h') diff --git a/kjsembed/jsbindingplugin.h b/kjsembed/jsbindingplugin.h new file mode 100644 index 00000000..6755621b --- /dev/null +++ b/kjsembed/jsbindingplugin.h @@ -0,0 +1,66 @@ +// -*- c++ -*- + +/* + * Copyright (C) 2001-2003, Richard J. Moore + * + * 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. + */ + +#ifndef KJSEMBEDBINDINGPLUGIN_H +#define KJSEMBEDBINDINGPLUGIN_H +#include +#include +#include +#include + +#include + +namespace KJSEmbed { + + class KJSEmbedPart; + + namespace Bindings { + /** + * Interface for KJSBindings that can be added as plugins. + * + * @author Ian Reinhart Geiser, geiseri@kde.org + * @version $Id$ + */ + class KJSEMBED_EXPORT JSBindingPlugin : public QObject { + Q_OBJECT + public: + JSBindingPlugin( QObject *parent, const char *name, const QStringList &args ); + virtual ~JSBindingPlugin(); + /** + * This method is called by the KJSFactory to bootstrap the plugin. + * Plugin developers will want to use this method to create their QObject binding, + * or call their addBindings() method in their JSOpaque proxy or JSValueProxy. + * + * The value returned from ths function is the KJS::Object that represents the + * proxy arround the added object. + */ + virtual KJS::Object createBinding( KJSEmbedPart *jspart, KJS::ExecState *exec, const KJS::List &args ) const = 0; + + /** + * add bindings to an object (eg an qobject returned by a slot + */ + virtual void addBindings( KJS::ExecState * /*exec*/, KJS::Object & /*target*/ ) const {} + ; + }; + } // Bindings +} // KJSEmbed + +#endif -- cgit v1.2.1