summaryrefslogtreecommitdiffstats
path: root/ecmake/lib
diff options
context:
space:
mode:
authorJérémy Zurcher <jeremy@asynk.ch>2012-04-16 09:40:15 +0200
committerJérémy Zurcher <jeremy@asynk.ch>2012-04-16 09:40:15 +0200
commit6f682d7d94a30433531137476cd4aaa4dd200f3b (patch)
tree673f943db1f1df0e583509858f2c62c78708f9a7 /ecmake/lib
parent2224f05d43a0d782b626d09f397767597b3d7f4f (diff)
parent23929ded8ba244359e871e1d02ee1d05d060ea71 (diff)
downloadskeletons-6f682d7d94a30433531137476cd4aaa4dd200f3b.zip
skeletons-6f682d7d94a30433531137476cd4aaa4dd200f3b.tar.gz
Merge branch 'master' of asynk.ch:templates
Diffstat (limited to 'ecmake/lib')
-rw-r--r--ecmake/lib/CMakeLists.txt19
-rw-r--r--ecmake/lib/ecmake.c59
-rw-r--r--ecmake/lib/ecmake.h7
3 files changed, 85 insertions, 0 deletions
diff --git a/ecmake/lib/CMakeLists.txt b/ecmake/lib/CMakeLists.txt
new file mode 100644
index 0000000..6539c55
--- /dev/null
+++ b/ecmake/lib/CMakeLists.txt
@@ -0,0 +1,19 @@
+LIST(APPEND ECMAKE_CC_SOURCES
+ ecmake.c
+ )
+
+include_directories(
+ ${ELEMENTARY_INCLUDE_DIRS}
+ )
+
+add_library(ecmake SHARED ${ECMAKE_CC_SOURCES})
+target_link_libraries(ecmake
+ ${ELEMENTARY_LIBRARIES}
+ ${EFL_COVERAGE_LIBS}
+ )
+
+set_target_properties(ecmake PROPERTIES
+ COMPILE_FLAGS "${EFL_COVERAGE_CFLAGS}")
+set_target_properties(ecmake PROPERTIES
+ VERSION ${ECMAKE_VERSION} SOVERSION ${ECMAKE_VERSION_MAJOR})
+set_target_properties(ecmake PROPERTIES OUTPUT_NAME "ecmake")
diff --git a/ecmake/lib/ecmake.c b/ecmake/lib/ecmake.c
new file mode 100644
index 0000000..715bfac
--- /dev/null
+++ b/ecmake/lib/ecmake.c
@@ -0,0 +1,59 @@
+
+#include "ecmake.h"
+#include "config.h"
+
+#include <Elementary.h>
+
+static void
+on_done(void *data, Evas_Object *obj, void *event_info)
+{
+ // quit the mainloop (elm_run function will return)
+ elm_exit();
+}
+
+int
+hello_world()
+{
+ Evas_Object *win, *box, *lab, *btn;
+
+ // new window - do the usual and give it a name (hello) and title (Hello)
+ win = elm_win_util_standard_add("hello", "Hello");
+ // when the user clicks "close" on a window there is a request to delete
+ evas_object_smart_callback_add(win, "delete,request", on_done, NULL);
+
+ // add a box object - default is vertical. a box holds children in a row,
+ // either horizontally or vertically. nothing more.
+ box = elm_box_add(win);
+ // make the box horizontal
+ elm_box_horizontal_set(box, EINA_TRUE);
+ // add object as a resize object for the window (controls window minimum
+ // size as well as gets resized if window is resized)
+ elm_win_resize_object_add(win, box);
+ evas_object_show(box);
+
+ // add a label widget, set the text and put it in the pad frame
+ lab = elm_label_add(win);
+ // set default text of the label
+ elm_object_text_set(lab, "Hello out there world!");
+ // pack the label at the end of the box
+ elm_box_pack_end(box, lab);
+ evas_object_show(lab);
+
+ // add an ok button
+ btn = elm_button_add(win);
+ // set default text of button to "OK"
+ elm_object_text_set(btn, "OK");
+ // pack the button at the end of the box
+ elm_box_pack_end(box, btn);
+ evas_object_show(btn);
+ // call on_done when button is clicked
+ evas_object_smart_callback_add(btn, "clicked", on_done, NULL);
+
+ // now we are done, show the window
+ evas_object_show(win);
+
+ // run the mainloop and process events and callbacks
+ elm_run();
+ elm_shutdown();
+ return 0;
+}
diff --git a/ecmake/lib/ecmake.h b/ecmake/lib/ecmake.h
new file mode 100644
index 0000000..f7f456f
--- /dev/null
+++ b/ecmake/lib/ecmake.h
@@ -0,0 +1,7 @@
+#ifndef ECMAKE_H
+#define ECMAKE_H
+
+int
+hello_world();
+
+#endif