Add tv profile specific code
[platform/core/api/tethering.git] / src / tethering_private.c
index 05e7697..b169250 100755 (executable)
@@ -21,6 +21,7 @@
 
 static __thread bool is_feature_checked[TETHERING_SUPPORTED_FEATURE_MAX] = {0, };
 static __thread bool feature_supported[TETHERING_SUPPORTED_FEATURE_MAX] = {0, };
+static __thread GSList *tethering_handle_list = NULL;
 
 bool __check_feature_supported(const char *key, tethering_supported_feature_e feature)
 {
@@ -30,7 +31,7 @@ bool __check_feature_supported(const char *key, tethering_supported_feature_e fe
                        return false;
                }
 
-               feature_supported[feature] = true;
+               is_feature_checked[feature] = true;
        }
        return feature_supported[feature];
 }
@@ -44,19 +45,17 @@ int _tethering_check_feature_supported(const char* feature, ...)
 
        va_start(list, feature);
        key = feature;
-       while(1) {
-               if((strcmp(key, TETHERING_FEATURE) == 0)){
-                       value = __check_feature_supported(key, TETHERING_SUPPORTED_FEATURE);
-               }
-               if((strcmp(key, TETHERING_WIFI_FEATURE) == 0)){
-                       value = __check_feature_supported(key, TETHERING_SUPPORTED_FEATURE);
-               }
-               if((strcmp(key, TETHERING_BT_FEATURE) == 0)){
-                       value = __check_feature_supported(key, TETHERING_SUPPORTED_FEATURE);
-               }
-               if((strcmp(key, TETHERING_USB_FEATURE) == 0)){
+
+       while (1) {
+               if ((strcmp(key, TETHERING_FEATURE) == 0))
                        value = __check_feature_supported(key, TETHERING_SUPPORTED_FEATURE);
-               }
+               if ((strcmp(key, TETHERING_WIFI_FEATURE) == 0))
+                       value = __check_feature_supported(key, TETHERING_SUPPORTED_FEATURE_WIFI);
+               if ((strcmp(key, TETHERING_BT_FEATURE) == 0))
+                       value = __check_feature_supported(key, TETHERING_SUPPORTED_FEATURE_BT);
+               if ((strcmp(key, TETHERING_USB_FEATURE) == 0))
+                       value = __check_feature_supported(key, TETHERING_SUPPORTED_FEATURE_USB);
+
                supported |= value;
                key = va_arg(list, const char *);
                if (!key) break;
@@ -65,6 +64,7 @@ int _tethering_check_feature_supported(const char* feature, ...)
        if (!supported) {
                ERR("Not supported feature");
                set_last_result(TETHERING_ERROR_NOT_SUPPORT_API);
+               va_end(list);
                return TETHERING_ERROR_NOT_SUPPORT_API;
        }
        va_end(list);
@@ -72,3 +72,22 @@ int _tethering_check_feature_supported(const char* feature, ...)
 
        return TETHERING_ERROR_NONE;
 }
+
+void _tethering_add_handle(tethering_h handle)
+{
+       tethering_handle_list = g_slist_append(tethering_handle_list, handle);
+}
+
+void _tethering_remove_handle(tethering_h handle)
+{
+       tethering_handle_list = g_slist_remove(tethering_handle_list, handle);
+}
+
+bool _tethering_check_handle(tethering_h handle)
+{
+       if (g_slist_find(tethering_handle_list, handle) != NULL)
+               return true;
+       else
+               return false;
+}
+