5 * Copyright (C) 2007-2010 Marcel Holtmann <marcel@holtmann.org>
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU General Public License for more details.
18 * You should have received a copy of the GNU General Public License
19 * along with this program; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
38 #include "transport.h"
41 static GSList *drivers = NULL;
43 static struct obex_transport_driver *obex_transport_driver_find(
48 for (l = drivers; l; l = l->next) {
49 struct obex_transport_driver *driver = l->data;
51 if (g_strcmp0(name, driver->name) == 0)
58 GSList *obex_transport_driver_list(void)
63 int obex_transport_driver_register(struct obex_transport_driver *driver)
66 error("Invalid driver");
70 if (obex_transport_driver_find(driver->name) != NULL) {
71 error("Permission denied: transport %s already registered",
76 DBG("driver %p transport %s registered", driver, driver->name);
78 drivers = g_slist_prepend(drivers, driver);
83 void obex_transport_driver_unregister(struct obex_transport_driver *driver)
85 if (!g_slist_find(drivers, driver)) {
86 error("Unable to unregister: No such driver %p", driver);
90 DBG("driver %p transport %s unregistered", driver, driver->name);
92 drivers = g_slist_remove(drivers, driver);