add applistchanged event & delete area defination sandbox/wangzhiqiang/dbus_ws
authorwang_zhiqiang <wang_zhiqiang@dl.cn.nexty-ele.com>
Mon, 21 Jan 2019 10:07:29 +0000 (18:07 +0800)
committerwang_zhiqiang <wang_zhiqiang@dl.cn.nexty-ele.com>
Wed, 23 Jan 2019 12:48:25 +0000 (20:48 +0800)
Change-Id: I3c58712a2e4f080cc75387f94d3d91bb3cba6629

include/libhomescreen.hpp
src/libhomescreen.cpp

index 0fed49f..b9f5e75 100644 (file)
@@ -40,6 +40,7 @@ public:
        using handler_func = std::function<void(json_object*)>;
 
        enum EventType {
+               Event_Min,
                Event_ShowWindow = 1,
                Event_TapShortcut = 1,
                Event_OnScreenMessage,
@@ -47,19 +48,11 @@ public:
                Event_HideWindow,
                Event_ReplyShowWindow,
                Event_ShowNotification,
-               Event_ShowInformation
+               Event_ShowInformation,
+               Event_AppListChanged,
+               Event_Max
        };
 
-       /* Key for json obejct */
-       const char *_keyParameter = "parameter";
-       const char *_keyArea = "area";
-
-       /* display area */
-       const char *_areaNormal = "normal";
-       const char *_areaFullScreen = "fullscreen";
-       const char *_areaSplitMain = "split.main";
-       const char *_areaSplitSub = "split.sub";
-
        static const std::vector<std::string> api_list;
        static const std::vector<std::string> event_list;
 
@@ -87,6 +80,7 @@ public:
        int replyShowWindow(const char* application_id, json_object* json);
        int showNotification(json_object* json);
        int showInformation(json_object* json);
+       int getRunnables(void);
 
 
 private:
index 84e3472..b54e373 100644 (file)
@@ -46,7 +46,8 @@ const std::vector<std::string> LibHomeScreen::api_list {
        std::string("hideWindow"),
        std::string("replyShowWindow"),
        std::string("showNotification"),
-       std::string("showInformation")
+       std::string("showInformation"),
+       std::string("getRunnables")
 };
 
 const std::vector<std::string> LibHomeScreen::event_list {
@@ -58,6 +59,7 @@ const std::vector<std::string> LibHomeScreen::event_list {
        std::string("replyShowWindow"),
        std::string("showNotification"),
        std::string("showInformation"),
+       std::string("application-list-changed"),
        std::string("none")
 };
 
@@ -294,7 +296,7 @@ int LibHomeScreen::onScreenReply(const char* reply_message)
  */
 void LibHomeScreen::set_event_handler(enum EventType et, handler_func f)
 {
-       if (et >= 1 && et <= 7) {
+       if (et > Event_Min && et < Event_Max) {
                switch (et) {
                        case Event_ShowWindow:
                                this->subscribe(LibHomeScreen::event_list[0]);
@@ -317,6 +319,9 @@ void LibHomeScreen::set_event_handler(enum EventType et, handler_func f)
                        case Event_ShowInformation:
                                this->subscribe(LibHomeScreen::event_list[6]);
                                break;
+                       case Event_AppListChanged:
+                               this->subscribe(LibHomeScreen::event_list[7]);
+                               break;
                }
 
                this->handlers[et] = std::move(f);
@@ -588,6 +593,23 @@ int LibHomeScreen::showInformation(json_object* json)
        return this->call("showInformation", json);
 }
 
+/**
+ * get runnables list
+ *
+ * Call HomeScreen Service's getRunnables verb to get runnalbes list.
+ *
+ * #### Parameters
+ * - Nothing
+ *
+ * #### Return
+ * - Returns 0 on success or -1 in case of error.
+ *
+ */
+int LibHomeScreen::getRunnables(void)
+{
+       return this->call("getRunnables", nullptr);
+}
+
 
 /************* Callback Function *************/
 
@@ -683,6 +705,12 @@ void LibHomeScreen::on_event(void *closure, const char *event, struct afb_wsj1_m
                        i->second(json_data);
                }
        }
+       else if (strcasecmp(event_type, LibHomeScreen::event_list[7].c_str()) == 0) {
+               auto i = this->handlers.find(Event_AppListChanged);
+               if ( i != this->handlers.end() ) {
+                       i->second(json_data);
+               }
+       }
 }
 
 /**