From a6d58bb6052ac8cb01805a48c4ad2f129126116f Mon Sep 17 00:00:00 2001 From: tpearson Date: Wed, 24 Feb 2010 02:13:59 +0000 Subject: Added KDE3 version of kvirc git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/kvirc@1095341 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- src/modules/context/Makefile.am | 18 ++ src/modules/context/libkvicontext.cpp | 401 ++++++++++++++++++++++++++++++++++ 2 files changed, 419 insertions(+) create mode 100644 src/modules/context/Makefile.am create mode 100644 src/modules/context/libkvicontext.cpp (limited to 'src/modules/context') diff --git a/src/modules/context/Makefile.am b/src/modules/context/Makefile.am new file mode 100644 index 00000000..e4ec3252 --- /dev/null +++ b/src/modules/context/Makefile.am @@ -0,0 +1,18 @@ +############################################################################### +# KVirc IRC client Makefile - 10.03.2000 Szymon Stefanek +############################################################################### + +AM_CPPFLAGS = -I$(SS_TOPSRCDIR)/src/kvilib/include/ -I$(SS_TOPSRCDIR)/src/kvirc/include/ \ +$(SS_INCDIRS) $(SS_CPPFLAGS) -DGLOBAL_KVIRC_DIR=\"$(globalkvircdir)\" + +pluglib_LTLIBRARIES = libkvicontext.la + +libkvicontext_la_LDFLAGS = -module -avoid-version $(SS_LDFLAGS) $(SS_LIBDIRS) + +libkvicontext_la_SOURCES = libkvicontext.cpp +libkvicontext_la_LIBADD = $(SS_LIBLINK) ../../kvilib/build/libkvilib.la + +# noinst_HEADERS= + +%.moc: %.h + $(SS_QT_MOC) $< -o $@ diff --git a/src/modules/context/libkvicontext.cpp b/src/modules/context/libkvicontext.cpp new file mode 100644 index 00000000..a6a3bb97 --- /dev/null +++ b/src/modules/context/libkvicontext.cpp @@ -0,0 +1,401 @@ +//============================================================================= +// +// File : libkvicontext.cpp +// Creation date : Wed Jan 02 2007 03:04:12 GMT by Szymon Stefanek +// +// This file is part of the KVirc irc client distribution +// Copyright (C) 2007 Szymon Stefanek (pragma at kvirc dot net) +// +// This program is FREE software. You can redistribute it and/or +// modify it under the terms of the GNU General Public License +// as published by the Free Software Foundation; either version 2 +// of the License, or (at your opinion) any later version. +// +// 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 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. +// +//============================================================================= + +//#warning: FIXME: Incomplete documentation ('seealso', 'example', etc) + +#include "kvi_module.h" +#include "kvi_locale.h" +#include "kvi_qstring.h" +#include "kvi_window.h" +#include "kvi_frame.h" +#include "kvi_console.h" +#include "kvi_app.h" + +#include "kvi_ircserver.h" +#include "kvi_irccontext.h" +#include "kvi_ircconnection.h" +#include "kvi_ircconnectionserverinfo.h" +#include "kvi_ircconnectionuserinfo.h" +#include "kvi_ircconnectiontarget.h" + +#define GET_CONSOLE_FROM_STANDARD_PARAMS \ + kvs_int_t iContextId; \ + KVSM_PARAMETERS_BEGIN(c) \ + KVSM_PARAMETER("irc_context_id",KVS_PT_UINT,KVS_PF_OPTIONAL,iContextId) \ + KVSM_PARAMETERS_END(c) \ + KviConsole * pConsole = NULL; \ + if(c->parameterCount() > 0) \ + pConsole = g_pApp->findConsole(iContextId); \ + else \ + pConsole = c->window()->console(); + +#define GET_CONNECTION_FROM_STANDARD_PARAMS \ + GET_CONSOLE_FROM_STANDARD_PARAMS \ + KviIrcConnection * pConnection = NULL; \ + if(pConsole) \ + pConnection = pConsole->context()->connection(); + +#define STANDARD_IRC_CONNECTION_TARGET_PARAMETER(_fncName,_setCall) \ + static bool _fncName(KviKvsModuleFunctionCall * c) \ + { \ + GET_CONNECTION_FROM_STANDARD_PARAMS \ + if(pConnection) \ + { \ + if(pConnection->target()) \ + { \ + _setCall; \ + return true; \ + } \ + } \ + c->returnValue()->setNothing(); \ + return true; \ + } + +/* + @doc: context.networkName + @type: + function + @title: + $context.networkName + @short: + Returns the IRC network name of an IRC context + @syntax: + $contex.networkName + $contex.networkName() + @description: + Returns the name of the network for the specified IRC context. + If no irc_context_id is specified then the current irc_context is used. + If the irc_context_id specification is not valid then this function + returns nothing. If the specified IRC context is not currently connected + then this function returns nothing. + @seealso: + [fnc]$context.serverHostName[/fnc] +*/ + +STANDARD_IRC_CONNECTION_TARGET_PARAMETER( + context_kvs_fnc_networkName, + c->returnValue()->setString(pConnection->target()->network()->name()) + ) + + +/* + @doc: context.serverHostName + @type: + function + @title: + $context.serverHostName + @short: + Returns the IRC server name of an IRC context + @syntax: + $contex.serverHostName + $contex.serverHostName() + @description: + Returns the host name of the IRC server that was used to perform + the connection in the specified irc context. + If no irc_context_id is specified then the current irc_context is used. + If the irc_context_id specification is not valid then this function + returns nothing. If the specified IRC context is not currently connected + then this function returns nothing. + If the returned value is non empty then it will always be a valid + DNS hostname that can be used to perform a real connection. + Please note that this is different from $my.server() which might + return an invalid DNS entry. + @seealso: + [fnc]$context.serverPort[/fnc], + [fnc]$context.serverIpAddress[/fnc], + [fnc]$context.serverPassword[/fnc] +*/ + +STANDARD_IRC_CONNECTION_TARGET_PARAMETER( + context_kvs_fnc_serverHostName, + c->returnValue()->setString(pConnection->target()->server()->hostName()) + ) + +/* + @doc: context.serverIpAddress + @type: + function + @title: + $context.serverIpAddress + @short: + Returns the IRC server ip address of an IRC context + @syntax: + $contex.serverIpAddress + $contex.serverIpAddress() + @description: + Returns the ip address of the IRC server for the specified irc context. + If no irc_context_id is specified then the current irc_context is used. + If the irc_context_id specification is not valid then this function + returns nothing. If the specified IRC context is not currently connected + then this function returns nothing. + @seealso: + [fnc]$context.serverPort[/fnc], + [fnc]$context.serverHostName[/fnc], + [fnc]$context.serverPassword[/fnc] +*/ + +STANDARD_IRC_CONNECTION_TARGET_PARAMETER( + context_kvs_fnc_serverIpAddress, + c->returnValue()->setString(pConnection->target()->server()->ipAddress()) + ) + +/* + @doc: context.serverIsIPV6 + @type: + function + @title: + $context.serverIsIPV6 + @short: + Returns the IPV6 state of an IRC context + @syntax: + $contex.serverIsIPV6 + $contex.serverIsIPV6() + @description: + Returns true if the current irc context connection runs over IPV6. + If no irc_context_id is specified then the current irc_context is used. + If the irc_context_id specification is not valid then this function + returns nothing (that evaluates to false). If the specified IRC context + is not currently connected then this function returns nothing (that + evaluates to false). + @seealso: + [fnc]$context.serverPort[/fnc], + [fnc]$context.serverHostName[/fnc], + [fnc]$context.serverPassword[/fnc] +*/ + +STANDARD_IRC_CONNECTION_TARGET_PARAMETER( + context_kvs_fnc_serverIsIPV6, + c->returnValue()->setBoolean(pConnection->target()->server()->isIpV6()) + ) + +/* + @doc: context.serverIsSSL + @type: + function + @title: + $context.serverIsSSL + @short: + Returns the SSL state of an IRC context + @syntax: + $contex.serverIsSSL + $contex.serverIsSSL() + @description: + Returns true if the current irc context connection runs over SSL. + If no irc_context_id is specified then the current irc_context is used. + If the irc_context_id specification is not valid then this function + returns nothing (that evaluates to false). If the specified IRC context + is not currently connected then this function returns nothing (that + evaluates to false). + @seealso: + [fnc]$context.serverPort[/fnc], + [fnc]$context.serverHostName[/fnc], + [fnc]$context.serverPassword[/fnc] +*/ + +STANDARD_IRC_CONNECTION_TARGET_PARAMETER( + context_kvs_fnc_serverIsSSL, + c->returnValue()->setBoolean(pConnection->target()->server()->useSSL()) + ) + +/* + @doc: context.serverPassword + @type: + function + @title: + $context.serverPassword + @short: + Returns the password used to login to the server of an IRC context + @syntax: + $contex.serverPassword + $contex.serverPassword() + @description: + Returns the password used to login to the IRC server for the specified irc context. + If no irc_context_id is specified then the current irc_context is used. + If the irc_context_id specification is not valid then this function + returns nothing. If the specified IRC context is not currently connected + then this function returns nothing. + @seealso: + [fnc]$context.serverHostName[/fnc], + [fnc]$context.serverIpAddress[/fnc], + [fnc]$context.serverPort[/fnc] +*/ + +STANDARD_IRC_CONNECTION_TARGET_PARAMETER( + context_kvs_fnc_serverPassword, + c->returnValue()->setString(pConnection->target()->server()->password()) + ) + + +/* + @doc: context.serverPort + @type: + function + @title: + $context.serverPort + @short: + Returns the port of the IRC server of an IRC context + @syntax: + $contex.serverPort + $contex.serverPort() + @description: + Returns the port of the IRC server for the specified irc context. + If no irc_context_id is specified then the current irc_context is used. + If the irc_context_id specification is not valid then this function + returns nothing. If the specified IRC context is not currently connected + then this function returns nothing. + @seealso: + [fnc]$context.serverHostName[/fnc], + [fnc]$context.serverIpAddress[/fnc] +*/ + +STANDARD_IRC_CONNECTION_TARGET_PARAMETER( + context_kvs_fnc_serverPort, + c->returnValue()->setInteger(pConnection->target()->server()->port()) + ) + + +/* + @doc: context.state + @type: + function + @title: + $context.state + @short: + Returns the state of an IRC context + @syntax: + $context.state + $context.state() + @description: + Returns a string describing the state of the specified irc context. + The string will be either "idle","connecting","loggingin" or "connected". + If no irc_context_id is specified then the current irc_context is used. + If the irc_context_id specification is not valid then this function + returns nothing. + @seealso: + [fnc]$context.serverHostName[/fnc], + [fnc]$context.serverIpAddress[/fnc] +*/ + +static bool context_kvs_fnc_state(KviKvsModuleFunctionCall * c) +{ + GET_CONSOLE_FROM_STANDARD_PARAMS + + if(pConsole) + { + switch(pConsole->ircContext()->state()) + { + case KviIrcContext::Idle: + c->returnValue()->setString(QString("idle")); + break; + case KviIrcContext::Connecting: + c->returnValue()->setString(QString("connecting")); + break; + case KviIrcContext::LoggingIn: + c->returnValue()->setString(QString("loggingin")); + break; + case KviIrcContext::Connected: + c->returnValue()->setString(QString("connected")); + break; + default: + c->returnValue()->setString(QString("unknown")); + break; + } + return true; + } + + c->returnValue()->setNothing(); + return true; +} + + +/* + @doc: context.list + @type: + function + @title: + $context.list + @short: + Returns a list of existing IRC contexts + @syntax: + $contex.list + @description: + Returns the array of currently existing IRC context identifiers. + @seealso: + @examples: + Print the names of the currently connected servers + [example] + foreach(%ic,$context.list) + echo "IRC Context" %ic ": " $context.serverHostName + [/example] +*/ + +static bool context_kvs_fnc_list(KviKvsModuleFunctionCall * c) +{ + KviKvsArray * pArray = new KviKvsArray(); + + KviPointerList * pWinList = g_pFrame->windowList(); + int idx = 0; + for(KviWindow * pWnd = pWinList->first();pWnd;pWnd = pWinList->next()) + { + if(pWnd->type() == KVI_WINDOW_TYPE_CONSOLE) + { + pArray->set(idx,new KviKvsVariant((kvs_int_t)((KviConsole *)pWnd)->ircContextId())); + idx++; + } + } + + c->returnValue()->setArray(pArray); + return true; +} + +static bool context_module_init(KviModule * m) +{ + KVSM_REGISTER_FUNCTION(m,"serverHostName",context_kvs_fnc_serverHostName); + KVSM_REGISTER_FUNCTION(m,"serverIpAddress",context_kvs_fnc_serverIpAddress); + KVSM_REGISTER_FUNCTION(m,"serverPort",context_kvs_fnc_serverPort); + KVSM_REGISTER_FUNCTION(m,"serverIsIPV6",context_kvs_fnc_serverIsIPV6); + KVSM_REGISTER_FUNCTION(m,"serverIsSSL",context_kvs_fnc_serverIsSSL); + KVSM_REGISTER_FUNCTION(m,"serverPassword",context_kvs_fnc_serverPassword); + KVSM_REGISTER_FUNCTION(m,"networkName",context_kvs_fnc_networkName); + KVSM_REGISTER_FUNCTION(m,"state",context_kvs_fnc_state); + KVSM_REGISTER_FUNCTION(m,"list",context_kvs_fnc_list); + + return true; +} + +static bool context_module_cleanup(KviModule *m) +{ + return true; +} + +KVIRC_MODULE( + "context", + "1.0.0", + "Copyright (C) 2007 Szymon Stefanek (pragma at kvirc dot net)", + "Irc Context Related Functions", + context_module_init, + 0, + 0, + context_module_cleanup +) -- cgit v1.2.1