elementary/naviframe - added overlap style and updated test case.
[framework/uifw/elementary.git] / src / bin / test_panel.c
index 70578b9..6330645 100644 (file)
@@ -4,6 +4,8 @@
 #endif
 #ifndef ELM_LIB_QUICKLAUNCH
 
+#define LIST_ITEM_MAX 20
+
 static Elm_Genlist_Item_Class itc;
 
 static void _bstatus(void *data, Evas_Object *obj, void *event_info);
@@ -15,6 +17,8 @@ static void _item_del(void *data, Evas_Object *obj);
 static void _fill_list(Evas_Object *obj);
 static Eina_Bool _dir_has_subs(const char *path);
 
+static Eina_List *dirs = NULL;
+
 static void
 _tstatus(void *data, Evas_Object *obj, void *event_info __UNUSED__)
 {
@@ -87,24 +91,26 @@ _fill_list(Evas_Object *obj)
 {
    DIR *d;
    struct dirent *de;
-   Eina_List *dirs = NULL, *l;
+   Eina_List *l;
    char *real;
+   unsigned int x = 0;
 
-   if (!(d = opendir(getenv("HOME")))) return;
-   while ((de = readdir(d)))
+   if (!dirs)
      {
-        char buff[PATH_MAX];
-
-        if (de->d_name[0] == '.') continue;
-        snprintf(buff, sizeof(buff), "%s/%s", getenv("HOME"), de->d_name);
-        if (!ecore_file_is_dir(buff)) continue;
-        real = ecore_file_realpath(buff);
-        dirs = eina_list_append(dirs, real);
+        if (!(d = opendir(getenv("HOME")))) return;
+        while ((de = readdir(d)) && (x < LIST_ITEM_MAX))
+          {
+             char buff[PATH_MAX];
+
+             if (de->d_name[0] == '.') continue;
+             snprintf(buff, sizeof(buff), "%s/%s", getenv("HOME"), de->d_name);
+             if (!ecore_file_is_dir(buff)) continue;
+             x++;
+             real = ecore_file_realpath(buff);
+             dirs = eina_list_sorted_insert(dirs, EINA_COMPARE_CB(strcoll), real);
+          }
+        closedir(d);
      }
-   closedir(d);
-
-   dirs = eina_list_sort(dirs, eina_list_count(dirs), EINA_COMPARE_CB(strcoll));
-
    EINA_LIST_FOREACH(dirs, l, real)
      {
         Eina_Bool result = EINA_FALSE;
@@ -115,11 +121,9 @@ _fill_list(Evas_Object *obj)
                                   NULL, ELM_GENLIST_ITEM_NONE, NULL, NULL);
         else
           elm_genlist_item_append(obj, &itc, eina_stringshare_add(real),
-                                  NULL, ELM_GENLIST_ITEM_SUBITEMS,
+                                  NULL, ELM_GENLIST_ITEM_TREE,
                                   NULL, NULL);
-        free(real);
      }
-   eina_list_free(dirs);
 }
 
 static Eina_Bool
@@ -174,12 +178,12 @@ test_panel(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info
    evas_object_size_hint_align_set(bx, EVAS_HINT_FILL, EVAS_HINT_FILL);
    evas_object_show(bx);
 
-   panel = elm_panel_add(win);
+   panel = elm_panel_add(vbx);
    elm_panel_orient_set(panel, ELM_PANEL_ORIENT_TOP);
    evas_object_size_hint_weight_set(panel, EVAS_HINT_EXPAND, 0);
    evas_object_size_hint_align_set(panel, EVAS_HINT_FILL, EVAS_HINT_FILL);
 
-   toolbar = elm_toolbar_add(win);
+   toolbar = elm_toolbar_add(panel);
    elm_toolbar_homogeneous_set(toolbar, 0);
    elm_toolbar_shrink_mode_set(toolbar, ELM_TOOLBAR_SHRINK_NONE);
    evas_object_size_hint_weight_set(toolbar, EVAS_HINT_EXPAND, 0);
@@ -192,7 +196,7 @@ test_panel(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info
    elm_box_pack_end(vbx, panel);
    evas_object_show(panel);
 
-   panel = elm_panel_add(win);
+   panel = elm_panel_add(bx);
    elm_panel_orient_set(panel, ELM_PANEL_ORIENT_LEFT);
    evas_object_size_hint_weight_set(panel, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
    evas_object_size_hint_align_set(panel, 0, EVAS_HINT_FILL);
@@ -203,7 +207,7 @@ test_panel(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info
    itc.func.state_get = _state_get;
    itc.func.del = _item_del;
 
-   list = elm_genlist_add(win);
+   list = elm_genlist_add(panel);
    evas_object_size_hint_min_set(list, 100, -1);
    evas_object_size_hint_weight_set(list, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
    evas_object_size_hint_align_set(list, EVAS_HINT_FILL, EVAS_HINT_FILL);
@@ -216,13 +220,13 @@ test_panel(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info
 
    _fill_list(list);
 
-   panel = elm_panel_add(win);
+   panel = elm_panel_add(bx);
    elm_panel_orient_set(panel, ELM_PANEL_ORIENT_RIGHT);
    evas_object_size_hint_weight_set(panel, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
    evas_object_size_hint_align_set(panel, 1, EVAS_HINT_FILL);
    elm_panel_hidden_set(panel, EINA_TRUE);
 
-   list = elm_genlist_add(win);
+   list = elm_genlist_add(panel);
    evas_object_size_hint_min_set(list, 100, -1);
    evas_object_size_hint_weight_set(list, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
    evas_object_size_hint_align_set(list, EVAS_HINT_FILL, EVAS_HINT_FILL);
@@ -234,16 +238,21 @@ test_panel(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info
    evas_object_show(panel);
 
    _fill_list(list);
+   {
+      char *dir;
+      EINA_LIST_FREE(dirs, dir)
+        free(dir);
+   }
 
    elm_box_pack_end(vbx, bx);
 
-   panel = elm_panel_add(win);
+   panel = elm_panel_add(vbx);
    elm_panel_orient_set(panel, ELM_PANEL_ORIENT_BOTTOM);
    evas_object_size_hint_weight_set(panel, EVAS_HINT_EXPAND, 0);
    evas_object_size_hint_align_set(panel, EVAS_HINT_FILL, EVAS_HINT_FILL);
    elm_panel_hidden_set(panel, EINA_TRUE);
 
-   toolbar = elm_toolbar_add(win);
+   toolbar = elm_toolbar_add(panel);
    elm_toolbar_homogeneous_set(toolbar, 0);
    elm_toolbar_shrink_mode_set(toolbar, ELM_TOOLBAR_SHRINK_NONE);
    evas_object_size_hint_weight_set(toolbar, EVAS_HINT_EXPAND, 0);