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/jsopaqueproxy.cpp | 137 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 137 insertions(+) create mode 100644 kjsembed/jsopaqueproxy.cpp (limited to 'kjsembed/jsopaqueproxy.cpp') diff --git a/kjsembed/jsopaqueproxy.cpp b/kjsembed/jsopaqueproxy.cpp new file mode 100644 index 00000000..c5c2600d --- /dev/null +++ b/kjsembed/jsopaqueproxy.cpp @@ -0,0 +1,137 @@ +/* + * 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. + */ + +#include +#include + +#include "global.h" + +#include +#include +#include + +#include "jsbinding.h" +#include "jsobjectproxy.h" +#include "jsobjectproxy_imp.h" +#include "jsvalueproxy_imp.h" + +#include "jsopaqueproxy_imp.h" +#include "jsopaqueproxy.h" + +namespace KJSEmbed { + +typedef Bindings::JSOpaqueProxyImp JSOpaqueProxyImp; + +JSOpaqueProxy::JSOpaqueProxy() + : JSProxy( JSProxy::OpaqueProxy ), ptr(0) +{ +} + +JSOpaqueProxy::JSOpaqueProxy( QTextStream *ts ) + : JSProxy( JSProxy::OpaqueProxy ), ptr(0) +{ + setValue( ts ); +} + +JSOpaqueProxy::JSOpaqueProxy( const QEvent *ev ) + : JSProxy( JSProxy::OpaqueProxy ), ptr(0) +{ + setValue( ev ); +} + +JSOpaqueProxy::~JSOpaqueProxy() +{ + kdDebug() << "Delete JSOpaqueProxy " << endl; + + if( ptr ) { + if(owner() == JavaScript + && ptr->type() != typeid(void) ) ptr->cleanup(); + delete ptr; + } +} + +QString JSOpaqueProxy::typeName() const +{ + return ptrtype; +} + +bool JSOpaqueProxy::inherits( const char *clazz ) +{ + return (ptrtype == clazz); +} + +void JSOpaqueProxy::setValue( QTextStream *ts ) +{ + if( ptr ) { + if(owner() == JavaScript) ptr->cleanup(); + delete ptr; + } + ptr = new Pointer(ts); + ptrtype = "QTextStream"; +} + +void JSOpaqueProxy::setValue( const QEvent *ev ) +{ + if( ptr ) { + if(owner() == JavaScript) ptr->cleanup(); + delete ptr; + } + ptr = new Pointer(ev); + ptrtype = "QEvent"; +} + +QTextStream *JSOpaqueProxy::toTextStream() +{ + return toNative(); +} + +const QEvent *JSOpaqueProxy::toEvent() +{ + return toNative(); +} + +void JSOpaqueProxy::addBindings( KJS::ExecState *exec, KJS::Object &object ) +{ + MethodTable methods[] = { + { JSOpaqueProxyImp::MethodTypeName, "typeName" }, + { 0, 0 } + }; + + int i = 0; + do { + JSOpaqueProxyImp *obj = new JSOpaqueProxyImp( exec, methods[i].id, this ); + obj->setName( KJS::Identifier( methods[i].name ) ); + object.put( exec , obj->name(), KJS::Object(obj) ); + i++; + } while( methods[i].id ); +} + +KJS::UString JSOpaqueProxy::toString( KJS::ExecState */*exec*/ ) const +{ + QString s( "%1 (%2)" ); + return KJS::UString( s.arg("JSOpaqueProxy").arg(ptrtype) ); +} + + +} // namespace KJSEmbed + +// Local Variables: +// c-basic-offset: 4 +// End: + -- cgit v1.2.1