Adding the timeout did not work.  I'm fairly new to backtracing, but I
followed the directions from the pidgin wiki and here's what I got:

*When the segfault occurred while running:

Adding buddy...
(20:08:00) oscar: ssi: adding buddy 401787217 to group Buddies
(20:08:00) oscar: Requesting ICQ alias for 401787217(20:08:00) oscar:
icq response: 60 bytes, 579746952, 0x07da, 0x0024
(20:08:00) oscar: ssi: status is 0x000e for a 0x0008 action with name no
item

Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0xb79318d0 (LWP 25796)]
purple_auth_request (data=0xb7eceff4, msg=0x8791008 "") at oscar.c:2533
2533            od = gc->proto_data;

*The backtrace:

#0  purple_auth_request (data=0xb7eceff4, msg=0x8791008 "") at
oscar.c:2533
        gc = (PurpleConnection *) 0xb6ebc
        account = (PurpleAccount *) 0xbfc027a8
        buddy = <value optimized out>
        group = <value optimized out>
#1  0x08048fce in request_input_cb ()
No locals.
#2  0xb7e522b6 in ?? () from /usr/lib/libglib-2.0.so.0
No symbol table info available.
#3  0xb7e51b88 in g_main_context_dispatch ()
from /usr/lib/libglib-2.0.so.0
No symbol table info available.
#4  0xb7e550eb in ?? () from /usr/lib/libglib-2.0.so.0
No symbol table info available.
#5  0xb7e555ba in g_main_loop_run () from /usr/lib/libglib-2.0.so.0
No symbol table info available.
#6  0x080491e0 in main ()
No locals.

I also attached the full source code of the program, as simplified as
possible (the only difference is that my password is replaced with
"PASSWORD").  I compile it with:

gcc `pkg-config --libs glib-2.0` -I /usr/include/libpurple/
-I /usr/include/glib-2.0/ -I /usr/lib/glib-2.0/include/ test.c -lpurple
-o test

...if that makes any difference

Let me know if you need any more information.

-Michael
#define CUSTOM_USER_DIRECTORY  "/dev/null"
#define CUSTOM_PLUGIN_PATH     ""
#define PLUGIN_SAVE_PREF       "/purple/master/plugins/saved"
#define UI_ID                  "master"
/*
 * pidgin
 *
 * Pidgin is the legal property of its developers, whose names are too numerous
 * to list here.  Please refer to the COPYRIGHT file distributed with this
 * source distribution.
 *
 * 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., 51 Franklin Street, Fifth Floor, Boston, MA  02111-1301  USA
 *
 */

#include "purple.h"

#include <glib.h>

#include <signal.h>
#include <string.h>
#include <unistd.h>

#include "defines.h"

#include <stdio.h>

/**
 * The following eventloop functions are used in both pidgin and purple-text. If your
 * application uses glib mainloop, you can safely use this verbatim.
 */
#define PURPLE_GLIB_READ_COND  (G_IO_IN | G_IO_HUP | G_IO_ERR)
#define PURPLE_GLIB_WRITE_COND (G_IO_OUT | G_IO_HUP | G_IO_ERR | G_IO_NVAL)

typedef struct _PurpleGLibIOClosure {
	PurpleInputFunction function;
	guint result;
	gpointer data;
} PurpleGLibIOClosure;

static void purple_glib_io_destroy(gpointer data)
{
	g_free(data);
}

static gboolean purple_glib_io_invoke(GIOChannel *source, GIOCondition condition, gpointer data)
{
	PurpleGLibIOClosure *closure = data;
	PurpleInputCondition purple_cond = 0;

	if (condition & PURPLE_GLIB_READ_COND)
		purple_cond |= PURPLE_INPUT_READ;
	if (condition & PURPLE_GLIB_WRITE_COND)
		purple_cond |= PURPLE_INPUT_WRITE;

	closure->function(closure->data, g_io_channel_unix_get_fd(source),
			  purple_cond);

	return TRUE;
}

static guint glib_input_add(gint fd, PurpleInputCondition condition, PurpleInputFunction function,
							   gpointer data)
{
	PurpleGLibIOClosure *closure = g_new0(PurpleGLibIOClosure, 1);
	GIOChannel *channel;
	GIOCondition cond = 0;

	closure->function = function;
	closure->data = data;

	if (condition & PURPLE_INPUT_READ)
		cond |= PURPLE_GLIB_READ_COND;
	if (condition & PURPLE_INPUT_WRITE)
		cond |= PURPLE_GLIB_WRITE_COND;

	channel = g_io_channel_unix_new(fd);
	closure->result = g_io_add_watch_full(channel, G_PRIORITY_DEFAULT, cond,
					      purple_glib_io_invoke, closure, purple_glib_io_destroy);

	g_io_channel_unref(channel);
	return closure->result;
}

static PurpleEventLoopUiOps glib_eventloops = 
{
	g_timeout_add,
	g_source_remove,
	glib_input_add,
	g_source_remove,
	NULL,
#if GLIB_CHECK_VERSION(2,14,0)
	g_timeout_add_seconds,
#else
	NULL,
#endif

	/* padding */
	NULL,
	NULL,
	NULL
};
/*** End of the eventloop functions. ***/



gboolean request_input_cb(gpointer data)
{
GCallback ok_cb = data;
ok_cb();
}


static void
*request_input(const char *title, const char *primary, const char *secondary, const char *default_value, gboolean multiline, gboolean masked, gchar *hint, const char *ok_text, GCallback ok_cb, const char *cancel_text, GCallback cancel_cb, PurpleAccount *account, const char *who, PurpleConversation *conv, void *user_data)
{
purple_timeout_add(2, request_input_cb, ok_cb);
}



static PurpleRequestUiOps request_uiops = 
{
	request_input, /* request_input  */
	NULL,          /* request_choice */
	NULL,          /* request_action */
	NULL,          /* request_fields */
	NULL,          /* request_file   */
	NULL,          /* close_request  */
	NULL,          /* request_folder */
	NULL,
	NULL,
	NULL,
	NULL
};



static void
null_ui_init(void)
{
	/**
	 * This should initialize the UI components for all the modules.
	 */
	purple_request_set_ui_ops(&request_uiops);
}

static PurpleCoreUiOps null_core_uiops = 
{
	NULL,
	NULL,
	null_ui_init,
	NULL,

	/* padding */
	NULL,
	NULL,
	NULL,
	NULL
};

static void
init_libpurple(void)
{
	/* Set a custom user directory (optional) */
	purple_util_set_user_dir(CUSTOM_USER_DIRECTORY);

	/* We do not want any debugging for now to keep the noise to a minimum. */
	purple_debug_set_enabled(TRUE);

	/* Set the core-uiops, which is used to
	 * 	- initialize the ui specific preferences.
	 * 	- initialize the debug ui.
	 * 	- initialize the ui components for all the modules.
	 * 	- uninitialize the ui components for all the modules when the core terminates.
	 */
	purple_core_set_ui_ops(&null_core_uiops);

	/* Set the uiops for the eventloop. If your client is glib-based, you can safely
	 * copy this verbatim. */
	purple_eventloop_set_ui_ops(&glib_eventloops);

	/* Set path to search for plugins. The core (libpurple) takes care of loading the
	 * core-plugins, which includes the protocol-plugins. So it is not essential to add
	 * any path here, but it might be desired, especially for ui-specific plugins. */
	purple_plugins_add_search_path(CUSTOM_PLUGIN_PATH);

	/* Now that all the essential stuff has been set, let's try to init the core. It's
	 * necessary to provide a non-NULL name for the current ui to the core. This name
	 * is used by stuff that depends on this ui, for example the ui-specific plugins. */
	if (!purple_core_init(UI_ID)) {
		/* Initializing the core failed. Terminate. */
		fprintf(stderr,
				"libpurple initialization failed. Dumping core.\n"
				"Please report this!\n");
		abort();
	}

	/* Create and load the buddylist. */
	purple_set_blist(purple_blist_new());
	purple_blist_load();

	/* Load the preferences. */
//	purple_prefs_load();

	/* Load the desired plugins. The client should save the list of loaded plugins in
	 * the preferences using purple_plugins_save_loaded(PLUGIN_SAVE_PREF) */
	purple_plugins_load_saved(PLUGIN_SAVE_PREF);

	/* Load the pounces. */
	purple_pounces_load();
}


gboolean test(gpointer data)
{
	PurpleAccount *account = data;
	PurpleBuddy *buddy = purple_buddy_new(account, "401787217", NULL);
	printf("Adding buddy...\n");
	purple_blist_add_buddy(buddy, NULL, purple_find_group("Buddies"), NULL);
	purple_account_add_buddy(account, buddy);
}


int main(int argc, char *argv[])
{

	GMainLoop *loop = g_main_loop_new(NULL, FALSE);

	/* libpurple's built-in DNS resolution forks processes to perform
	 * blocking lookups without blocking the main process.  It does not
	 * handle SIGCHLD itself, so if the UI does not you quickly get an army
	 * of zombie subprocesses marching around.
	 */
	signal(SIGCHLD, SIG_IGN);

	init_libpurple();

	printf("libpurple initialized.\n");

	PurpleAccount *account = purple_account_new("579746952", "prpl-icq");
	purple_account_set_password(account, "PASSWORD");
	purple_accounts_add(account);
	purple_account_set_enabled(account, UI_ID, TRUE);
	purple_timeout_add_seconds(10, test, account); //gives the account time to connect first

	g_main_loop_run(loop);

	return 0;
}
_______________________________________________
Support@pidgin.im mailing list
Want to unsubscribe?  Use this link:
http://pidgin.im/cgi-bin/mailman/listinfo/support

Reply via email to