4 * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd.
6 * Contact: MyoungJune Park <mj2004.park@samsung.com>
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
23 #include <eina_list.h>
27 #include <setting-debug.h>
28 #include <setting-common-general-func.h>
29 #include <setting-common-draw-widget.h>
31 #include <setting-plugin.h>
34 extern setting_main_appdata *g_main_ad;
36 static Setting_GenGroupItem_Data *g_list_item; /*TEST*/
39 * UI draw handler table : _g_draw_list
40 * - contains Object_Drawer typed object.
42 Eina_List *_g_drawer_list = NULL;
46 * @return Evas_Object * obj
48 static void* navigationbar_func(void *data, xmlNode *xmlObj);
54 static void* group_func(void *data, xmlNode *xmlObj);
57 * @return Setting_GenGroupItem_Data* ptr
59 static void* link_func(void *data, xmlNode *xmlObj);
62 * @return Setting_GenGroupItem_Data* ptr
64 static void* slider_func(void *data, xmlNode *xmlObj);
67 * @return Setting_GenGroupItem_Data* ptr
69 static void* label_func(void *data, xmlNode *xmlObj);
72 * @return Setting_GenGroupItem_Data* ptr
74 static void* checkbox_func(void *data, xmlNode *xmlObj);
77 * @return Setting_GenGroupItem_Data* ptr
79 static void* editbox_func(void *data, xmlNode *xmlObj);
82 * @return Setting_GenGroupItem_Data* ptr
84 static void* expandlist_func(void *data, xmlNode *xmlObj);
89 static void* expanditem_func(void *data, xmlNode *xmlObj);
94 static void* settings_func(void *data, xmlNode *xmlObj);
97 static void* launch_func(void *data, xmlNode *xmlObj);
102 static void* setting_func(void *data, xmlNode *xmlObj);
104 static int __node_walker(PluginNode* context, xmlNode* cur);
106 static int __node_finder(PluginNode* context, xmlNode* cur, char* id_str, char* value, bool* is_end);
109 static void __drawer_add(const char *type, drawer_fp draw)
111 Object_Drawer *node = calloc(1, sizeof(Object_Drawer));
112 if (node && type && draw)
117 _g_drawer_list = eina_list_append(_g_drawer_list, node);
123 static drawer_fp __drawer_find(char* type)
126 SETTING_TRACE("node type:%s", type);
127 Eina_List *check_list = _g_drawer_list;
128 Object_Drawer *list_item = NULL;
131 list_item = (Object_Drawer *) eina_list_data_get(check_list);
132 if (NULL == list_item)
135 if (0 == safeStrCmp(list_item->type, type))
137 //SETTING_TRACE("list_item->type:%s", list_item->type);
140 //if not matched,to check next node.
141 check_list = eina_list_next(check_list);
144 //SETTING_TRACE("list_item:%p", list_item);
145 return list_item ? list_item->draw : NULL;
147 void setting_drawer_list_init()
151 /* <navigationbar> */__drawer_add("navigationbar", navigationbar_func);
153 /* <bool> */__drawer_add("bool", checkbox_func);
154 /* <string> */__drawer_add("string", editbox_func);
155 /* <group> */__drawer_add("group", group_func);
156 /* <integer> */__drawer_add("integer", slider_func);
157 /* <label> */__drawer_add("label", label_func);
158 /* <link> */__drawer_add("link", link_func);
159 /* <launch> */__drawer_add("launch", launch_func);
160 /* <extendlist> */__drawer_add("expandlist", expandlist_func);
161 /* <extenditem> */__drawer_add("expanditem", expanditem_func);
162 /* <settings> */__drawer_add("settings", settings_func);
163 /* <setting> */__drawer_add("setting", setting_func);
166 void setting_drawer_list_fini()
170 Object_Drawer *node = NULL;
171 Eina_List *li = _g_drawer_list;
173 node = (Object_Drawer *) eina_list_data_get(li);
176 //SETTING_TRACE("Deregister %s", node->type);
179 li = eina_list_next(li);
181 _g_drawer_list = eina_list_free(_g_drawer_list);
182 _g_drawer_list = NULL;
186 /////////////////////////
187 /////////////////////////
188 /////////////////////////
190 #define MAX_CONTENT_LEN 512
191 #define MAX_LOCAL_BUFSIZE 128
192 #define DBUS_PATH "/setting/dbus_handler"
193 #define DBUS_SIGNAL_INTERFACE "org.tizen.setting.signal"
195 #define APPID_LENGTH 10
196 #define APPID_POS_FROM_PATH 10
198 static char* s_pkg_name;
201 static char* substring(const char* str, size_t begin, size_t len)
203 if (str == 0 || strlen(str) == 0 || strlen(str) < begin || strlen(str) < (begin+len))
206 return strndup(str + begin, len);
213 * ncbyusjryr.AppSetting --> package ID is ncbyusjryr
214 * "Update_" "ncbyusjryr"
216 static char* get_app_string(char* path)
219 char* temp = substring(path, APPID_POS_FROM_PATH, APPID_LENGTH/*string size*/);
220 SETTING_TRACE("package ID : >>> %s ",temp );
224 //------------------------------------------------------
226 static DBusConnection *bus;
227 //------------------------------------------------------
228 static DBusHandlerResult __signal_filter(DBusConnection* conn, DBusMessage* message, void* user_data)
230 int my_pid = getpid();
236 dbus_error_init(&error);
238 setting_main_appdata *ad = user_data;
239 char* plugin_path = ad->plugin_path;
240 char* pkg_name = get_app_string(plugin_path);
242 if (pkg_name == NULL)
244 SETTING_TRACE("pkg_name is NULL - it's abnormal operation");
245 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
248 char str_buf[MAX_COMMON_BUFFER_LEN];
249 snprintf(str_buf, MAX_COMMON_BUFFER_LEN, "Update_%s", pkg_name);
250 s_pkg_name = strdup(str_buf);
258 if (s_pkg_name == NULL)
260 SETTING_TRACE("s_pkg_name is NULL - it's abnormal operation");
261 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
263 SETTING_TRACE("s_pkg_name : %s ", s_pkg_name);
264 if (dbus_message_is_signal(message, DBUS_SIGNAL_INTERFACE, s_pkg_name))
266 if (dbus_message_get_args(message, &error,
267 DBUS_TYPE_UINT32, &sender_pid,
268 DBUS_TYPE_STRING, &key,
269 DBUS_TYPE_STRING, &value,
270 DBUS_TYPE_INVALID) == FALSE)
272 SETTING_TRACE_ERROR("Fail to get data : %s", error.message);
273 dbus_error_free(&error);
274 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
278 if (sender_pid != 0 && my_pid != sender_pid)
280 SETTING_TRACE("received key : %s , value : %s", key, value);
281 //-------------------------------------------------------------
282 // received key : checkbox1|N/A , value : INT|1
283 //-------------------------------------------------------------
284 //char* key = "checkbox1|N/A";
288 ptr = strchr(key, '|');
291 xmlDocPtr doc = NULL;
294 //parsing for : checkbox1|N/A -> checkbox1
295 char* key_name = substring(key, 0, strlen(key)-strlen(ptr));
296 char* val_name = strchr(value, '|');
300 doc = xmlParseFile(plugin_path);
303 SETTING_TRACE("unable to parse file : %s", plugin_path);
304 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; /* xml parsing error */
307 xmlNode *root = xmlDocGetRootElement(doc);
311 // TODO : message queing
312 // get key/value from d-bus and parse xml and search xml data with key
313 static int count = 0;
314 SETTING_TRACE(" BEGIN ---------------------------- dbus--> before __node_finder : %d", count);
315 __node_finder((PluginNode*)ad->plugin_node, root, key_name ,val_name, &is_end);
316 SETTING_TRACE(" END ----------------------------- dbus--> after __node_finder : %d", count);
320 GError *error = NULL;
325 xmlSaveFormatFile(ad->plugin_path, doc, 1);
326 // TODO: make sure this is right
329 SETTING_TRACE("__cfg_file_write successful");
336 return DBUS_HANDLER_RESULT_HANDLED;
339 static int __send_msg(char* key, char* value)
341 DBusMessage* message;
343 int sender_pid = getpid();
348 // ex) in gdb --> $15 = 0x43b6eb78 "Update_(null)" -> error codintion
349 if (s_pkg_name == NULL)
351 SETTING_TRACE("s_pkg_name is NULL - it's abnormal operation");
355 message = dbus_message_new_signal(DBUS_PATH, DBUS_SIGNAL_INTERFACE, s_pkg_name);
357 SETTING_TRACE("Sending message[%s:%s] via dbus", key ,value);
358 if (dbus_message_append_args(message,
359 DBUS_TYPE_UINT32, &sender_pid,
360 DBUS_TYPE_STRING, &key,
361 DBUS_TYPE_STRING, &value,
362 DBUS_TYPE_INVALID) == FALSE)
364 SETTING_TRACE("Fail to load data error");
368 if (dbus_connection_send(bus, message, NULL) == FALSE)
370 SETTING_TRACE("Fail to send message");
374 dbus_connection_flush(bus);
375 dbus_message_unref(message);
377 SETTING_TRACE("[CLIENT] send data signal done");
383 static void __send_int_msg(xmlNode* xmlObj, int val)
386 const char *id = (char*)xmlGetProp(xmlObj, "id");
387 const char *title = (char*)xmlGetProp(xmlObj, "title");
388 char key[MAX_CONTENT_LEN] = {0,};
389 snprintf(key, sizeof(key), "%s|%s", id, title);
391 char value[MAX_CONTENT_LEN] = {0,};
392 snprintf(value, sizeof(value), "INT|%d", val);
393 __send_msg(key, value);
398 static void __send_string_msg(xmlNode* xmlObj, char *string)
400 const char *id = (char*)xmlGetProp(xmlObj, "id");
401 const char *title = (char*)xmlGetProp(xmlObj, "title");
402 char key[MAX_CONTENT_LEN] = {0,};
403 snprintf(key, sizeof(key), "%s|%s", id, title);
405 char value[MAX_CONTENT_LEN] = {0,};
406 snprintf(value, sizeof(value), "STRING|%s", string);
407 __send_msg(key, value);
411 int setting_dbus_handler_init(void* user_data)
416 SETTING_TRACE("already get a bus, need release first.");
417 setting_dbus_handler_fini();
421 memset(&error, 0, sizeof(DBusError));
422 char rule[MAX_LOCAL_BUFSIZE + 1] = {0,};
423 dbus_error_init(&error);
424 bus = dbus_bus_get_private(DBUS_BUS_SYSTEM, &error);
427 SETTING_TRACE("Fail to connect to the D-BUS daemon: %s", error.message);
428 dbus_error_free(&error);
432 dbus_connection_setup_with_g_main(bus, NULL);
433 snprintf(rule, MAX_LOCAL_BUFSIZE, "path='%s',type='signal',interface='%s'", DBUS_PATH, DBUS_SIGNAL_INTERFACE);
435 dbus_bus_add_match(bus, rule, &error);
436 if (dbus_error_is_set(&error))
438 SETTING_TRACE("Fail to rule set; %s", error.message);
439 dbus_bus_remove_match(bus, rule, &error);
440 dbus_error_free(&error);
441 dbus_connection_close(bus);
446 if (dbus_connection_add_filter(bus, __signal_filter, user_data, NULL) == FALSE)
448 dbus_bus_remove_match(bus, rule, &error);
449 dbus_error_free(&error);
450 dbus_connection_close(bus);
455 SETTING_TRACE("app signal initialized");
459 int setting_dbus_handler_fini(void)
462 //do safty checking first.
463 setting_retvm_if(!bus, 0, "!bus");
465 memset(&error, 0, sizeof(DBusError));
466 char rule[MAX_LOCAL_BUFSIZE + 1] = {0, };
468 dbus_error_init(&error);
471 bus = dbus_bus_get_private(DBUS_BUS_SYSTEM, &error);
473 //dbus_connection_remove_filter(bus, __signal_filter, NULL);
476 snprintf(rule, MAX_LOCAL_BUFSIZE, "path='%s',type='signal',interface='%s'", DBUS_PATH, DBUS_SIGNAL_INTERFACE);
477 dbus_bus_remove_match(bus, rule, &error);
479 if (dbus_error_is_set(&error))
481 SETTING_TRACE("Fail to rule unset: %s", error.message);
482 dbus_error_free(&error);
486 dbus_connection_close(bus);
488 SETTING_TRACE("app signal finalized");
492 /////////////////////////////
493 /////////////////////////////
494 /////////////////////////////
496 Elm_Genlist_Item_Class itc_layout;
499 static int __cfg_file_write(Draw_Data *pd)
503 GError *error = NULL;
506 xmlSaveFormatFile(pd->cfg_file, pd->doc, 1);
507 //xmlFreeDoc(pd->doc);
509 SETTING_TRACE("__cfg_file_write successful");
517 static void ___click_softkey_back_cb(void *data, Evas_Object *obj,
523 PluginNode* node = (PluginNode*)data;
524 Draw_Data *pd = node->pd;
526 evas_object_del(pd->ly_main);
530 setting_plugin_destroy(node);
531 if (g_main_ad->navibar_main)
533 elm_naviframe_item_pop(g_main_ad->navibar_main);
546 static void* group_func(void *data, xmlNode *xmlObj)
549 retv_if(!data || !xmlObj, NULL);
551 PluginNode* node = (PluginNode*)data;
552 Draw_Data *pd = node->pd;
554 // original code is non-recursive
556 const char *title = (char*)json_object_get_string_member(jsonObj, "title");
557 (void)setting_create_Gendial_field_titleItem(pd->scroller,
561 // non recursive method
562 if (json_object_has_member(jsonObj, "elements"))
564 JsonNode* elements_node = json_object_get_member(jsonObj, "elements");
568 for (i=0; i < json_array_get_length(json_node_get_array(elements_node)); i++)
570 tempobj = json_array_get_object_element(json_node_get_array(elements_node), i);
571 type = (char*)json_object_get_string_member(tempobj, "type");
572 drawer_fp fp = __drawer_find(type);
573 if (fp) fp(pd, tempobj); // draw it
577 // new code is recursive
578 const char *title = (char*)xmlGetProp(xmlObj, "title");
579 SETTING_TRACE (" >>> GROUP NAME : %s \n", title);
580 (void)setting_create_Gendial_field_titleItem(pd->scroller, &(itc_group_item), title, NULL);
587 static void* __link_list_cb(void *data, Evas_Object *obj, void *event_info)
590 retv_if(data == NULL, NULL);
591 retvm_if(event_info == NULL, NULL, "Invalid argument: event info is NULL");
592 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
593 elm_genlist_item_selected_set(item, 0);
594 Setting_GenGroupItem_Data *list_item =
595 (Setting_GenGroupItem_Data *) elm_object_item_data_get(item);
597 xmlNode* xmlObj = data;
598 retv_if(!xmlObj, NULL);
599 const char *link_file = (char*)xmlGetProp(xmlObj, "value");
603 SETTING_TRACE_ERROR("Invalidate liked file");
606 char file[1024] = {0,};
607 snprintf(file, sizeof(file), "%s/%s", PLUGIN_CFG_DIR, link_file);
608 SETTING_TRACE("file:%s", file);
610 PluginNode* plugin_node = setting_plugin_create(file);
611 setting_plugin_load(plugin_node, (const char *)file);
613 //setting_plugin_load(NULL, file);
618 static void* __launch_list_cb(void *data, Evas_Object *obj, void *event_info)
621 retv_if(data == NULL, NULL);
622 retvm_if(event_info == NULL, NULL, "Invalid argument: event info is NULL");
623 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
624 elm_genlist_item_selected_set(item, 0);
625 Setting_GenGroupItem_Data *list_item =
626 (Setting_GenGroupItem_Data *) elm_object_item_data_get(item);
628 xmlNode* xmlObj = data;
629 retv_if(!xmlObj, NULL);
630 const char *key_str = (char*)xmlGetProp(xmlObj, "id");
631 const char *title_str = (char*)xmlGetProp(xmlObj, "title");
632 const char *appid_str = (char*)xmlGetProp(xmlObj, "appid");
633 const char *operation_str = (char*)xmlGetProp(xmlObj, "operation");
636 service_h svc = NULL;
637 service_create(&svc);
638 service_set_app_id(svc, appid_str); // xml property – appid
639 service_set_operation(svc, operation_str); // property : operation
640 service_send_launch_request(svc, NULL, NULL);
641 service_destroy(svc);
646 static void* label_func(void *data, xmlNode *xmlObj)
649 retv_if(!data || !xmlObj, NULL);
650 PluginNode* node = (PluginNode*)data;
651 Draw_Data *pd = node->pd;
653 const char *title = (char*)xmlGetProp(xmlObj, "title");
655 Setting_GenGroupItem_Data *obj =
656 setting_create_Gendial_field_def(pd->scroller, &(itc_1text),
658 xmlObj, SWALLOW_Type_INVALID, NULL, NULL,
659 0, title, NULL, NULL);
664 static void* link_func(void *data, xmlNode *xmlObj)
667 retv_if(!data || !xmlObj, NULL);
668 PluginNode* node = (PluginNode*)data;
669 Draw_Data *pd = node->pd;
671 const char *key_str = (char*)xmlGetProp(xmlObj, "id");
672 Setting_GenGroupItem_Data * obj =
673 setting_create_Gendial_field_def(pd->scroller, &(itc_1text),
675 xmlObj, SWALLOW_Type_INVALID, NULL, NULL,
676 0, key_str, NULL, NULL);
681 static void* launch_func(void *data, xmlNode *xmlObj)
684 retv_if(!data || !xmlObj, NULL);
685 PluginNode* node = (PluginNode*)data;
686 Draw_Data *pd = node->pd;
688 const char *title_str = (char*)xmlGetProp(xmlObj, "title");
690 Setting_GenGroupItem_Data * obj =
691 setting_create_Gendial_field_def(pd->scroller, &(itc_1text),
693 xmlObj, SWALLOW_Type_INVALID, NULL, NULL,
694 0, title_str, NULL, NULL);
699 static void __slider_stop_cb(void *data, Evas_Object *obj,
702 ret_if(data == NULL || obj == NULL);
703 double val = elm_slider_value_get(obj);
704 SETTING_TRACE("val = %f", val);
705 Setting_GenGroupItem_Data *list_item = data;
706 ret_if(list_item->userdata == NULL);
708 xmlNode* xmlObj = list_item->userdata;
711 //apply the vconf changes after stopping moving slider..
712 list_item->chk_status = (int)(val + 0.5);
713 elm_slider_value_set(obj, list_item->chk_status);
715 SETTING_TRACE(" slider after ---> val = %d", (int) list_item->chk_status);
717 // int -> double -> xmlChar*
720 sprintf(buf, "%d", (int) list_item->chk_status);
721 newattr = xmlSetProp(xmlObj, "value", buf);
723 __send_int_msg(xmlObj, list_item->chk_status);
724 __cfg_file_write((Draw_Data *)list_item->belongs_to);
728 static void* slider_func(void *data, xmlNode *xmlObj)
731 retv_if(!data || !xmlObj, NULL);
732 PluginNode* node = (PluginNode*)data;
733 Draw_Data *pd = node->pd;
736 const char *title = (char*)xmlGetProp(xmlObj, "title");
738 SETTING_TRACE (" >>> [slider input] min=%s max=%s value=%s ",(char*)xmlGetProp(xmlObj, "min"), (char*)xmlGetProp(xmlObj, "max"), (char*)xmlGetProp(xmlObj, "value"));
740 int value = atoi((char*)xmlGetProp(xmlObj, "value"));
741 int min = atoi((char*)xmlGetProp(xmlObj, "min"));
742 int max = atoi((char*)xmlGetProp(xmlObj, "max"));
744 SETTING_TRACE ("[slider input] min=%d max=%d value=%d ", min, max, value);
746 setting_create_Gendial_itc("dialogue/1text.1icon.5", &(itc_layout));
747 Setting_GenGroupItem_Data *list_item =
748 setting_create_Gendial_field_def(pd->scroller, &(itc_layout), NULL,
750 SWALLOW_Type_LAYOUT_SLIDER,
751 IMG_SENSITIVITY_ICON_01,
752 IMG_SENSITIVITY_ICON_02, value,
755 list_item->win_main = NULL;
756 list_item->evas = NULL;
757 list_item->isIndicatorVisible = true;
758 list_item->slider_min = min;
759 list_item->slider_max = max;
760 list_item->userdata = xmlObj;
761 list_item->stop_change_cb = __slider_stop_cb;
762 list_item->belongs_to = (int)pd;
765 g_list_item = list_item;
767 return (void*)list_item;
772 elm_object_item_data_set(item_to_update->item, item_to_update);
773 elm_genlist_item_update(item_to_update->item);
775 static void* navigationbar_func(void *data, xmlNode *xmlObj)
779 ret_if(!data || !xmlObj);
781 PluginNode* node = (PluginNode*)data;
782 Draw_Data *pd = node->pd;
784 //----------------------------------------------------------------
785 // [DATA] title, btn[0], btn[1]
786 const char *title = (char*)xmlGetProp(xmlObj, "title");
787 char *btn[2] = {0, };
789 // find child nodes named 'elements'
790 if (xmlObj->children) {
791 xmlNode* cur = xmlObj->children;
795 if (!xmlStrcmp(cur->name, (const xmlChar*)"button")) {
796 btn[i] = xmlGetProp(cur, "title");
797 SETTING_TRACE("------>>> node type : Element, name=%s id=%s / btn[%d] = %s ",
798 cur->name,xmlGetProp(cur, "id"),
806 //----------------------------------------------------------------
808 pd->ly_main = setting_create_layout_navi_bar_genlist(pd->win_get,
811 _(btn[1]), _(btn[0]),
812 ___click_softkey_back_cb,
813 ___click_softkey_back_cb, data, &pd->scroller,
821 static void __check_mouse_up_cb(void *data, Evas_Object *obj,
826 setting_retm_if(data == NULL, "Data parameter is NULL");
828 retm_if(event_info == NULL, "Invalid argument: event info is NULL");
829 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
830 elm_genlist_item_selected_set(item, 0);
831 Setting_GenGroupItem_Data *list_item =
832 (Setting_GenGroupItem_Data *) elm_object_item_data_get(item);
834 SETTING_TRACE("clicking item[%s]", _(list_item->keyStr));
836 int old_status = elm_check_state_get(list_item->eo_check);
837 list_item->chk_status = !old_status;
838 elm_check_state_set(list_item->eo_check, list_item->chk_status);
840 xmlNode *xmlObj = data;
842 newattr = xmlSetProp(xmlObj, "state", xmlXPathCastNumberToString(list_item->chk_status));
844 __send_int_msg(xmlObj, list_item->chk_status);
845 __cfg_file_write((Draw_Data *)list_item->belongs_to);
849 static void __chk_btn_cb(void *data, Evas_Object *obj,
854 retm_if(data == NULL, "Data parameter is NULL");
855 Setting_GenGroupItem_Data *list_item = (Setting_GenGroupItem_Data *) data;
857 xmlNode* xmlObj = list_item->userdata;
859 list_item->chk_status = elm_check_state_get(obj); /* for genlist update status */
862 if (list_item->chk_status == 1) {
863 newattr = xmlSetProp(xmlObj, "value", "true");
864 } else if (list_item->chk_status == 0) {
865 newattr = xmlSetProp(xmlObj, "value", "false");
867 newattr = xmlSetProp(xmlObj, "value", "false");
870 const char *id = (char*)xmlGetProp(xmlObj, "id");
871 const char *title = (char*)xmlGetProp(xmlObj, "title");
872 //SETTING_TRACE(" >>>> id:%s , title:%s", id, title);
873 __send_int_msg(xmlObj, list_item->chk_status);
874 __cfg_file_write((Draw_Data *)list_item->belongs_to);
879 static void* checkbox_func(void *data, xmlNode *xmlObj)
882 retv_if(!data || !xmlObj, NULL);
884 PluginNode* node = (PluginNode*)data;
885 Draw_Data *pd = node->pd;
887 // [DATA] title, value
888 const char *title = (char*)xmlGetProp(xmlObj, "title");
891 char* value = (char*)xmlGetProp(xmlObj, "value");
895 if ( 0 == safeStrCmp(value, "true")) {
897 } else if ( 0 == safeStrCmp(value, "false")) {
900 ival = 0; // default : false (0)
903 // title, value, xmlObj
904 Setting_GenGroupItem_Data *list_item =
905 setting_create_Gendial_field_def(pd->scroller,
909 SWALLOW_Type_1TOGGLE,
916 list_item->userdata = xmlObj;
917 list_item->belongs_to = (int) pd;
918 SETTING_TRACE("pd:%p,list_item->belongs_to:%d", pd, list_item->belongs_to);
925 static void __entry_unfocus_cb(void *data, Evas_Object *obj, void *event_info)
928 retm_if(!data || !obj, "Data parameter is NULL");
930 setting_hide_input_pannel_cb(obj);
931 const char *entry_str = elm_entry_entry_get(obj);
932 char *entry_str_utf8 = NULL;
933 entry_str_utf8 = elm_entry_markup_to_utf8(entry_str);
935 Setting_GenGroupItem_Data *list_item = data;
937 xmlNode* xmlObj = list_item->userdata;
939 FREE(entry_str_utf8);
944 const char *title = (char*)xmlSetProp(xmlObj, "value",entry_str_utf8);
946 __send_string_msg(xmlObj, entry_str_utf8);
947 __cfg_file_write((Draw_Data *)list_item->belongs_to);
949 FREE(entry_str_utf8);
954 static void __editbox_list_cb(void *data, Evas_Object *obj,
960 retm_if(event_info == NULL, "Invalid argument: event info is NULL");
961 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
962 elm_genlist_item_selected_set(item, 0);
963 Setting_GenGroupItem_Data *list_item = (Setting_GenGroupItem_Data *) elm_object_item_data_get(item);
965 SETTING_TRACE("clicking item[%s]", _(list_item->keyStr));
966 if (!elm_object_focus_get(list_item->eo_check)) {
967 elm_object_focus_set(list_item->eo_check, EINA_TRUE);
970 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(list_item->eo_check);
971 setting_retm_if(imf_context == NULL, "imf_context is NULL");
972 ecore_imf_context_input_panel_show(imf_context);
976 static void __editbox_changed_cb(void *data, Evas_Object *obj,
980 retm_if(!data || !obj, "Data parameter is NULL");
981 retm_if(!elm_object_focus_get(obj), "Entry is not focused");
983 Setting_GenGroupItem_Data *list_item =
984 (Setting_GenGroupItem_Data *) data;
986 const char *entry_str = elm_entry_entry_get(obj);
987 int entry_len = safeStrLen(entry_str);
988 SETTING_TRACE("entry_str:[%s], lenght:%d", entry_str, entry_len);
990 G_FREE(list_item->sub_desc);//release first
991 list_item->sub_desc = (char *)g_strdup(entry_str);
998 * @see also __editbox_changed_cb
999 * @see also __entry_unfocus_cb
1001 static void* editbox_func(void *data, xmlNode *xmlObj)
1003 SETTING_TRACE_BEGIN;
1004 retv_if(!data || !xmlObj, NULL);
1006 PluginNode* node = (PluginNode*)data;
1007 Draw_Data *pd = node->pd;
1009 const char *title = (char*)xmlGetProp(xmlObj, "title");
1010 const char *key_str= (char*)xmlGetProp(xmlObj, "value");
1012 const char *minlength= (char*)xmlGetProp(xmlObj, "minlength");
1013 const char *maxlength= (char*)xmlGetProp(xmlObj, "maxlength");
1018 max_len = atoi(maxlength);
1019 SETTING_TRACE(" >> MAXLENGTH FILTER IS AVAILABLE !!!! maxlength = %d", max_len);
1022 Setting_GenGroupItem_Data *list_item = NULL;
1027 // without maxlength filter
1028 list_item = setting_create_Gendial_field_def(pd->scroller, &(itc_1icon),
1030 pd, SWALLOW_Type_LAYOUT_ENTRY,
1031 NULL, NULL, 0, title, key_str,
1032 __editbox_changed_cb);
1035 // add max length filter
1036 list_item = setting_create_Gendial_field_entry_fo(
1041 SWALLOW_Type_LAYOUT_ENTRY,
1042 NULL, NULL, 0, title, key_str,
1043 __editbox_changed_cb,
1045 ELM_INPUT_PANEL_LAYOUT_NORMAL,
1055 list_item->userdata = xmlObj;
1056 list_item->stop_change_cb = __entry_unfocus_cb;
1057 list_item->belongs_to = (int)pd;
1064 static void __expanditem_func_sel_cb(void *data, Evas_Object *obj, void *event_info)
1066 SETTING_TRACE_BEGIN;
1068 retm_if(event_info == NULL, "Invalid argument: event info is NULL");
1069 Elm_Object_Item *subitem = (Elm_Object_Item *) event_info;
1070 Elm_Object_Item *parentItem = elm_genlist_item_parent_get(subitem);
1071 elm_genlist_item_selected_set(subitem, 0);
1072 Setting_GenGroupItem_Data *data_subItem = elm_object_item_data_get(subitem);
1073 Setting_GenGroupItem_Data *data_parentItem = elm_object_item_data_get(parentItem); /* parent data */
1074 ret_if(NULL == data_subItem || NULL == data_parentItem);
1076 elm_radio_value_set(data_subItem->rgd, data_subItem->chk_status);
1078 data_parentItem->sub_desc = (char *)g_strdup(_(data_subItem->keyStr));
1079 elm_object_item_data_set(data_parentItem->item, data_parentItem);
1080 elm_genlist_item_update(data_parentItem->item);
1082 xmlNode* xmlObj = data_parentItem->userdata;
1086 //newattr = xmlSetProp(xmlObj, "string", data_parentItem->sub_desc);
1087 newattr = xmlSetProp(xmlObj, "value", data_parentItem->sub_desc);
1089 __send_string_msg(xmlObj, data_parentItem->sub_desc);
1090 __cfg_file_write((Draw_Data *)data_parentItem->belongs_to);
1094 static void __expanditem_func_exp_cb(void *data, Evas_Object *obj, void *event_info)
1096 ret_if(NULL == data || NULL == event_info);
1097 SETTING_TRACE_BEGIN;
1099 PluginNode* node = (PluginNode*)data;
1100 Draw_Data *pd = node->pd;
1102 Elm_Object_Item *parentItem = event_info; /* parent item */
1103 Setting_GenGroupItem_Data *data_parentItem = elm_object_item_data_get(parentItem); /* parent data */
1104 Evas_Object *scroller = elm_object_item_widget_get(parentItem);
1107 xmlNode *xmlObj = data_parentItem->userdata;
1108 char *value = (char*)xmlGetProp(xmlObj, "value");
1109 SETTING_TRACE(">>> value = %s", value);
1110 Evas_Object *rgd = NULL;
1112 if (xmlObj->children && !data_parentItem->rgd) {//to protect from entering repeatly
1113 xmlNode* cur = xmlObj->children;
1115 rgd = elm_radio_add(scroller);
1116 elm_radio_value_set(rgd, -1);
1119 char *subitem_title = NULL;
1120 int subitem_index = 0;
1124 // print out debug message
1125 if (data_parentItem->childs)
1128 Eina_List *li = data_parentItem->childs;
1131 Setting_GenGroupItem_Data* node = eina_list_data_get(li);
1133 SETTING_TRACE(" <<< node->keyStr : %s >>> ", node->keyStr);
1136 li = eina_list_next(li);
1138 SETTING_TRACE(" <<<how many : %d>>> ", howmany);
1141 if (data_parentItem->childs)
1143 eina_list_free(data_parentItem->childs);
1144 data_parentItem->childs = NULL;
1147 while (cur != NULL) {
1148 if (!xmlStrcmp(cur->name, (const xmlChar*)"expanditem")) {
1149 type = (char*)xmlGetProp(cur, "type");
1150 if (0 == safeStrCmp(type, "radio")) {
1151 subitem_title = (char*)xmlGetProp(cur, "title");
1152 Setting_GenGroupItem_Data *list_item =
1153 setting_create_Gendial_exp_sub_field(scroller,
1154 &(itc_1icon_1text_sub),
1155 __expanditem_func_sel_cb, NULL, parentItem,
1156 SWALLOW_Type_1RADIO, rgd,
1158 subitem_title, NULL);
1161 if (0 == safeStrCmp(value, subitem_title)) {
1162 sel_idx = subitem_index;
1163 SETTING_TRACE("%d is selected in Radio Group", sel_idx);
1165 SETTING_TRACE(" eina list add >>> value = %s, subitem_title = %s ", value, subitem_title);
1166 data_parentItem->childs = eina_list_append(data_parentItem->childs, list_item);
1170 SETTING_TRACE("invalid type[:%s]", type);
1177 elm_radio_value_set(rgd, sel_idx);
1178 data_parentItem->rgd = rgd;//protecting condition
1183 static void __expanditem_func_smart_cb(void *data, Evas_Object *obj, void *event_info)
1185 ret_if(data == NULL || event_info == NULL);
1186 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
1187 Setting_GenGroupItem_Data *data_item = elm_object_item_data_get(item);
1188 char *cb_type = data;
1190 if (0 == safeStrCmp(cb_type, "contracted")) {
1191 data_item->rgd = NULL;
1192 elm_genlist_item_subitems_clear(item);
1197 static void* settings_func(void *data, xmlNode *xmlObj)
1203 static Evas_Object *setting_create_win_layout2(Evas_Object *win_layout, Evas_Object *win_obj)
1206 Evas_Object *layout = NULL;
1209 layout = elm_layout_add(win_obj);
1210 setting_retvm_if(layout == NULL, FALSE, "layout == NULL");
1212 elm_layout_theme_set(layout, "layout", "application", "default");
1213 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1214 evas_object_size_hint_align_set(layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
1215 elm_win_resize_object_add(win_obj, layout);
1217 Evas_Object *bg = setting_create_bg(layout, win_obj, "group_list");
1218 elm_object_part_content_set(layout, "elm.swallow.bg", bg);
1219 evas_object_show(layout);
1224 Evas_Object *setting_create_layout_navi_bar2(Evas_Object *win_layout, Evas_Object *win_obj, char *title_str, char *lbutton_str, char *rbutton_str, char *mbutton_str, setting_call_back_func lbutton_click_cb, setting_call_back_func rbutton_click_cb, setting_call_back_func mbutton_click_cb, void *cb_data, Evas_Object *eo_view, /*any container obj constructed on any evas obj */
1225 Evas_Object **navi_bar,
1226 Evas_Object **titleobj)
1229 Evas_Object *layout = setting_create_win_layout2(win_layout, win_obj);
1230 *navi_bar = setting_create_navi_bar(layout);
1232 setting_create_navi_bar_buttons(title_str,
1233 lbutton_str, rbutton_str, mbutton_str,
1234 lbutton_click_cb, rbutton_click_cb,
1235 mbutton_click_cb, cb_data, eo_view /*content */ ,
1240 static void __plugin_genlist_unrealized_cb(void* data,Evas_Object* obj, void* event_info)
1242 SETTING_TRACE_BEGIN;
1243 ret_if(data == NULL);
1245 Elm_Object_Item *item = (Elm_Object_Item*)event_info;
1246 Setting_GenGroupItem_Data *node = (Setting_GenGroupItem_Data *)elm_object_item_data_get(item);
1247 ret_if(node== NULL);
1249 SETTING_TRACE("keyStr : %s ", node->keyStr);
1250 //item_to_update->childs)
1254 eina_list_free(node->childs);
1255 node->childs = NULL;
1260 static void* setting_func(void *data, xmlNode *xmlObj)
1262 SETTING_TRACE_BEGIN;
1263 retv_if(!data || !xmlObj, NULL);
1265 PluginNode* node = (PluginNode*)data;
1266 Draw_Data *pd = node->pd;
1268 // [DATA] title, btn[0], btn[1]
1269 const char *title = (char*)xmlGetProp(xmlObj, "title");
1270 char *btn[2] = {/* 0 */"OK", /* 1 */"NO"};
1272 SETTING_TRACE("before setting_create_layout_navi_bar_genlist");
1275 pd->scroller = elm_genlist_add(g_main_ad->win_main);
1276 retvm_if(pd->scroller == NULL, NULL,
1277 "Cannot set scroller object as contento of layout");
1278 elm_object_style_set(pd->scroller, "dialogue");
1279 elm_genlist_clear(pd->scroller); /* first to clear list */
1281 evas_object_smart_callback_add(pd->scroller, "unrealized", __plugin_genlist_unrealized_cb, node);
1284 SETTING_TRACE("_(title):%s", _(title));
1286 setting_push_layout_navi_bar(
1288 _("IDS_COM_BODY_BACK"), NULL, NULL,
1289 ___click_softkey_back_cb,
1292 g_main_ad->navibar_main, NULL);
1293 SETTING_TRACE("after setting_create_layout_navi_bar_genlist");
1299 static void* expanditem_func(void *data, xmlNode *xmlObj)
1301 // DO NOTHING - expandlist draws this area
1305 static void* expandlist_func(void *data, xmlNode *xmlObj)
1307 SETTING_TRACE_BEGIN;
1308 retv_if(!data || !xmlObj, NULL);
1310 PluginNode* node = (PluginNode*)data;
1311 Draw_Data *pd = node->pd;
1313 const char *key_str = (char*)xmlGetProp(xmlObj, "title");
1314 const char *value = (char*)xmlGetProp(xmlObj, "value"); // string -> value
1316 setting_enable_expandable_genlist(pd->scroller, data, __expanditem_func_exp_cb, __expanditem_func_smart_cb);
1317 Setting_GenGroupItem_Data *list_item =
1318 setting_create_Gendial_exp_parent_field(pd->scroller,
1319 &(itc_2text_3_parent),
1321 SWALLOW_Type_INVALID,
1325 list_item->userdata = xmlObj;
1326 list_item->belongs_to = (int)pd;
1327 list_item->childs = NULL; /* init */
1335 static int __node_walker(PluginNode* context, xmlNode* cur)
1337 //SETTING_TRACE_BEGIN;
1338 Draw_Data *pd = context->pd;
1341 retv_if(!context->ui_list, -1);
1343 xmlNode *cur_node = NULL;
1344 for (cur_node = cur; cur_node;cur_node = cur_node->next) {
1345 if (cur_node->type == XML_ELEMENT_NODE) {
1346 // SETTING_TRACE("node type : %s id= %s", cur_node->name,xmlGetProp(cur_node, "id"));
1347 drawer_fp fp = __drawer_find(cur_node->name);
1351 void* vret = fp(context, cur_node); // draw it
1355 Setting_GenGroupItem_Data* genlist_node = (Setting_GenGroupItem_Data* )vret;
1356 //SETTING_TRACE("add node to Eina List name : %s, id : ", cur_node->name, xmlGetProp(cur_node, "id"));
1357 // add it to the hash table create before.
1360 char* key_name = xmlGetProp(cur_node, "id");
1361 eina_hash_add(context->ui_list, strdup(key_name),(void*)genlist_node);
1364 SETTING_TRACE(" >>>> fp is NULL ");
1367 __node_walker(context, cur_node->children); /* RECURSIVE */
1373 * @param id_str [in] "id"
1374 * @param value [in] value to be udpated
1375 * @see __expanditem_func_sel_cb
1377 static int __node_finder(PluginNode* context, xmlNode* cur, char* id_str, char* value, bool* is_end)
1379 SETTING_TRACE_BEGIN;
1380 xmlNode *cur_node = NULL;
1384 SETTING_TRACE("context is NULL - it's error CONDITION ");
1388 retv_if(!context->ui_list, -1);
1389 if (*is_end == true) return 0;
1391 for (cur_node = cur; cur_node;cur_node = cur_node->next) {
1392 if (cur_node->type == XML_ELEMENT_NODE) {
1394 char* id_name = (char*)xmlGetProp(cur_node, "id");
1395 if ( id_name && 0 == strcmp(id_str, id_name))
1397 SETTING_TRACE("FOUND >>>> %s", id_name);
1398 // cur_node - update xml code
1399 xmlAttrPtr newattr = xmlSetProp(cur_node, "value", value);
1401 //-----------------------------------------------------------
1404 if ( 0 == strcmp (cur_node->name, "integer"))
1406 SETTING_TRACE(">>>>> UPDATE SLIDER CONTROL %x --- %s ",context->ui_list, id_name);
1407 Setting_GenGroupItem_Data* item_to_update = (Setting_GenGroupItem_Data*)eina_hash_find(context->ui_list, id_name);
1410 item_to_update->chk_status = atoi(value);
1411 SETTING_TRACE(">>> o-------------0 SLIDER VALUE = %d ", item_to_update->chk_status);
1413 elm_object_item_data_set(item_to_update->item, item_to_update);
1414 elm_genlist_item_update(item_to_update->item);
1416 SETTING_TRACE("item_to_update is NULL");
1420 if ( 0 == strcmp (cur_node->name, "bool"))
1422 SETTING_TRACE(">>>>> UPDATE TOGGLE CONTROL pluginpath:%s, ---- %x --- %s ", context->plugin_path, context->ui_list, id_name);
1423 Setting_GenGroupItem_Data* item_to_update = NULL;
1424 item_to_update = (Setting_GenGroupItem_Data*)eina_hash_find(context->ui_list, id_name);
1427 item_to_update->chk_status = atoi(value);
1428 SETTING_TRACE(">>> o-------------0 TOGGLE VALUE = %d ", item_to_update->chk_status);
1430 elm_object_item_data_set(item_to_update->item, item_to_update);
1431 elm_genlist_item_update(item_to_update->item);
1433 SETTING_TRACE("item_to_update is NULL");
1436 // case : edit control
1437 if ( 0 == strcmp (cur_node->name, "string"))
1439 SETTING_TRACE(">>>>> UPDATE EDIT CONTROL CONTROL %x --- %s ",context->ui_list, id_name);
1440 Setting_GenGroupItem_Data* item_to_update = (Setting_GenGroupItem_Data*)eina_hash_find(context->ui_list, id_name);
1443 char* old_string = item_to_update->sub_desc;
1444 item_to_update->sub_desc = strdup(value);
1445 SETTING_TRACE(">>> o-------------0 STRING VALUE = %s ", value);
1449 elm_object_item_data_set(item_to_update->item, item_to_update);
1450 elm_genlist_item_update(item_to_update->item);
1453 SETTING_TRACE("item_to_update is NULL");
1456 // case : expand list
1462 //-----------------------------------------------------------
1463 if ( 0 == strcmp (cur_node->name, "expandlist"))
1466 SETTING_TRACE(">>>>> UPDATE EXPAND LIST CONTROL %x --- %s ",context->ui_list, id_name);
1467 Setting_GenGroupItem_Data* item_to_update = NULL;
1468 item_to_update = (Setting_GenGroupItem_Data*)eina_hash_find(context->ui_list, id_name);
1471 char* old_string = item_to_update->sub_desc;
1472 item_to_update->sub_desc = strdup(value);
1473 SETTING_TRACE(">>> o-------------0 EXPAND LIST VALUE = %s ", value);
1477 elm_object_item_data_set(item_to_update->item, item_to_update);
1478 elm_genlist_item_update(item_to_update->item);
1480 // TODO: need to update child elements
1481 // item_to_update->childs ---> expanded list
1484 // there should have 4 sub items.
1485 //-----------------------------------------------------
1486 // has it already freed by someone?
1487 //-----------------------------------------------------
1488 if (item_to_update->childs)
1491 Eina_List *li = item_to_update->childs;
1494 Setting_GenGroupItem_Data* node = eina_list_data_get(li);
1496 li = eina_list_next(li);
1498 SETTING_TRACE(" expandlist -- how many items are there? : %d ", howmany2);
1501 if (item_to_update->childs)
1503 Eina_List *li = item_to_update->childs;
1504 int radio_index = 0;
1507 Setting_GenGroupItem_Data* node = eina_list_data_get(li);
1509 if (node->item && node->keyStr)
1511 // do something more
1512 // SETTING_TRACE(">>> RADIO LIST STRING VALUE = %s ", node->keyStr);
1513 // set position of radio button
1514 if (strcmp(node->keyStr, value) == 0) // << CRAAH !!!!
1516 elm_radio_value_set(node->rgd, radio_index);
1519 SETTING_TRACE(">>> node has unproper values - Setting_GenGroupItem_Data");
1521 elm_object_item_data_set(item_to_update->item, item_to_update);
1522 elm_genlist_item_update(item_to_update->item);
1525 li = eina_list_next(li);
1531 SETTING_TRACE("item_to_update is NULL");
1540 __node_finder(context, cur_node->children, id_str, value, is_end); /* RECURSIVE */
1545 static unsigned int _plugin_string_key_length(const char*key)
1550 return (int)strlen(key) + 1;
1553 static int _plugin_string_key_cmp(const char* key1, int key1_length,
1554 const char* key2, int key2_length)
1556 return strcmp(key1, key2);
1559 static void _plugin_entry_free_cb(void* data)
1561 Setting_GenGroupItem_Data* node = (Setting_GenGroupItem_Data*) data;
1564 eina_list_free(node->childs);
1565 node->childs = NULL;
1569 PluginNode* setting_plugin_create()
1571 PluginNode *node = calloc(1, sizeof(PluginNode));
1572 setting_retvm_if(!node, -1, "Create PluginNode obj failed");
1573 Draw_Data *pd = calloc(1, sizeof(Draw_Data));
1580 setting_retvm_if(!pd, -1, "Create Draw_Data obj failed");
1584 node->ui_list = eina_hash_new(EINA_KEY_LENGTH(_plugin_string_key_length),
1585 EINA_KEY_CMP(_plugin_string_key_cmp),
1586 EINA_KEY_HASH(eina_hash_superfast),
1587 _plugin_entry_free_cb,
1593 void setting_plugin_destroy(PluginNode* node)
1595 SETTING_TRACE_BEGIN;
1597 SETTING_TRACE("node is NOT NULL")
1599 SETTING_TRACE("node->pd is NOT NULL")
1600 if(node->pd->doc != NULL) {
1601 xmlSaveFormatFile(node->plugin_path, node->pd->doc, 1);
1602 xmlFreeDoc(node->pd->doc);
1603 node->pd->doc = NULL;
1604 SETTING_TRACE("__cfg_file_write successful");
1611 if (node->ui_list) {
1612 eina_hash_free(node->ui_list);
1613 node->ui_list = NULL;
1622 static Eina_Bool _plugin_foreach_cb(const Eina_Hash *hash, const void*key, void* data, void* fdata)
1624 Setting_GenGroupItem_Data* node = (Setting_GenGroupItem_Data*) data;
1625 SETTING_TRACE("%s --- %s ", (char*)key, node->keyStr);
1630 void setting_plugin_debug(PluginNode* context)
1632 // SETTING_TRACE("HASH TABLE -------------------------------------");
1633 if (context->ui_list) {
1634 eina_hash_foreach(context->ui_list,_plugin_foreach_cb, NULL);
1636 // SETTING_TRACE("HASH TABLE -------------------------------------");
1640 void setting_plugin_update(PluginNode* context)
1642 Eina_List *li = context->ui_list;
1645 Setting_GenGroupItem_Data* node = (Setting_GenGroupItem_Data*) eina_list_data_get(li);
1647 // SETTING_TRACE(" ---> keyStr : %s , swallow type : %d ", node->keyStr, node->swallow_type);
1648 Setting_GenGroupItem_Data* item_to_update = NULL;
1649 item_to_update = node;
1650 elm_object_item_data_set(item_to_update->item, item_to_update);
1651 elm_genlist_item_update(item_to_update->item);
1653 li = eina_list_next(li);
1661 bool setting_plugin_load(PluginNode* context, const char *cfg_file)
1663 SETTING_TRACE("cfg_file:%s", cfg_file)
1664 if (isEmptyStr(cfg_file) || 0 != access(cfg_file, R_OK|W_OK|F_OK ))
1666 SETTING_TRACE_ERROR(" error occured : access \n");
1669 context->pd->cfg_file = cfg_file;
1671 //GError *error = NULL;
1673 context->pd->doc = xmlParseFile(cfg_file);
1674 context->pd->root = xmlDocGetRootElement(context->pd->doc);
1676 // signal filter change
1677 //setting_dbus_handler_init(g_main_ad);
1678 void* user_data = (void*)g_main_ad;
1681 dbus_error_init(&error);
1682 char rule[MAX_LOCAL_BUFSIZE + 1] = {0,};
1683 bus = dbus_bus_get_private(DBUS_BUS_SYSTEM, &error);
1686 SETTING_TRACE("Fail to connect to the D-BUS daemon: %s", error.message);
1687 dbus_error_free(&error);
1692 // dbus_connection_remove_filter(bus, __signal_filter, NULL);
1695 snprintf(rule, MAX_LOCAL_BUFSIZE, "path='%s',type='signal',interface='%s'", DBUS_PATH, DBUS_SIGNAL_INTERFACE);
1696 dbus_bus_add_match(bus, rule, &error);
1697 if (dbus_error_is_set(&error))
1699 SETTING_TRACE("Fail to rule set; %s", error.message);
1700 dbus_bus_remove_match(bus, rule, &error);
1701 dbus_error_free(&error);
1702 dbus_connection_close(bus);
1708 if (dbus_connection_add_filter(bus, __signal_filter, user_data, NULL) == FALSE)
1710 dbus_bus_remove_match(bus, rule, &error);
1711 dbus_error_free(&error);
1712 dbus_connection_close(bus);
1717 // TODO: error handler here
1718 __node_walker(context, context->pd->root);
1721 setting_plugin_debug(context);