From 71f818d1e71321be50f24780905a74e9a6ab90da Mon Sep 17 00:00:00 2001 From: "Aaron J. Seigo" Date: Wed, 18 Nov 2009 22:55:46 +0000 Subject: [PATCH] Restore files svn path=/trunk/KDE/kdebase/runtime/; revision=1051162 --- .../javascript/simplebindings/url.cpp | 125 ++++++++++++++++++ 1 file changed, 125 insertions(+) create mode 100644 scriptengines/javascript/simplebindings/url.cpp diff --git a/scriptengines/javascript/simplebindings/url.cpp b/scriptengines/javascript/simplebindings/url.cpp new file mode 100644 index 000000000..950c2dd2d --- /dev/null +++ b/scriptengines/javascript/simplebindings/url.cpp @@ -0,0 +1,125 @@ +/* + * Copyright 2007 Richard J. Moore + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU Library General Public License version 2 as + * published by the Free Software Foundation + * + * 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 General Public License for more details + * + * You should have received a copy of the GNU Library General Public + * License along with this program; if not, write to the + * Free Software Foundation, Inc., + * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + */ + +#include +#include +#include +#include +#include "../backportglobal.h" + +Q_DECLARE_METATYPE(KUrl*) +//Q_DECLARE_METATYPE(KUrl) unneeded; found in kurl.h + +static QScriptValue ctor(QScriptContext *ctx, QScriptEngine *eng) +{ + if (ctx->argumentCount() == 1) + { + QString url = ctx->argument(0).toString(); + return qScriptValueFromValue(eng, KUrl(url)); + } + + return qScriptValueFromValue(eng, KUrl()); +} + +static QScriptValue toString(QScriptContext *ctx, QScriptEngine *eng) +{ + DECLARE_SELF(KUrl, toString); + return QScriptValue(eng, self->prettyUrl()); +} + +static QScriptValue protocol(QScriptContext *ctx, QScriptEngine *eng) +{ + DECLARE_SELF(KUrl, protocol); + if (ctx->argumentCount()) { + QString v = ctx->argument(0).toString(); + self->setProtocol(v); + } + + return QScriptValue(eng, self->protocol()); +} + +static QScriptValue setProtocol(QScriptContext *ctx, QScriptEngine *) +{ + DECLARE_SELF(KUrl, setProtocol); + QString v = ctx->argument(0).toString(); + self->setProtocol(v); + return QScriptValue(); +} + +static QScriptValue host(QScriptContext *ctx, QScriptEngine *eng) +{ + DECLARE_SELF(KUrl, protocol); + if (ctx->argumentCount()) { + QString v = ctx->argument(0).toString(); + self->setHost(v); + } + + return QScriptValue(eng, self->host()); +} + +static QScriptValue path(QScriptContext *ctx, QScriptEngine *eng) +{ + DECLARE_SELF(KUrl, path); + if (ctx->argumentCount()) { + QString v = ctx->argument(0).toString(); + self->setPath(v); + } + + return QScriptValue(eng, self->path()); +} + +static QScriptValue user(QScriptContext *ctx, QScriptEngine *eng) +{ + DECLARE_SELF(KUrl, user); + if (ctx->argumentCount()) { + QString v = ctx->argument(0).toString(); + self->setUser(v); + } + + return QScriptValue(eng, self->user()); +} + +static QScriptValue password(QScriptContext *ctx, QScriptEngine *eng) +{ + DECLARE_SELF(KUrl, password); + if (ctx->argumentCount()) { + QString v = ctx->argument(0).toString(); + self->setPassword(v); + } + + return QScriptValue(eng, self->password()); +} + +QScriptValue constructKUrlClass(QScriptEngine *eng) +{ + QScriptValue proto = qScriptValueFromValue(eng, KUrl()); + QScriptValue::PropertyFlags getter = QScriptValue::PropertyGetter; + QScriptValue::PropertyFlags setter = QScriptValue::PropertySetter; + + proto.setProperty("toString", eng->newFunction(toString), getter); + proto.setProperty("protocol", eng->newFunction(protocol), getter | setter); + proto.setProperty("host", eng->newFunction(host), getter | setter); + proto.setProperty("path", eng->newFunction(path), getter | setter); + proto.setProperty("user", eng->newFunction(user), getter | setter); + proto.setProperty("password", eng->newFunction(password), getter | setter); + + eng->setDefaultPrototype(qMetaTypeId(), proto); + eng->setDefaultPrototype(qMetaTypeId(), proto); + + return eng->newFunction(ctor, proto); +}