diff libgaim/dbus-useful.c @ 20389:e354528c4163

propagate from branch 'im.pidgin.gaim' (head 70ac931e4936c7916eec18a07fe46a0af0fd7403) to branch 'im.pidgin.rlaager.merging.soc-msnp13-to-svn18164' (head 5b5cde92182d2a922a8e7e6c2308342a5490a8c9)
author Richard Laager <rlaager@wiktel.com>
date Sun, 15 Apr 2007 02:10:37 +0000
parents 60b1bc8dbf37
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/libgaim/dbus-useful.c	Sun Apr 15 02:10:37 2007 +0000
@@ -0,0 +1,53 @@
+#include <string.h>
+#include <glib.h>
+
+#include "dbus-useful.h"
+#include "conversation.h"
+#include "util.h"
+
+
+GaimAccount *
+gaim_accounts_find_ext(const char *name, const char *protocol_id,
+		       gboolean (*account_test)(const GaimAccount *account))
+{
+	GaimAccount *result = NULL;
+	GList *l;
+	char *who;
+
+	if (name)
+		who = g_strdup(gaim_normalize(NULL, name));
+	else
+		who = NULL;
+
+	for (l = gaim_accounts_get_all(); l != NULL; l = l->next) {
+		GaimAccount *account = (GaimAccount *)l->data;
+
+		if (who && strcmp(gaim_normalize(NULL, gaim_account_get_username(account)), who))
+			continue;
+
+		if (protocol_id && strcmp(account->protocol_id, protocol_id))
+			continue;
+
+		if (account_test && !account_test(account))
+			continue;
+
+		result = account;
+		break;
+	}
+
+	g_free(who);
+
+	return result;
+}
+
+GaimAccount *gaim_accounts_find_any(const char *name, const char *protocol)
+{
+	return gaim_accounts_find_ext(name, protocol, NULL);
+}
+
+GaimAccount *gaim_accounts_find_connected(const char *name, const char *protocol)
+{
+	return gaim_accounts_find_ext(name, protocol, gaim_account_is_connected);
+}
+
+