1 /* MManager - a Desktop wide manager for multimedia applications.
3 * Copyright (C) 2008 Cosimo Cecchi <cosimoc@gnome.org>
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the
17 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 * Boston, MA 02111-1307, USA.
22 #include <glib-object.h>
24 #include "mm-module-manager.h"
25 #include "mm-application-provider.h"
26 #include "mm-category-provider.h"
27 #include "mm-hit-collection-provider.h"
28 #include "mm-module.h"
30 #define MM_MODULE_MANAGER_GET_PRIVATE(o) \
31 (G_TYPE_INSTANCE_GET_PRIVATE ((o), MM_TYPE_MODULE_MANAGER, MMModuleManagerDetails))
33 G_DEFINE_TYPE (MMModuleManager
, mm_module_manager
, G_TYPE_OBJECT
);
35 struct _MMModuleManagerDetails
{
41 load_modules (MMModuleManager
*manager
)
43 MMModuleManagerDetails
*details
= manager
->details
;
47 dir
= g_dir_open (details
->path
, 0, &error
);
49 g_warning ("Unable to load modules from %s: %s",
50 details
->path
, error
->message
);
54 while ((name
= g_dir_read_name (dir
))) {
55 if (g_str_has_suffix (name
, "." G_MODULE_SUFFIX
)) {
59 filename
= g_build_filename (details
->path
, name
, NULL
);
60 module
= mm_module_load_file (filename
);
64 details
->modules
= g_list_prepend (details
->modules
, module
);
76 mm_module_manager_finalize (GObject
*o
)
78 MMModuleManager
*manager
= MM_MODULE_MANAGER (o
);
80 g_free (manager
->details
->path
);
81 g_list_free (manager
->details
->modules
);
83 G_OBJECT_CLASS (mm_module_manager_parent_class
)->finalize (o
);
87 mm_module_manager_init (MMModuleManager
*manager
)
89 MMModuleManagerDetails
*details
= manager
->details
=
90 MM_MODULE_MANAGER_GET_PRIVATE (manager
);
92 details
->path
= g_strdup (MMEDIAMANAGER_EXTENSIONDIR
);
93 details
->modules
= NULL
;
94 load_modules (manager
);
98 mm_module_manager_class_init (MMModuleManagerClass
*klass
)
100 G_OBJECT_CLASS (klass
)->finalize
= mm_module_manager_finalize
;
102 g_type_class_add_private (klass
, sizeof (MMModuleManagerDetails
));
106 find_module_for_name (MMModuleManager
*manager
,
112 gboolean found
= FALSE
;
114 for (l
= manager
->details
->modules
; l
; l
= l
->next
) {
116 module_name
= mm_module_get_name (module
);
117 if (g_strcmp0 (name
, module_name
) == 0) {
126 g_warning ("Can't find a module named %s", name
);
136 * mm_module_manager_get_all_application_providers:
137 * @manager: a #MMModuleManager.
139 * Gets a list of all the #MMApplicationProvider objects known to @manager.
141 * Return value: a #GList of #MMApplicationProvider objects. Use #g_list_free
146 mm_module_manager_get_all_application_providers (MMModuleManager
*manager
)
149 GList
*application_providers
= NULL
;
151 for (l
= manager
->details
->modules
; l
; l
= l
->next
) {
152 application_providers
= g_list_prepend (application_providers
,
153 mm_module_get_application_provider (MM_MODULE (l
->data
)));
156 return application_providers
;
160 * mm_module_manager_get_category_provider_for_application:
161 * @manager: a #MMModuleManager.
162 * @id: the application id.
164 * Gets the #MMCategoryProvider for the application specified by @id.
166 * Return value: a #MMCategoryProvider or %NULL.
170 mm_module_manager_get_category_provider_for_application (MMModuleManager
*manager
,
173 MMCategoryProvider
*provider
= NULL
;
176 module
= find_module_for_name (manager
, id
);
181 provider
= mm_module_get_category_provider (module
);
187 * mm_module_manager_get_hit_collection_provider_for_application:
188 * @manager: a #MMModuleManager.
189 * @id: the application id.
191 * Gets the #MMHitCollectionProvider for the application specified by @id.
193 * Return value: a #MMHitCollectionProvider or %NULL.
196 MMHitCollectionProvider
*
197 mm_module_manager_get_hit_collection_provider_for_application (MMModuleManager
*manager
,
200 MMHitCollectionProvider
*provider
= NULL
;
203 module
= find_module_for_name (manager
, id
);
208 provider
= mm_module_get_hit_collection_provider (module
);