telepathygabble/src/tp-channel-factory-iface.c
changeset 0 d0f3a028347a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/telepathygabble/src/tp-channel-factory-iface.c	Tue Feb 02 01:10:06 2010 +0200
@@ -0,0 +1,138 @@
+/*
+ * tp-channel-factory-iface.c - Stubs for Telepathy Channel Factory interface
+ *
+ * Copyright (C) 2006 Collabora Ltd.
+ * 
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library 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
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
+ */
+
+#include <glib-object.h>
+
+#include "tp-channel-factory-iface.h"
+#include "tp-channel-factory-iface-signals-marshal.h"
+#include "tp-channel-iface.h"
+
+
+#ifdef EMULATOR
+#include "libgabble_wsd_solution.h"
+
+	GET_STATIC_VAR_FROM_TLS(initialized,gabble_fac_iface,gboolean)
+	#define initialized (*GET_WSD_VAR_NAME(initialized,gabble_fac_iface, s)())	
+
+	GET_STATIC_VAR_FROM_TLS(type,gabble_fac_iface,GType)
+	#define type (*GET_WSD_VAR_NAME(type,gabble_fac_iface, s)())	
+
+#endif
+
+
+static void
+tp_channel_factory_iface_base_init (gpointer klass)
+{
+#ifndef EMULATOR
+  static gboolean initialized = FALSE;
+#endif
+
+  if (!initialized) {
+    initialized = TRUE;
+
+    g_signal_new ("new-channel",
+                  G_OBJECT_CLASS_TYPE (klass),
+                  G_SIGNAL_RUN_LAST | G_SIGNAL_DETAILED,
+                  0,
+                  NULL, NULL,
+                  g_cclosure_marshal_VOID__OBJECT,
+                  G_TYPE_NONE, 1, G_TYPE_OBJECT);
+
+    g_signal_new ("channel-error",
+                  G_OBJECT_CLASS_TYPE (klass),
+                  G_SIGNAL_RUN_LAST | G_SIGNAL_DETAILED,
+                  0,
+                  NULL, NULL,
+                  tp_channel_factory_iface_marshal_VOID__OBJECT_POINTER,
+                  G_TYPE_NONE, 2, G_TYPE_OBJECT, G_TYPE_POINTER);
+  }
+}
+
+GType
+tp_channel_factory_iface_get_type (void)
+{
+
+#ifndef EMULATOR
+  static GType type = 0;
+#endif
+
+  if (type == 0) {
+    static const GTypeInfo info = {
+      sizeof (TpChannelFactoryIfaceClass),
+      tp_channel_factory_iface_base_init,   /* base_init */
+      NULL,   /* base_finalize */
+      NULL,   /* class_init */
+      NULL,   /* class_finalize */
+      NULL,   /* class_data */
+      0,
+      0,      /* n_preallocs */
+      NULL    /* instance_init */
+    };
+
+    type = g_type_register_static (G_TYPE_INTERFACE, "TpChannelFactoryIface", &info, 0);
+  }
+
+  return type;
+}
+
+void
+tp_channel_factory_iface_close_all (TpChannelFactoryIface *self)
+{
+  TP_CHANNEL_FACTORY_IFACE_GET_CLASS (self)->close_all (self);
+}
+
+void
+tp_channel_factory_iface_connecting (TpChannelFactoryIface *self)
+{
+  TP_CHANNEL_FACTORY_IFACE_GET_CLASS (self)->connecting (self);
+}
+
+void
+tp_channel_factory_iface_connected (TpChannelFactoryIface *self)
+{
+  TP_CHANNEL_FACTORY_IFACE_GET_CLASS (self)->connected (self);
+}
+
+void
+tp_channel_factory_iface_disconnected (TpChannelFactoryIface *self)
+{
+  TP_CHANNEL_FACTORY_IFACE_GET_CLASS (self)->disconnected (self);
+}
+
+void
+tp_channel_factory_iface_foreach (TpChannelFactoryIface *self,
+                                  TpChannelFunc func,
+                                  gpointer data)
+{
+  TP_CHANNEL_FACTORY_IFACE_GET_CLASS (self)->foreach (self, func, data);
+}
+
+TpChannelFactoryRequestStatus
+tp_channel_factory_iface_request (TpChannelFactoryIface *self,
+                                  const gchar *chan_type,
+                                  TpHandleType handle_type,
+                                  guint handle,
+                                  TpChannelIface **ret,
+                                  GError **error)
+{
+  return (TP_CHANNEL_FACTORY_IFACE_GET_CLASS (self)->request (self, chan_type,
+        handle_type, handle, ret, error));
+}