Mercurial > pidgin
view libpurple/plugins/ipc-test-server.c @ 17576:d495103dcf88
Two questions:
1. XMPP <status> messages inside <presence> broadcasts should be
plaintext and not HTML, right?
2. 'stripped = purple_markup_strip_html(str)' is basically the same as
'purple_markup_html_to_xhtml(str, NULL, &stripped)', right?
This fixes a bug Emily found where setting an XMPP status message with
an embedded link would drop the link completely. For example, in
Pidgin you set your away message and insert a link so that the message
body is <a href="http://www.example.com/">Example</a>. When we set
this message for an XMPP account it just strips the HTML and sets the
message to "Example". This change causes the message to be
"Example (http://www.example.com/)". It's the same thing we do when
displaying links in tooltips in the blist.
author | Mark Doliner <mark@kingant.net> |
---|---|
date | Sun, 10 Jun 2007 15:58:23 +0000 |
parents | 32c366eeeb99 |
children | 44b4e8bd759b |
line wrap: on
line source
/* * IPC test server plugin. * * Copyright (C) 2003 Christian Hammond. * * 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 option) 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., 59 Temple Place - Suite 330, Boston, MA * 02111-1307, USA. */ #define IPC_TEST_SERVER_PLUGIN_ID "core-ipc-test-server" #include "internal.h" #include "debug.h" #include "plugin.h" #include "version.h" static int add_func(int i1, int i2) { purple_debug_misc("ipc-test-server", "Got %d, %d, returning %d\n", i1, i2, i1 + i2); return i1 + i2; } static int sub_func(int i1, int i2) { purple_debug_misc("ipc-test-server", "Got %d, %d, returning %d\n", i1, i2, i1 - i2); return i1 - i2; } static gboolean plugin_load(PurplePlugin *plugin) { purple_plugin_ipc_register(plugin, "add", PURPLE_CALLBACK(add_func), purple_marshal_INT__INT_INT, purple_value_new(PURPLE_TYPE_INT), 2, purple_value_new(PURPLE_TYPE_INT), purple_value_new(PURPLE_TYPE_INT)); purple_plugin_ipc_register(plugin, "sub", PURPLE_CALLBACK(sub_func), purple_marshal_INT__INT_INT, purple_value_new(PURPLE_TYPE_INT), 2, purple_value_new(PURPLE_TYPE_INT), purple_value_new(PURPLE_TYPE_INT)); return TRUE; } static PurplePluginInfo info = { PURPLE_PLUGIN_MAGIC, PURPLE_MAJOR_VERSION, PURPLE_MINOR_VERSION, PURPLE_PLUGIN_STANDARD, /**< type */ NULL, /**< ui_requirement */ 0, /**< flags */ NULL, /**< dependencies */ PURPLE_PRIORITY_DEFAULT, /**< priority */ IPC_TEST_SERVER_PLUGIN_ID, /**< id */ N_("IPC Test Server"), /**< name */ VERSION, /**< version */ /** summary */ N_("Test plugin IPC support, as a server."), /** description */ N_("Test plugin IPC support, as a server. This registers the IPC " "commands."), "Christian Hammond <chipx86@gnupdate.org>", /**< author */ PURPLE_WEBSITE, /**< homepage */ plugin_load, /**< load */ NULL, /**< unload */ NULL, /**< destroy */ NULL, /**< ui_info */ NULL, /**< extra_info */ NULL, NULL }; static void init_plugin(PurplePlugin *plugin) { } PURPLE_INIT_PLUGIN(ipctestserver, init_plugin, info)