3 * Copyright (c) 2012 Samsung Electronics Co., Ltd.
5 * Licensed under the Flora License, Version 1.0 (the License);
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
9 * http://floralicense.org/license/
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an AS IS BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
18 #include <eina_list.h>
22 #include <setting-debug.h>
23 #include <setting-common-general-func.h>
24 #include <setting-common-draw-widget.h>
26 #include <setting-plugin.h>
29 extern setting_main_appdata *g_main_ad;
31 static Setting_GenGroupItem_Data *g_list_item; /*TEST*/
34 * UI draw handler table : _g_draw_list
35 * - contains Object_Drawer typed object.
37 Eina_List *_g_drawer_list = NULL;
41 * @return Evas_Object * obj
43 static void* navigationbar_func(void *data, xmlNode *xmlObj);
49 static void* group_func(void *data, xmlNode *xmlObj);
52 * @return Setting_GenGroupItem_Data* ptr
54 static void* link_func(void *data, xmlNode *xmlObj);
57 * @return Setting_GenGroupItem_Data* ptr
59 static void* slider_func(void *data, xmlNode *xmlObj);
62 * @return Setting_GenGroupItem_Data* ptr
64 static void* label_func(void *data, xmlNode *xmlObj);
67 * @return Setting_GenGroupItem_Data* ptr
69 static void* checkbox_func(void *data, xmlNode *xmlObj);
72 * @return Setting_GenGroupItem_Data* ptr
74 static void* editbox_func(void *data, xmlNode *xmlObj);
77 * @return Setting_GenGroupItem_Data* ptr
79 static void* expandlist_func(void *data, xmlNode *xmlObj);
84 static void* expanditem_func(void *data, xmlNode *xmlObj);
89 static void* settings_func(void *data, xmlNode *xmlObj);
92 static void* launch_func(void *data, xmlNode *xmlObj);
97 static void* setting_func(void *data, xmlNode *xmlObj);
99 static int __node_walker(PluginNode* context, xmlNode* cur);
101 static int __node_finder(PluginNode* context, xmlNode* cur, char* id_str, char* value, bool* is_end);
104 static void __drawer_add(const char *type, drawer_fp draw)
106 Object_Drawer *node = calloc(1, sizeof(Object_Drawer));
107 if (node && type && draw)
112 _g_drawer_list = eina_list_append(_g_drawer_list, node);
118 static drawer_fp __drawer_find(char* type)
121 SETTING_TRACE("node type:%s", type);
122 Eina_List *check_list = _g_drawer_list;
123 Object_Drawer *list_item = NULL;
126 list_item = (Object_Drawer *) eina_list_data_get(check_list);
127 if (NULL == list_item)
130 if (0 == safeStrCmp(list_item->type, type))
132 //SETTING_TRACE("list_item->type:%s", list_item->type);
135 //if not matched,to check next node.
136 check_list = eina_list_next(check_list);
139 //SETTING_TRACE("list_item:%p", list_item);
140 return list_item ? list_item->draw : NULL;
142 void setting_drawer_list_init()
146 /* <navigationbar> */__drawer_add("navigationbar", navigationbar_func);
148 /* <bool> */__drawer_add("bool", checkbox_func);
149 /* <string> */__drawer_add("string", editbox_func);
150 /* <group> */__drawer_add("group", group_func);
151 /* <integer> */__drawer_add("integer", slider_func);
152 /* <label> */__drawer_add("label", label_func);
153 /* <link> */__drawer_add("link", link_func);
154 /* <launch> */__drawer_add("launch", launch_func);
155 /* <extendlist> */__drawer_add("expandlist", expandlist_func);
156 /* <extenditem> */__drawer_add("expanditem", expanditem_func);
157 /* <settings> */__drawer_add("settings", settings_func);
158 /* <setting> */__drawer_add("setting", setting_func);
161 void setting_drawer_list_fini()
165 Object_Drawer *node = NULL;
166 Eina_List *li = _g_drawer_list;
168 node = (Object_Drawer *) eina_list_data_get(li);
171 //SETTING_TRACE("Deregister %s", node->type);
174 li = eina_list_next(li);
176 _g_drawer_list = eina_list_free(_g_drawer_list);
177 _g_drawer_list = NULL;
181 /////////////////////////
182 /////////////////////////
183 /////////////////////////
185 #define MAX_CONTENT_LEN 512
186 #define MAX_LOCAL_BUFSIZE 128
187 #define DBUS_PATH "/setting/dbus_handler"
188 #define DBUS_SIGNAL_INTERFACE "org.tizen.setting.signal"
190 #define APPID_LENGTH 10
191 #define APPID_POS_FROM_PATH 10
193 static char* s_pkg_name;
196 static char* substring(const char* str, size_t begin, size_t len)
198 if (str == 0 || strlen(str) == 0 || strlen(str) < begin || strlen(str) < (begin+len))
201 return strndup(str + begin, len);
208 * ncbyusjryr.AppSetting --> package ID is ncbyusjryr
209 * "Update_" "ncbyusjryr"
211 static char* get_app_string(char* path)
214 char* temp = substring(path, APPID_POS_FROM_PATH, APPID_LENGTH/*string size*/);
215 SETTING_TRACE("package ID : >>> %s ",temp );
219 //------------------------------------------------------
221 static DBusConnection *bus;
222 //------------------------------------------------------
223 static DBusHandlerResult __signal_filter(DBusConnection* conn, DBusMessage* message, void* user_data)
225 int my_pid = getpid();
231 dbus_error_init(&error);
233 setting_main_appdata *ad = user_data;
234 char* plugin_path = ad->plugin_path;
235 char* pkg_name = get_app_string(plugin_path);
237 if (pkg_name == NULL)
239 SETTING_TRACE("pkg_name is NULL - it's abnormal operation");
240 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
243 char str_buf[MAX_COMMON_BUFFER_LEN];
244 snprintf(str_buf, MAX_COMMON_BUFFER_LEN, "Update_%s", pkg_name);
245 s_pkg_name = strdup(str_buf);
253 if (s_pkg_name == NULL)
255 SETTING_TRACE("s_pkg_name is NULL - it's abnormal operation");
256 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
258 SETTING_TRACE("s_pkg_name : %s ", s_pkg_name);
259 if (dbus_message_is_signal(message, DBUS_SIGNAL_INTERFACE, s_pkg_name))
261 if (dbus_message_get_args(message, &error,
262 DBUS_TYPE_UINT32, &sender_pid,
263 DBUS_TYPE_STRING, &key,
264 DBUS_TYPE_STRING, &value,
265 DBUS_TYPE_INVALID) == FALSE)
267 SETTING_TRACE_ERROR("Fail to get data : %s", error.message);
268 dbus_error_free(&error);
269 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED;
273 if (sender_pid != 0 && my_pid != sender_pid)
275 SETTING_TRACE("received key : %s , value : %s", key, value);
276 //-------------------------------------------------------------
277 // received key : checkbox1|N/A , value : INT|1
278 //-------------------------------------------------------------
279 //char* key = "checkbox1|N/A";
283 ptr = strchr(key, '|');
286 xmlDocPtr doc = NULL;
289 //parsing for : checkbox1|N/A -> checkbox1
290 char* key_name = substring(key, 0, strlen(key)-strlen(ptr));
291 char* val_name = strchr(value, '|');
295 doc = xmlParseFile(plugin_path);
298 SETTING_TRACE("unable to parse file : %s", plugin_path);
299 return DBUS_HANDLER_RESULT_NOT_YET_HANDLED; /* xml parsing error */
302 xmlNode *root = xmlDocGetRootElement(doc);
306 // TODO : message queing
307 // get key/value from d-bus and parse xml and search xml data with key
308 static int count = 0;
309 SETTING_TRACE(" BEGIN ---------------------------- dbus--> before __node_finder : %d", count);
310 __node_finder((PluginNode*)ad->plugin_node, root, key_name ,val_name, &is_end);
311 SETTING_TRACE(" END ----------------------------- dbus--> after __node_finder : %d", count);
315 GError *error = NULL;
320 xmlSaveFormatFile(ad->plugin_path, doc, 1);
321 // TODO: make sure this is right
324 SETTING_TRACE("__cfg_file_write successful");
331 return DBUS_HANDLER_RESULT_HANDLED;
334 static int __send_msg(char* key, char* value)
336 DBusMessage* message;
338 int sender_pid = getpid();
343 // ex) in gdb --> $15 = 0x43b6eb78 "Update_(null)" -> error codintion
344 if (s_pkg_name == NULL)
346 SETTING_TRACE("s_pkg_name is NULL - it's abnormal operation");
350 message = dbus_message_new_signal(DBUS_PATH, DBUS_SIGNAL_INTERFACE, s_pkg_name);
352 SETTING_TRACE("Sending message[%s:%s] via dbus", key ,value);
353 if (dbus_message_append_args(message,
354 DBUS_TYPE_UINT32, &sender_pid,
355 DBUS_TYPE_STRING, &key,
356 DBUS_TYPE_STRING, &value,
357 DBUS_TYPE_INVALID) == FALSE)
359 SETTING_TRACE("Fail to load data error");
363 if (dbus_connection_send(bus, message, NULL) == FALSE)
365 SETTING_TRACE("Fail to send message");
369 dbus_connection_flush(bus);
370 dbus_message_unref(message);
372 SETTING_TRACE("[CLIENT] send data signal done");
378 static void __send_int_msg(xmlNode* xmlObj, int val)
381 const char *id = (char*)xmlGetProp(xmlObj, "id");
382 const char *title = (char*)xmlGetProp(xmlObj, "title");
383 char key[MAX_CONTENT_LEN] = {0,};
384 snprintf(key, sizeof(key), "%s|%s", id, title);
386 char value[MAX_CONTENT_LEN] = {0,};
387 snprintf(value, sizeof(value), "INT|%d", val);
388 __send_msg(key, value);
393 static void __send_string_msg(xmlNode* xmlObj, char *string)
395 const char *id = (char*)xmlGetProp(xmlObj, "id");
396 const char *title = (char*)xmlGetProp(xmlObj, "title");
397 char key[MAX_CONTENT_LEN] = {0,};
398 snprintf(key, sizeof(key), "%s|%s", id, title);
400 char value[MAX_CONTENT_LEN] = {0,};
401 snprintf(value, sizeof(value), "STRING|%s", string);
402 __send_msg(key, value);
406 int setting_dbus_handler_init(void* user_data)
411 SETTING_TRACE("already get a bus, need release first.");
412 setting_dbus_handler_fini();
416 memset(&error, 0, sizeof(DBusError));
417 char rule[MAX_LOCAL_BUFSIZE + 1] = {0,};
418 dbus_error_init(&error);
419 bus = dbus_bus_get_private(DBUS_BUS_SYSTEM, &error);
422 SETTING_TRACE("Fail to connect to the D-BUS daemon: %s", error.message);
423 dbus_error_free(&error);
427 dbus_connection_setup_with_g_main(bus, NULL);
428 snprintf(rule, MAX_LOCAL_BUFSIZE, "path='%s',type='signal',interface='%s'", DBUS_PATH, DBUS_SIGNAL_INTERFACE);
430 dbus_bus_add_match(bus, rule, &error);
431 if (dbus_error_is_set(&error))
433 SETTING_TRACE("Fail to rule set; %s", error.message);
434 dbus_bus_remove_match(bus, rule, &error);
435 dbus_error_free(&error);
436 dbus_connection_close(bus);
441 if (dbus_connection_add_filter(bus, __signal_filter, user_data, NULL) == FALSE)
443 dbus_bus_remove_match(bus, rule, &error);
444 dbus_error_free(&error);
445 dbus_connection_close(bus);
450 SETTING_TRACE("app signal initialized");
454 int setting_dbus_handler_fini(void)
457 //do safty checking first.
458 setting_retvm_if(!bus, 0, "!bus");
460 memset(&error, 0, sizeof(DBusError));
461 char rule[MAX_LOCAL_BUFSIZE + 1] = {0, };
463 dbus_error_init(&error);
466 bus = dbus_bus_get_private(DBUS_BUS_SYSTEM, &error);
468 //dbus_connection_remove_filter(bus, __signal_filter, NULL);
471 snprintf(rule, MAX_LOCAL_BUFSIZE, "path='%s',type='signal',interface='%s'", DBUS_PATH, DBUS_SIGNAL_INTERFACE);
472 dbus_bus_remove_match(bus, rule, &error);
474 if (dbus_error_is_set(&error))
476 SETTING_TRACE("Fail to rule unset: %s", error.message);
477 dbus_error_free(&error);
481 dbus_connection_close(bus);
483 SETTING_TRACE("app signal finalized");
487 /////////////////////////////
488 /////////////////////////////
489 /////////////////////////////
491 Elm_Genlist_Item_Class itc_layout;
494 static int __cfg_file_write(Draw_Data *pd)
498 GError *error = NULL;
501 xmlSaveFormatFile(pd->cfg_file, pd->doc, 1);
502 //xmlFreeDoc(pd->doc);
504 SETTING_TRACE("__cfg_file_write successful");
512 static void ___click_softkey_back_cb(void *data, Evas_Object *obj,
518 PluginNode* node = (PluginNode*)data;
519 Draw_Data *pd = node->pd;
521 evas_object_del(pd->ly_main);
525 setting_plugin_destroy(node);
526 if (g_main_ad->navibar_main)
528 elm_naviframe_item_pop(g_main_ad->navibar_main);
541 static void* group_func(void *data, xmlNode *xmlObj)
544 retv_if(!data || !xmlObj, NULL);
546 PluginNode* node = (PluginNode*)data;
547 Draw_Data *pd = node->pd;
549 // original code is non-recursive
551 const char *title = (char*)json_object_get_string_member(jsonObj, "title");
552 (void)setting_create_Gendial_field_titleItem(pd->scroller,
556 // non recursive method
557 if (json_object_has_member(jsonObj, "elements"))
559 JsonNode* elements_node = json_object_get_member(jsonObj, "elements");
563 for (i=0; i < json_array_get_length(json_node_get_array(elements_node)); i++)
565 tempobj = json_array_get_object_element(json_node_get_array(elements_node), i);
566 type = (char*)json_object_get_string_member(tempobj, "type");
567 drawer_fp fp = __drawer_find(type);
568 if (fp) fp(pd, tempobj); // draw it
572 // new code is recursive
573 const char *title = (char*)xmlGetProp(xmlObj, "title");
574 SETTING_TRACE (" >>> GROUP NAME : %s \n", title);
575 (void)setting_create_Gendial_field_titleItem(pd->scroller, &(itc_group_item), title, NULL);
582 static void* __link_list_cb(void *data, Evas_Object *obj, void *event_info)
585 retv_if(data == NULL, NULL);
586 retvm_if(event_info == NULL, NULL, "Invalid argument: event info is NULL");
587 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
588 elm_genlist_item_selected_set(item, 0);
589 Setting_GenGroupItem_Data *list_item =
590 (Setting_GenGroupItem_Data *) elm_object_item_data_get(item);
592 xmlNode* xmlObj = data;
593 retv_if(!xmlObj, NULL);
594 const char *link_file = (char*)xmlGetProp(xmlObj, "value");
598 SETTING_TRACE_ERROR("Invalidate liked file");
601 char file[1024] = {0,};
602 snprintf(file, sizeof(file), "%s/%s", PLUGIN_CFG_DIR, link_file);
603 SETTING_TRACE("file:%s", file);
605 PluginNode* plugin_node = setting_plugin_create(file);
606 setting_plugin_load(plugin_node, (const char *)file);
608 //setting_plugin_load(NULL, file);
613 static void* __launch_list_cb(void *data, Evas_Object *obj, void *event_info)
616 retv_if(data == NULL, NULL);
617 retvm_if(event_info == NULL, NULL, "Invalid argument: event info is NULL");
618 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
619 elm_genlist_item_selected_set(item, 0);
620 Setting_GenGroupItem_Data *list_item =
621 (Setting_GenGroupItem_Data *) elm_object_item_data_get(item);
623 xmlNode* xmlObj = data;
624 retv_if(!xmlObj, NULL);
625 const char *key_str = (char*)xmlGetProp(xmlObj, "id");
626 const char *title_str = (char*)xmlGetProp(xmlObj, "title");
627 const char *appid_str = (char*)xmlGetProp(xmlObj, "appid");
628 const char *operation_str = (char*)xmlGetProp(xmlObj, "operation");
631 service_h svc = NULL;
632 service_create(&svc);
633 service_set_app_id(svc, appid_str); // xml property – appid
634 service_set_operation(svc, operation_str); // property : operation
635 service_send_launch_request(svc, NULL, NULL);
636 service_destroy(svc);
641 static void* label_func(void *data, xmlNode *xmlObj)
644 retv_if(!data || !xmlObj, NULL);
645 PluginNode* node = (PluginNode*)data;
646 Draw_Data *pd = node->pd;
648 const char *title = (char*)xmlGetProp(xmlObj, "title");
650 Setting_GenGroupItem_Data *obj =
651 setting_create_Gendial_field_def(pd->scroller, &(itc_1text),
653 xmlObj, SWALLOW_Type_INVALID, NULL, NULL,
654 0, title, NULL, NULL);
659 static void* link_func(void *data, xmlNode *xmlObj)
662 retv_if(!data || !xmlObj, NULL);
663 PluginNode* node = (PluginNode*)data;
664 Draw_Data *pd = node->pd;
666 const char *key_str = (char*)xmlGetProp(xmlObj, "id");
667 Setting_GenGroupItem_Data * obj =
668 setting_create_Gendial_field_def(pd->scroller, &(itc_1text),
670 xmlObj, SWALLOW_Type_INVALID, NULL, NULL,
671 0, key_str, NULL, NULL);
676 static void* launch_func(void *data, xmlNode *xmlObj)
679 retv_if(!data || !xmlObj, NULL);
680 PluginNode* node = (PluginNode*)data;
681 Draw_Data *pd = node->pd;
683 const char *title_str = (char*)xmlGetProp(xmlObj, "title");
685 Setting_GenGroupItem_Data * obj =
686 setting_create_Gendial_field_def(pd->scroller, &(itc_1text),
688 xmlObj, SWALLOW_Type_INVALID, NULL, NULL,
689 0, title_str, NULL, NULL);
694 static void __slider_stop_cb(void *data, Evas_Object *obj,
697 ret_if(data == NULL || obj == NULL);
698 double val = elm_slider_value_get(obj);
699 SETTING_TRACE("val = %f", val);
700 Setting_GenGroupItem_Data *list_item = data;
701 ret_if(list_item->userdata == NULL);
703 xmlNode* xmlObj = list_item->userdata;
706 //apply the vconf changes after stopping moving slider..
707 list_item->chk_status = (int)(val + 0.5);
708 elm_slider_value_set(obj, list_item->chk_status);
710 SETTING_TRACE(" slider after ---> val = %d", (int) list_item->chk_status);
712 // int -> double -> xmlChar*
715 sprintf(buf, "%d", (int) list_item->chk_status);
716 newattr = xmlSetProp(xmlObj, "value", buf);
718 __send_int_msg(xmlObj, list_item->chk_status);
719 __cfg_file_write((Draw_Data *)list_item->belongs_to);
723 static void* slider_func(void *data, xmlNode *xmlObj)
726 retv_if(!data || !xmlObj, NULL);
727 PluginNode* node = (PluginNode*)data;
728 Draw_Data *pd = node->pd;
731 const char *title = (char*)xmlGetProp(xmlObj, "title");
733 SETTING_TRACE (" >>> [slider input] min=%s max=%s value=%s ",(char*)xmlGetProp(xmlObj, "min"), (char*)xmlGetProp(xmlObj, "max"), (char*)xmlGetProp(xmlObj, "value"));
735 int value = atoi((char*)xmlGetProp(xmlObj, "value"));
736 int min = atoi((char*)xmlGetProp(xmlObj, "min"));
737 int max = atoi((char*)xmlGetProp(xmlObj, "max"));
739 SETTING_TRACE ("[slider input] min=%d max=%d value=%d ", min, max, value);
741 setting_create_Gendial_itc("dialogue/1text.1icon.5", &(itc_layout));
742 Setting_GenGroupItem_Data *list_item =
743 setting_create_Gendial_field_def(pd->scroller, &(itc_layout), NULL,
745 SWALLOW_Type_LAYOUT_SLIDER,
746 IMG_SENSITIVITY_ICON_01,
747 IMG_SENSITIVITY_ICON_02, value,
750 list_item->win_main = NULL;
751 list_item->evas = NULL;
752 list_item->isIndicatorVisible = true;
753 list_item->slider_min = min;
754 list_item->slider_max = max;
755 list_item->userdata = xmlObj;
756 list_item->stop_change_cb = __slider_stop_cb;
757 list_item->belongs_to = (int)pd;
760 g_list_item = list_item;
762 return (void*)list_item;
767 elm_object_item_data_set(item_to_update->item, item_to_update);
768 elm_genlist_item_update(item_to_update->item);
770 static void* navigationbar_func(void *data, xmlNode *xmlObj)
774 ret_if(!data || !xmlObj);
776 PluginNode* node = (PluginNode*)data;
777 Draw_Data *pd = node->pd;
779 //----------------------------------------------------------------
780 // [DATA] title, btn[0], btn[1]
781 const char *title = (char*)xmlGetProp(xmlObj, "title");
782 char *btn[2] = {0, };
784 // find child nodes named 'elements'
785 if (xmlObj->children) {
786 xmlNode* cur = xmlObj->children;
790 if (!xmlStrcmp(cur->name, (const xmlChar*)"button")) {
791 btn[i] = xmlGetProp(cur, "title");
792 SETTING_TRACE("------>>> node type : Element, name=%s id=%s / btn[%d] = %s ",
793 cur->name,xmlGetProp(cur, "id"),
801 //----------------------------------------------------------------
803 pd->ly_main = setting_create_layout_navi_bar_genlist(pd->win_get,
806 _(btn[1]), _(btn[0]),
807 ___click_softkey_back_cb,
808 ___click_softkey_back_cb, data, &pd->scroller,
816 static void __check_mouse_up_cb(void *data, Evas_Object *obj,
821 setting_retm_if(data == NULL, "Data parameter is NULL");
823 retm_if(event_info == NULL, "Invalid argument: event info is NULL");
824 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
825 elm_genlist_item_selected_set(item, 0);
826 Setting_GenGroupItem_Data *list_item =
827 (Setting_GenGroupItem_Data *) elm_object_item_data_get(item);
829 SETTING_TRACE("clicking item[%s]", _(list_item->keyStr));
831 int old_status = elm_check_state_get(list_item->eo_check);
832 list_item->chk_status = !old_status;
833 elm_check_state_set(list_item->eo_check, list_item->chk_status);
835 xmlNode *xmlObj = data;
837 newattr = xmlSetProp(xmlObj, "state", xmlXPathCastNumberToString(list_item->chk_status));
839 __send_int_msg(xmlObj, list_item->chk_status);
840 __cfg_file_write((Draw_Data *)list_item->belongs_to);
844 static void __chk_btn_cb(void *data, Evas_Object *obj,
849 retm_if(data == NULL, "Data parameter is NULL");
850 Setting_GenGroupItem_Data *list_item = (Setting_GenGroupItem_Data *) data;
852 xmlNode* xmlObj = list_item->userdata;
854 list_item->chk_status = elm_check_state_get(obj); /* for genlist update status */
857 if (list_item->chk_status == 1) {
858 newattr = xmlSetProp(xmlObj, "value", "true");
859 } else if (list_item->chk_status == 0) {
860 newattr = xmlSetProp(xmlObj, "value", "false");
862 newattr = xmlSetProp(xmlObj, "value", "false");
865 const char *id = (char*)xmlGetProp(xmlObj, "id");
866 const char *title = (char*)xmlGetProp(xmlObj, "title");
867 //SETTING_TRACE(" >>>> id:%s , title:%s", id, title);
868 __send_int_msg(xmlObj, list_item->chk_status);
869 __cfg_file_write((Draw_Data *)list_item->belongs_to);
874 static void* checkbox_func(void *data, xmlNode *xmlObj)
877 retv_if(!data || !xmlObj, NULL);
879 PluginNode* node = (PluginNode*)data;
880 Draw_Data *pd = node->pd;
882 // [DATA] title, value
883 const char *title = (char*)xmlGetProp(xmlObj, "title");
886 char* value = (char*)xmlGetProp(xmlObj, "value");
890 if ( 0 == safeStrCmp(value, "true")) {
892 } else if ( 0 == safeStrCmp(value, "false")) {
895 ival = 0; // default : false (0)
898 // title, value, xmlObj
899 Setting_GenGroupItem_Data *list_item =
900 setting_create_Gendial_field_def(pd->scroller,
904 SWALLOW_Type_1TOGGLE,
911 list_item->userdata = xmlObj;
912 list_item->belongs_to = (int) pd;
913 SETTING_TRACE("pd:%p,list_item->belongs_to:%d", pd, list_item->belongs_to);
920 static void __entry_unfocus_cb(void *data, Evas_Object *obj, void *event_info)
923 retm_if(!data || !obj, "Data parameter is NULL");
925 setting_hide_input_pannel_cb(obj);
926 const char *entry_str = elm_entry_entry_get(obj);
927 char *entry_str_utf8 = NULL;
928 entry_str_utf8 = elm_entry_markup_to_utf8(entry_str);
930 Setting_GenGroupItem_Data *list_item = data;
932 xmlNode* xmlObj = list_item->userdata;
934 FREE(entry_str_utf8);
939 const char *title = (char*)xmlSetProp(xmlObj, "value",entry_str_utf8);
941 __send_string_msg(xmlObj, entry_str_utf8);
942 __cfg_file_write((Draw_Data *)list_item->belongs_to);
944 FREE(entry_str_utf8);
949 static void __editbox_list_cb(void *data, Evas_Object *obj,
955 retm_if(event_info == NULL, "Invalid argument: event info is NULL");
956 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
957 elm_genlist_item_selected_set(item, 0);
958 Setting_GenGroupItem_Data *list_item = (Setting_GenGroupItem_Data *) elm_object_item_data_get(item);
960 SETTING_TRACE("clicking item[%s]", _(list_item->keyStr));
961 if (!elm_object_focus_get(list_item->eo_check)) {
962 elm_object_focus_set(list_item->eo_check, EINA_TRUE);
965 Ecore_IMF_Context *imf_context = (Ecore_IMF_Context *)elm_entry_imf_context_get(list_item->eo_check);
966 setting_retm_if(imf_context == NULL, "imf_context is NULL");
967 ecore_imf_context_input_panel_show(imf_context);
971 static void __editbox_changed_cb(void *data, Evas_Object *obj,
975 retm_if(!data || !obj, "Data parameter is NULL");
976 retm_if(!elm_object_focus_get(obj), "Entry is not focused");
978 Setting_GenGroupItem_Data *list_item =
979 (Setting_GenGroupItem_Data *) data;
981 const char *entry_str = elm_entry_entry_get(obj);
982 int entry_len = safeStrLen(entry_str);
983 SETTING_TRACE("entry_str:[%s], lenght:%d", entry_str, entry_len);
985 G_FREE(list_item->sub_desc);//release first
986 list_item->sub_desc = (char *)g_strdup(entry_str);
993 * @see also __editbox_changed_cb
994 * @see also __entry_unfocus_cb
996 static void* editbox_func(void *data, xmlNode *xmlObj)
999 retv_if(!data || !xmlObj, NULL);
1001 PluginNode* node = (PluginNode*)data;
1002 Draw_Data *pd = node->pd;
1004 const char *title = (char*)xmlGetProp(xmlObj, "title");
1005 const char *key_str= (char*)xmlGetProp(xmlObj, "value");
1007 const char *minlength= (char*)xmlGetProp(xmlObj, "minlength");
1008 const char *maxlength= (char*)xmlGetProp(xmlObj, "maxlength");
1013 max_len = atoi(maxlength);
1014 SETTING_TRACE(" >> MAXLENGTH FILTER IS AVAILABLE !!!! maxlength = %d", max_len);
1017 Setting_GenGroupItem_Data *list_item = NULL;
1022 // without maxlength filter
1023 list_item = setting_create_Gendial_field_def(pd->scroller, &(itc_1icon),
1025 pd, SWALLOW_Type_LAYOUT_ENTRY,
1026 NULL, NULL, 0, title, key_str,
1027 __editbox_changed_cb);
1030 // add max length filter
1031 list_item = setting_create_Gendial_field_entry_fo(
1036 SWALLOW_Type_LAYOUT_ENTRY,
1037 NULL, NULL, 0, title, key_str,
1038 __editbox_changed_cb,
1040 ELM_INPUT_PANEL_LAYOUT_NORMAL,
1050 list_item->userdata = xmlObj;
1051 list_item->stop_change_cb = __entry_unfocus_cb;
1052 list_item->belongs_to = (int)pd;
1059 static void __expanditem_func_sel_cb(void *data, Evas_Object *obj, void *event_info)
1061 SETTING_TRACE_BEGIN;
1063 retm_if(event_info == NULL, "Invalid argument: event info is NULL");
1064 Elm_Object_Item *subitem = (Elm_Object_Item *) event_info;
1065 Elm_Object_Item *parentItem = elm_genlist_item_parent_get(subitem);
1066 elm_genlist_item_selected_set(subitem, 0);
1067 Setting_GenGroupItem_Data *data_subItem = elm_object_item_data_get(subitem);
1068 Setting_GenGroupItem_Data *data_parentItem = elm_object_item_data_get(parentItem); /* parent data */
1069 ret_if(NULL == data_subItem || NULL == data_parentItem);
1071 elm_radio_value_set(data_subItem->rgd, data_subItem->chk_status);
1073 data_parentItem->sub_desc = (char *)g_strdup(_(data_subItem->keyStr));
1074 elm_object_item_data_set(data_parentItem->item, data_parentItem);
1075 elm_genlist_item_update(data_parentItem->item);
1077 xmlNode* xmlObj = data_parentItem->userdata;
1081 //newattr = xmlSetProp(xmlObj, "string", data_parentItem->sub_desc);
1082 newattr = xmlSetProp(xmlObj, "value", data_parentItem->sub_desc);
1084 __send_string_msg(xmlObj, data_parentItem->sub_desc);
1085 __cfg_file_write((Draw_Data *)data_parentItem->belongs_to);
1089 static void __expanditem_func_exp_cb(void *data, Evas_Object *obj, void *event_info)
1091 ret_if(NULL == data || NULL == event_info);
1092 SETTING_TRACE_BEGIN;
1094 PluginNode* node = (PluginNode*)data;
1095 Draw_Data *pd = node->pd;
1097 Elm_Object_Item *parentItem = event_info; /* parent item */
1098 Setting_GenGroupItem_Data *data_parentItem = elm_object_item_data_get(parentItem); /* parent data */
1099 Evas_Object *scroller = elm_object_item_widget_get(parentItem);
1102 xmlNode *xmlObj = data_parentItem->userdata;
1103 char *value = (char*)xmlGetProp(xmlObj, "value");
1104 SETTING_TRACE(">>> value = %s", value);
1105 Evas_Object *rgd = NULL;
1107 if (xmlObj->children && !data_parentItem->rgd) {//to protect from entering repeatly
1108 xmlNode* cur = xmlObj->children;
1110 rgd = elm_radio_add(scroller);
1111 elm_radio_value_set(rgd, -1);
1114 char *subitem_title = NULL;
1115 int subitem_index = 0;
1119 // print out debug message
1120 if (data_parentItem->childs)
1123 Eina_List *li = data_parentItem->childs;
1126 Setting_GenGroupItem_Data* node = eina_list_data_get(li);
1128 SETTING_TRACE(" <<< node->keyStr : %s >>> ", node->keyStr);
1131 li = eina_list_next(li);
1133 SETTING_TRACE(" <<<how many : %d>>> ", howmany);
1136 if (data_parentItem->childs)
1138 eina_list_free(data_parentItem->childs);
1139 data_parentItem->childs = NULL;
1142 while (cur != NULL) {
1143 if (!xmlStrcmp(cur->name, (const xmlChar*)"expanditem")) {
1144 type = (char*)xmlGetProp(cur, "type");
1145 if (0 == safeStrCmp(type, "radio")) {
1146 subitem_title = (char*)xmlGetProp(cur, "title");
1147 Setting_GenGroupItem_Data *list_item =
1148 setting_create_Gendial_exp_sub_field(scroller,
1149 &(itc_1icon_1text_sub),
1150 __expanditem_func_sel_cb, NULL, parentItem,
1151 SWALLOW_Type_1RADIO, rgd,
1153 subitem_title, NULL);
1156 if (0 == safeStrCmp(value, subitem_title)) {
1157 sel_idx = subitem_index;
1158 SETTING_TRACE("%d is selected in Radio Group", sel_idx);
1160 SETTING_TRACE(" eina list add >>> value = %s, subitem_title = %s ", value, subitem_title);
1161 data_parentItem->childs = eina_list_append(data_parentItem->childs, list_item);
1165 SETTING_TRACE("invalid type[:%s]", type);
1172 elm_radio_value_set(rgd, sel_idx);
1173 data_parentItem->rgd = rgd;//protecting condition
1178 static void __expanditem_func_smart_cb(void *data, Evas_Object *obj, void *event_info)
1180 ret_if(data == NULL || event_info == NULL);
1181 Elm_Object_Item *item = (Elm_Object_Item *) event_info;
1182 Setting_GenGroupItem_Data *data_item = elm_object_item_data_get(item);
1183 char *cb_type = data;
1185 if (0 == safeStrCmp(cb_type, "contracted")) {
1186 data_item->rgd = NULL;
1187 elm_genlist_item_subitems_clear(item);
1192 static void* settings_func(void *data, xmlNode *xmlObj)
1198 static Evas_Object *setting_create_win_layout2(Evas_Object *win_layout, Evas_Object *win_obj)
1201 Evas_Object *layout = NULL;
1204 layout = elm_layout_add(win_obj);
1205 setting_retvm_if(layout == NULL, FALSE, "layout == NULL");
1207 elm_layout_theme_set(layout, "layout", "application", "default");
1208 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
1209 evas_object_size_hint_align_set(layout, EVAS_HINT_FILL, EVAS_HINT_FILL);
1210 elm_win_resize_object_add(win_obj, layout);
1212 Evas_Object *bg = setting_create_bg(layout, win_obj, "group_list");
1213 elm_object_part_content_set(layout, "elm.swallow.bg", bg);
1214 evas_object_show(layout);
1219 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 */
1220 Evas_Object **navi_bar,
1221 Evas_Object **titleobj)
1224 Evas_Object *layout = setting_create_win_layout2(win_layout, win_obj);
1225 *navi_bar = setting_create_navi_bar(layout);
1227 setting_create_navi_bar_buttons(title_str,
1228 lbutton_str, rbutton_str, mbutton_str,
1229 lbutton_click_cb, rbutton_click_cb,
1230 mbutton_click_cb, cb_data, eo_view /*content */ ,
1235 static void __plugin_genlist_unrealized_cb(void* data,Evas_Object* obj, void* event_info)
1237 SETTING_TRACE_BEGIN;
1238 ret_if(data == NULL);
1240 Elm_Object_Item *item = (Elm_Object_Item*)event_info;
1241 Setting_GenGroupItem_Data *node = (Setting_GenGroupItem_Data *)elm_object_item_data_get(item);
1242 ret_if(node== NULL);
1244 SETTING_TRACE("keyStr : %s ", node->keyStr);
1245 //item_to_update->childs)
1249 eina_list_free(node->childs);
1250 node->childs = NULL;
1255 static void* setting_func(void *data, xmlNode *xmlObj)
1257 SETTING_TRACE_BEGIN;
1258 retv_if(!data || !xmlObj, NULL);
1260 PluginNode* node = (PluginNode*)data;
1261 Draw_Data *pd = node->pd;
1263 // [DATA] title, btn[0], btn[1]
1264 const char *title = (char*)xmlGetProp(xmlObj, "title");
1265 char *btn[2] = {/* 0 */"OK", /* 1 */"NO"};
1267 SETTING_TRACE("before setting_create_layout_navi_bar_genlist");
1270 pd->scroller = elm_genlist_add(g_main_ad->win_main);
1271 retvm_if(pd->scroller == NULL, NULL,
1272 "Cannot set scroller object as contento of layout");
1273 elm_object_style_set(pd->scroller, "dialogue");
1274 elm_genlist_clear(pd->scroller); /* first to clear list */
1276 evas_object_smart_callback_add(pd->scroller, "unrealized", __plugin_genlist_unrealized_cb, node);
1279 SETTING_TRACE("_(title):%s", _(title));
1281 setting_push_layout_navi_bar(
1283 _("IDS_COM_BODY_BACK"), NULL, NULL,
1284 ___click_softkey_back_cb,
1287 g_main_ad->navibar_main, NULL);
1288 SETTING_TRACE("after setting_create_layout_navi_bar_genlist");
1294 static void* expanditem_func(void *data, xmlNode *xmlObj)
1296 // DO NOTHING - expandlist draws this area
1300 static void* expandlist_func(void *data, xmlNode *xmlObj)
1302 SETTING_TRACE_BEGIN;
1303 retv_if(!data || !xmlObj, NULL);
1305 PluginNode* node = (PluginNode*)data;
1306 Draw_Data *pd = node->pd;
1308 const char *key_str = (char*)xmlGetProp(xmlObj, "title");
1309 const char *value = (char*)xmlGetProp(xmlObj, "value"); // string -> value
1311 setting_enable_expandable_genlist(pd->scroller, data, __expanditem_func_exp_cb, __expanditem_func_smart_cb);
1312 Setting_GenGroupItem_Data *list_item =
1313 setting_create_Gendial_exp_parent_field(pd->scroller,
1314 &(itc_2text_3_parent),
1316 SWALLOW_Type_INVALID,
1320 list_item->userdata = xmlObj;
1321 list_item->belongs_to = (int)pd;
1322 list_item->childs = NULL; /* init */
1330 static int __node_walker(PluginNode* context, xmlNode* cur)
1332 //SETTING_TRACE_BEGIN;
1333 Draw_Data *pd = context->pd;
1336 retv_if(!context->ui_list, -1);
1338 xmlNode *cur_node = NULL;
1339 for (cur_node = cur; cur_node;cur_node = cur_node->next) {
1340 if (cur_node->type == XML_ELEMENT_NODE) {
1341 // SETTING_TRACE("node type : %s id= %s", cur_node->name,xmlGetProp(cur_node, "id"));
1342 drawer_fp fp = __drawer_find(cur_node->name);
1346 void* vret = fp(context, cur_node); // draw it
1350 Setting_GenGroupItem_Data* genlist_node = (Setting_GenGroupItem_Data* )vret;
1351 //SETTING_TRACE("add node to Eina List name : %s, id : ", cur_node->name, xmlGetProp(cur_node, "id"));
1352 // add it to the hash table create before.
1355 char* key_name = xmlGetProp(cur_node, "id");
1356 eina_hash_add(context->ui_list, strdup(key_name),(void*)genlist_node);
1359 SETTING_TRACE(" >>>> fp is NULL ");
1362 __node_walker(context, cur_node->children); /* RECURSIVE */
1368 * @param id_str [in] "id"
1369 * @param value [in] value to be udpated
1370 * @see __expanditem_func_sel_cb
1372 static int __node_finder(PluginNode* context, xmlNode* cur, char* id_str, char* value, bool* is_end)
1374 SETTING_TRACE_BEGIN;
1375 xmlNode *cur_node = NULL;
1379 SETTING_TRACE("context is NULL - it's error CONDITION ");
1383 retv_if(!context->ui_list, -1);
1384 if (*is_end == true) return 0;
1386 for (cur_node = cur; cur_node;cur_node = cur_node->next) {
1387 if (cur_node->type == XML_ELEMENT_NODE) {
1389 char* id_name = (char*)xmlGetProp(cur_node, "id");
1390 if ( id_name && 0 == strcmp(id_str, id_name))
1392 SETTING_TRACE("FOUND >>>> %s", id_name);
1393 // cur_node - update xml code
1394 xmlAttrPtr newattr = xmlSetProp(cur_node, "value", value);
1396 //-----------------------------------------------------------
1399 if ( 0 == strcmp (cur_node->name, "integer"))
1401 SETTING_TRACE(">>>>> UPDATE SLIDER CONTROL %x --- %s ",context->ui_list, id_name);
1402 Setting_GenGroupItem_Data* item_to_update = (Setting_GenGroupItem_Data*)eina_hash_find(context->ui_list, id_name);
1405 item_to_update->chk_status = atoi(value);
1406 SETTING_TRACE(">>> o-------------0 SLIDER VALUE = %d ", item_to_update->chk_status);
1408 elm_object_item_data_set(item_to_update->item, item_to_update);
1409 elm_genlist_item_update(item_to_update->item);
1411 SETTING_TRACE("item_to_update is NULL");
1415 if ( 0 == strcmp (cur_node->name, "bool"))
1417 SETTING_TRACE(">>>>> UPDATE TOGGLE CONTROL pluginpath:%s, ---- %x --- %s ", context->plugin_path, context->ui_list, id_name);
1418 Setting_GenGroupItem_Data* item_to_update = NULL;
1419 item_to_update = (Setting_GenGroupItem_Data*)eina_hash_find(context->ui_list, id_name);
1422 item_to_update->chk_status = atoi(value);
1423 SETTING_TRACE(">>> o-------------0 TOGGLE VALUE = %d ", item_to_update->chk_status);
1425 elm_object_item_data_set(item_to_update->item, item_to_update);
1426 elm_genlist_item_update(item_to_update->item);
1428 SETTING_TRACE("item_to_update is NULL");
1431 // case : edit control
1432 if ( 0 == strcmp (cur_node->name, "string"))
1434 SETTING_TRACE(">>>>> UPDATE EDIT CONTROL CONTROL %x --- %s ",context->ui_list, id_name);
1435 Setting_GenGroupItem_Data* item_to_update = (Setting_GenGroupItem_Data*)eina_hash_find(context->ui_list, id_name);
1438 char* old_string = item_to_update->sub_desc;
1439 item_to_update->sub_desc = strdup(value);
1440 SETTING_TRACE(">>> o-------------0 STRING VALUE = %s ", value);
1444 elm_object_item_data_set(item_to_update->item, item_to_update);
1445 elm_genlist_item_update(item_to_update->item);
1448 SETTING_TRACE("item_to_update is NULL");
1451 // case : expand list
1457 //-----------------------------------------------------------
1458 if ( 0 == strcmp (cur_node->name, "expandlist"))
1461 SETTING_TRACE(">>>>> UPDATE EXPAND LIST CONTROL %x --- %s ",context->ui_list, id_name);
1462 Setting_GenGroupItem_Data* item_to_update = NULL;
1463 item_to_update = (Setting_GenGroupItem_Data*)eina_hash_find(context->ui_list, id_name);
1466 char* old_string = item_to_update->sub_desc;
1467 item_to_update->sub_desc = strdup(value);
1468 SETTING_TRACE(">>> o-------------0 EXPAND LIST VALUE = %s ", value);
1472 elm_object_item_data_set(item_to_update->item, item_to_update);
1473 elm_genlist_item_update(item_to_update->item);
1475 // TODO: need to update child elements
1476 // item_to_update->childs ---> expanded list
1479 // there should have 4 sub items.
1480 //-----------------------------------------------------
1481 // has it already freed by someone?
1482 //-----------------------------------------------------
1483 if (item_to_update->childs)
1486 Eina_List *li = item_to_update->childs;
1489 Setting_GenGroupItem_Data* node = eina_list_data_get(li);
1491 li = eina_list_next(li);
1493 SETTING_TRACE(" expandlist -- how many items are there? : %d ", howmany2);
1496 if (item_to_update->childs)
1498 Eina_List *li = item_to_update->childs;
1499 int radio_index = 0;
1502 Setting_GenGroupItem_Data* node = eina_list_data_get(li);
1504 if (node->item && node->keyStr)
1506 // do something more
1507 // SETTING_TRACE(">>> RADIO LIST STRING VALUE = %s ", node->keyStr);
1508 // set position of radio button
1509 if (strcmp(node->keyStr, value) == 0) // << CRAAH !!!!
1511 elm_radio_value_set(node->rgd, radio_index);
1514 SETTING_TRACE(">>> node has unproper values - Setting_GenGroupItem_Data");
1516 elm_object_item_data_set(item_to_update->item, item_to_update);
1517 elm_genlist_item_update(item_to_update->item);
1520 li = eina_list_next(li);
1526 SETTING_TRACE("item_to_update is NULL");
1535 __node_finder(context, cur_node->children, id_str, value, is_end); /* RECURSIVE */
1540 static unsigned int _plugin_string_key_length(const char*key)
1545 return (int)strlen(key) + 1;
1548 static int _plugin_string_key_cmp(const char* key1, int key1_length,
1549 const char* key2, int key2_length)
1551 return strcmp(key1, key2);
1554 static void _plugin_entry_free_cb(void* data)
1556 Setting_GenGroupItem_Data* node = (Setting_GenGroupItem_Data*) data;
1559 eina_list_free(node->childs);
1560 node->childs = NULL;
1564 PluginNode* setting_plugin_create()
1566 PluginNode *node = calloc(1, sizeof(PluginNode));
1567 setting_retvm_if(!node, -1, "Create PluginNode obj failed");
1568 Draw_Data *pd = calloc(1, sizeof(Draw_Data));
1575 setting_retvm_if(!pd, -1, "Create Draw_Data obj failed");
1579 node->ui_list = eina_hash_new(EINA_KEY_LENGTH(_plugin_string_key_length),
1580 EINA_KEY_CMP(_plugin_string_key_cmp),
1581 EINA_KEY_HASH(eina_hash_superfast),
1582 _plugin_entry_free_cb,
1588 void setting_plugin_destroy(PluginNode* node)
1590 SETTING_TRACE_BEGIN;
1592 SETTING_TRACE("node is NOT NULL")
1594 SETTING_TRACE("node->pd is NOT NULL")
1595 if(node->pd->doc != NULL) {
1596 xmlSaveFormatFile(node->plugin_path, node->pd->doc, 1);
1597 xmlFreeDoc(node->pd->doc);
1598 node->pd->doc = NULL;
1599 SETTING_TRACE("__cfg_file_write successful");
1606 if (node->ui_list) {
1607 eina_hash_free(node->ui_list);
1608 node->ui_list = NULL;
1617 static Eina_Bool _plugin_foreach_cb(const Eina_Hash *hash, const void*key, void* data, void* fdata)
1619 Setting_GenGroupItem_Data* node = (Setting_GenGroupItem_Data*) data;
1620 SETTING_TRACE("%s --- %s ", (char*)key, node->keyStr);
1625 void setting_plugin_debug(PluginNode* context)
1627 // SETTING_TRACE("HASH TABLE -------------------------------------");
1628 if (context->ui_list) {
1629 eina_hash_foreach(context->ui_list,_plugin_foreach_cb, NULL);
1631 // SETTING_TRACE("HASH TABLE -------------------------------------");
1635 void setting_plugin_update(PluginNode* context)
1637 Eina_List *li = context->ui_list;
1640 Setting_GenGroupItem_Data* node = (Setting_GenGroupItem_Data*) eina_list_data_get(li);
1642 // SETTING_TRACE(" ---> keyStr : %s , swallow type : %d ", node->keyStr, node->swallow_type);
1643 Setting_GenGroupItem_Data* item_to_update = NULL;
1644 item_to_update = node;
1645 elm_object_item_data_set(item_to_update->item, item_to_update);
1646 elm_genlist_item_update(item_to_update->item);
1648 li = eina_list_next(li);
1656 bool setting_plugin_load(PluginNode* context, const char *cfg_file)
1658 SETTING_TRACE("cfg_file:%s", cfg_file)
1659 if (isEmptyStr(cfg_file) || 0 != access(cfg_file, R_OK|W_OK|F_OK ))
1661 SETTING_TRACE_ERROR(" error occured : access \n");
1664 context->pd->cfg_file = cfg_file;
1666 //GError *error = NULL;
1668 context->pd->doc = xmlParseFile(cfg_file);
1669 context->pd->root = xmlDocGetRootElement(context->pd->doc);
1671 // signal filter change
1672 //setting_dbus_handler_init(g_main_ad);
1673 void* user_data = (void*)g_main_ad;
1676 dbus_error_init(&error);
1677 char rule[MAX_LOCAL_BUFSIZE + 1] = {0,};
1678 bus = dbus_bus_get_private(DBUS_BUS_SYSTEM, &error);
1681 SETTING_TRACE("Fail to connect to the D-BUS daemon: %s", error.message);
1682 dbus_error_free(&error);
1687 // dbus_connection_remove_filter(bus, __signal_filter, NULL);
1690 snprintf(rule, MAX_LOCAL_BUFSIZE, "path='%s',type='signal',interface='%s'", DBUS_PATH, DBUS_SIGNAL_INTERFACE);
1691 dbus_bus_add_match(bus, rule, &error);
1692 if (dbus_error_is_set(&error))
1694 SETTING_TRACE("Fail to rule set; %s", error.message);
1695 dbus_bus_remove_match(bus, rule, &error);
1696 dbus_error_free(&error);
1697 dbus_connection_close(bus);
1703 if (dbus_connection_add_filter(bus, __signal_filter, user_data, NULL) == FALSE)
1705 dbus_bus_remove_match(bus, rule, &error);
1706 dbus_error_free(&error);
1707 dbus_connection_close(bus);
1712 // TODO: error handler here
1713 __node_walker(context, context->pd->root);
1716 setting_plugin_debug(context);