tizen 2.4 release
[framework/uifw/elementary.git] / src / bin / test_eio.c
index 7e26a4c..51118b7 100644 (file)
@@ -1,18 +1,36 @@
 #ifdef HAVE_CONFIG_H
 # include "elementary_config.h"
 #endif
+
+#ifdef HAVE_SYS_TIMES_H
+# include <sys/times.h>
+#endif
+
+#ifdef _WIN32
+# ifndef WIN32_LEAN_AND_MEAN
+#  define WIN32_LEAN_AND_MEAN
+# endif
+# include <windows.h>
+# undef WIN32_LEAN_AND_MEAN
+#endif
+
 #include <Eio.h>
-#include <sys/times.h>
 
 #include <Elementary.h>
-#ifndef ELM_LIB_QUICKLAUNCH
 
 static Elm_Genlist_Item_Class it_eio;
 
+#ifdef _WIN32
+ULONGLONG st_time_kernel;
+ULONGLONG st_time_user;
+ULONGLONG en_time_kernel;
+ULONGLONG en_time_user;
+#else
 static clock_t st_time;
 static clock_t en_time;
 static struct tms st_cpu;
 static struct tms en_cpu;
+#endif
 
 static void _sel_file(void *data, Evas_Object *obj, void *event_info);
 static Eina_Bool _ls_filter_cb(void *data, Eio_File *handler, const char *file);
@@ -27,12 +45,12 @@ static void _gl_del(void *data, Evas_Object *obj);
 static void _test_eio_clear(void *data, Evas_Object *obj, void *event);
 
 static void
-_sel_file(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+_sel_file(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
 {
 }
 
 static Eina_Bool
-_ls_filter_cb(void *data __UNUSED__, Eio_File *handler __UNUSED__, const char *file __UNUSED__)
+_ls_filter_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED, const char *file EINA_UNUSED)
 {
   return EINA_TRUE;
 }
@@ -47,7 +65,7 @@ _compare_cb(const void *data1, const void *data2)
 }
 
 static void
-_ls_main_cb(void *data, Eio_File *handler __UNUSED__, const char *file)
+_ls_main_cb(void *data, Eio_File *handler EINA_UNUSED, const char *file)
 {
    elm_genlist_item_sorted_insert(data,
                                   &it_eio,
@@ -60,29 +78,76 @@ _ls_main_cb(void *data, Eio_File *handler __UNUSED__, const char *file)
 }
 
 static void
-_ls_done_cb(void *data __UNUSED__, Eio_File *handler __UNUSED__)
+_ls_done_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED)
 {
+#ifdef _WIN32
+   FILETIME tc;
+   FILETIME te;
+   FILETIME tk;
+   FILETIME tu;
+   ULARGE_INTEGER time_kernel;
+   ULARGE_INTEGER time_user;
+
+   if (!GetProcessTimes(GetCurrentProcess(),
+                        &tc, &te, &tk, &tu))
+     return;
+
+   time_kernel.u.LowPart = tk.dwLowDateTime;
+   time_kernel.u.HighPart = tk.dwHighDateTime;
+   en_time_kernel = time_kernel.QuadPart;
+
+   time_user.u.LowPart = tu.dwLowDateTime;
+   time_user.u.HighPart = tu.dwHighDateTime;
+   en_time_user = time_user.QuadPart;
+
+   fprintf(stderr, "ls done\n");
+   fprintf(stderr, "Kernel Time: %lld, User Time: %lld",
+           (en_time_kernel - st_time_kernel),
+           (en_time_user - st_time_user));
+#else
    en_time = times(&en_cpu);
    fprintf(stderr, "ls done\n");
    fprintf(stderr, "Real Time: %.jd, User Time: %.jd, System Time: %.jd\n",
            (intmax_t)(en_time - st_time),
            (intmax_t)(en_cpu.tms_utime - st_cpu.tms_utime),
            (intmax_t)(en_cpu.tms_stime - st_cpu.tms_stime));
+#endif
 }
 
 static void
-_ls_error_cb(void *data __UNUSED__, Eio_File *handler __UNUSED__, int error)
+_ls_error_cb(void *data EINA_UNUSED, Eio_File *handler EINA_UNUSED, int error)
 {
    fprintf(stderr, "error: [%s]\n", strerror(error));
 }
 
 static void
-_file_chosen(void *data, Evas_Object *obj __UNUSED__, void *event_info)
+_file_chosen(void *data, Evas_Object *obj EINA_UNUSED, void *event_info)
 {
    const char *file = event_info;
    if (file)
      {
+#ifdef _WIN32
+        FILETIME tc;
+        FILETIME te;
+        FILETIME tk;
+        FILETIME tu;
+        ULARGE_INTEGER time_kernel;
+        ULARGE_INTEGER time_user;
+
+        if (!GetProcessTimes(GetCurrentProcess(),
+                             &tc, &te, &tk, &tu))
+          return;
+
+        time_kernel.u.LowPart = tk.dwLowDateTime;
+        time_kernel.u.HighPart = tk.dwHighDateTime;
+        st_time_kernel = time_kernel.QuadPart;
+
+        time_user.u.LowPart = tu.dwLowDateTime;
+        time_user.u.HighPart = tu.dwHighDateTime;
+        st_time_user = time_user.QuadPart;
+#else
         st_time = times(&st_cpu);
+#endif
         eio_file_ls(file,
                     _ls_filter_cb,
                     _ls_main_cb,
@@ -93,7 +158,7 @@ _file_chosen(void *data, Evas_Object *obj __UNUSED__, void *event_info)
 }
 
 static char *
-_gl_text_get(void *data, Evas_Object *obj __UNUSED__, const char *part __UNUSED__)
+_gl_text_get(void *data, Evas_Object *obj EINA_UNUSED, const char *part EINA_UNUSED)
 {
    char buf[PATH_MAX];
    snprintf(buf, sizeof(buf), "Item # %s", (char*)data);
@@ -101,30 +166,30 @@ _gl_text_get(void *data, Evas_Object *obj __UNUSED__, const char *part __UNUSED_
 }
 
 static Evas_Object *
-_gl_content_get(void *data __UNUSED__, Evas_Object *obj __UNUSED__, const char *part __UNUSED__)
+_gl_content_get(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, const char *part EINA_UNUSED)
 {
    return NULL;
 }
 
 static Eina_Bool
-_gl_state_get(void *data __UNUSED__, Evas_Object *obj __UNUSED__, const char *part __UNUSED__)
+_gl_state_get(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, const char *part EINA_UNUSED)
 {
    return EINA_FALSE;
 }
 
 static void
-_gl_del(void *data __UNUSED__, Evas_Object *obj __UNUSED__)
+_gl_del(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED)
 {
 }
 
 static void
-_test_eio_clear(void *data, Evas_Object *obj __UNUSED__, void *event __UNUSED__)
+_test_eio_clear(void *data, Evas_Object *obj EINA_UNUSED, void *event EINA_UNUSED)
 {
    elm_genlist_clear(data);
 }
 
 void
-test_eio(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __UNUSED__)
+test_eio(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
 {
    Evas_Object *win, *vbox, *hbox, *ic, *bt, *fs_bt, *gl;
 
@@ -138,8 +203,8 @@ test_eio(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __
    elm_win_autodel_set(win, EINA_TRUE);
 
    vbox = elm_box_add(win);
-   elm_win_resize_object_add(win, vbox);
    evas_object_size_hint_weight_set(vbox, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   elm_win_resize_object_add(win, vbox);
    evas_object_show(vbox);
 
    gl = elm_genlist_add(win);
@@ -158,7 +223,7 @@ test_eio(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __
    elm_object_text_set(fs_bt, "Select a dir");
    elm_object_part_content_set(fs_bt, "icon", ic);
    elm_fileselector_button_inwin_mode_set(fs_bt, EINA_TRUE);
-   elm_fileselector_button_folder_only_set(fs_bt, EINA_TRUE);
+   elm_fileselector_folder_only_set(fs_bt, EINA_TRUE);
 
    elm_box_pack_end(hbox, fs_bt);
    elm_box_pack_end(vbox, hbox);
@@ -178,5 +243,3 @@ test_eio(void *data __UNUSED__, Evas_Object *obj __UNUSED__, void *event_info __
    evas_object_resize(win, 300, 500);
    evas_object_show(win);
 }
-
-#endif