Add TOUCH_SOUND setter function
[platform/core/api/system-settings.git] / CMakeLists.txt
index b4bc7b4..6b4b3a4 100755 (executable)
@@ -1,20 +1,50 @@
 
 CMAKE_MINIMUM_REQUIRED(VERSION 2.6)
 SET(fw_name "capi-system-system-settings")
+SET(unit_test "system-setting-unittest")
 
 PROJECT(${fw_name})
 
 SET(CMAKE_INSTALL_PREFIX /usr)
 SET(PREFIX ${CMAKE_INSTALL_PREFIX})
 
+SET(SYSTEM_SETTINGS_UTIL system-settings-util)
+SET(LIB_SYSTEM_SETTINGS_UTIL system-settings-util)
+
+#GCOV_PREFIX=/target/run’ and ‘GCOV_PREFIX_STRIP=1
+#---------------------------------------------------------------
+# code coverage
+#---------------------------------------------------------------
+set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/scripts/cmake)
+IF ((CMAKE_BUILD_TYPE STREQUAL "UNITTEST") OR (CMAKE_BUILD_TYPE STREQUAL "GCOVTEST"))
+       SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${EXTRA_CFLAGS} -g -O0 -fprofile-arcs -ftest-coverage --coverage")
+       SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS} -g -O0 -fprofile-arcs -ftest-coverage --coverage")
+ENDIF() #CMAKE_BUILD_TYPE STREQUAL "UNITTEST"
+#---------------------------------------------------------------
+# include/system-setting-config.h
+#---------------------------------------------------------------
+set (VERSION_MAJOR 1)
+set (VERSION_MINOR 0)
+set (SETTING_DEF_RES_PATH "\"${SETTING_DEF_RES}\"")
+
+set (SETTING_TIME_ZONEINFO_PATH "\"/usr/share/zoneinfo/\"")
+set (SETTING_TZONE_SYMLINK_PATH "\"/opt/etc/localtime\"")
+
+#      DSETTING_DEF_RES
+configure_file (
+               "${PROJECT_SOURCE_DIR}/system-setting-config.h.in"
+               "${PROJECT_SOURCE_DIR}/include/system-setting-config.h"
+)
+
+
 SET(LIBDIR "${CMAKE_LIBDIR}")
 SET(INC_DIR include)
 INCLUDE_DIRECTORIES(${INC_DIR})
 
-SET(requires "elementary ecore ecore-file dlog vconf appcore-efl capi-base-common glib-2.0 gobject-2.0 fontconfig libxml-2.0 bundle capi-appfw-application pkgmgr pkgmgr-info")
-
+SET(requires "dlog vconf fontconfig libxml-2.0 pkgmgr pkgmgr-info alarm-service capi-media-metadata-extractor aul json-glib-1.0 capi-appfw-app-manager capi-appfw-package-manager capi-system-info glib-2.0")
 SET(pc_requires "capi-base-common")
 
+
 IF(TIZEN_WEARABLE)
     ADD_DEFINITIONS(-DTIZEN_WEARABLE)
 ENDIF(TIZEN_WEARABLE)
@@ -28,8 +58,9 @@ FOREACH(flag ${${fw_name}_CFLAGS})
     SET(EXTRA_CFLAGS "${EXTRA_CFLAGS} ${flag}")
 ENDFOREACH(flag)
 
-#SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS} -fPIC -Wall -Werror")
-SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS} -fPIC")
+
+SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${EXTRA_CFLAGS} -fPIC -Wall -Werror-implicit-function-declaration")
+
 SET(CMAKE_C_FLAGS_DEBUG "-O0 -g")
 
 IF("${ARCH}" STREQUAL "arm")
@@ -39,9 +70,31 @@ ENDIF("${ARCH}" STREQUAL "arm")
 ADD_DEFINITIONS("-DPREFIX=\"${CMAKE_INSTALL_PREFIX}\"")
 ADD_DEFINITIONS("-DSLP_DEBUG")
 
+ADD_DEFINITIONS("-D_TZ_SYS_DATA=\"${TZ_SYS_DATA}\"")
+ADD_DEFINITIONS("-D_TZ_SYS_ETC=\"${TZ_SYS_ETC}\"")
+ADD_DEFINITIONS("-D_TZ_SYS_RO_SHARE=\"${TZ_SYS_RO_SHARE}\"")
+ADD_DEFINITIONS("-D_TZ_SYS_SHARE=\"${TZ_SYS_SHARE}\"")
+ADD_DEFINITIONS("-DSETTING_DEF_RES=\"${SETTING_DEF_RES}\"")
+
 SET(CMAKE_EXE_LINKER_FLAGS "-Wl,--as-needed -Wl,--rpath=/usr/lib")
+IF (CMAKE_BUILD_TYPE STREQUAL "UNITTEST")
+       SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -lgcov")
+       ADD_SUBDIRECTORY(${CMAKE_SOURCE_DIR}/unit_test)
+ENDIF() #CMAKE_BUILD_TYPE STREQUAL "UNITTEST"
+
+INCLUDE_DIRECTORIES(${CMAKE_SOURCE_DIR}/${SYSTEM_SETTINGS_UTIL}/include)
+ADD_SUBDIRECTORY(${CMAKE_SOURCE_DIR}/${SYSTEM_SETTINGS_UTIL})
+
+#AUX_SOURCE_DIRECTORY(src SOURCES)
+SET(SOURCES "src/system_setting_platform.c"
+                       "src/system_settings.c"
+                       "src/system_settings_json.c"
+                       "src/system_settings_ringtones.c"
+                       "src/system_settings_multi_callback.c"
+                       "src/system_settings_vconf.c")
+
+#SET(UNITSOURES "system_setting_unittest.c")
 
-aux_source_directory(src SOURCES)
 ADD_LIBRARY(${fw_name} SHARED ${SOURCES})
 
 TARGET_LINK_LIBRARIES(${fw_name} ${${fw_name}_LDFLAGS})
@@ -53,28 +106,15 @@ SET_TARGET_PROPERTIES(${fw_name}
      CLEAN_DIRECT_OUTPUT 1
 )
 
-# Test application - TC
-#ADD_EXECUTABLE(test TC/test.c)
-#TARGET_LINK_LIBRARIES(test ${fw_name})
-
-#SET_TARGET_PROPERTIES(test PROPERTIES OUTPUT_NAME test_system_settings)
-#INSTALL(TARGETS test DESTINATION /usr/local/bin)
-#---------------------------------------------------------------------
-
-# Test application - TC_gui
-#ADD_EXECUTABLE(test_gui TC_gui/main.c)
-#
-#INCLUDE(FindPkgConfig)
-#pkg_check_modules(test_gui REQUIRED "elementary appcore-efl ecore-imf eina ecore ecore-evas ecore-input")
-#FOREACH(flag ${test_gui_CFLAGS})
-#    SET(EXTRA_CFLAGS "${EXTRA_CFLAGS} ${flag}")
-#ENDFOREACH(flag)
-#
-#TARGET_LINK_LIBRARIES(test_gui ${fw_name})
-#SET_TARGET_PROPERTIES(test_gui PROPERTIES OUTPUT_NAME test_system_settings_gui)
-#INSTALL(TARGETS test_gui DESTINATION /usr/local/bin)
-#---------------------------------------------------------------------
-
+IF (CMAKE_BUILD_TYPE STREQUAL "UNITTEST")
+       # Coverage Testing
+       INSTALL(
+               DIRECTORY "CMakeFiles" DESTINATION /usr/src/packages/BUILD/capi-system-system-settings-${FULLVER}
+                       FILES_MATCHING
+                       PATTERN "*.gcno"
+                       PATTERN "*system_setting_unittest.c.gcno" EXCLUDE
+                       )
+ENDIF() #CMAKE_BUILD_TYPE STREQUAL "UNITTEST"
 
 
 INSTALL(TARGETS ${fw_name} DESTINATION ${LIBDIR})
@@ -82,6 +122,8 @@ INSTALL(
         DIRECTORY ${INC_DIR}/ DESTINATION include/system
         FILES_MATCHING
         PATTERN "*_private.h" EXCLUDE
+        PATTERN "*_json.h" EXCLUDE
+        PATTERN "*_ringtones.h" EXCLUDE
         PATTERN "${INC_DIR}/*.h"
         )
 
@@ -103,10 +145,10 @@ IF(UNIX)
 
 ADD_CUSTOM_TARGET (distclean @echo cleaning for source distribution)
 ADD_CUSTOM_COMMAND(
-        DEPENDS clean 
+        DEPENDS clean
         COMMENT "distribution clean"
         COMMAND find
-        ARGS    . 
+        ARGS    .
         -not -name config.cmake -and \(
         -name tester.c -or
         -name Testing -or
@@ -127,6 +169,5 @@ ADD_CUSTOM_COMMAND(
         TARGET  distclean
         VERBATIM
 )
-
 ENDIF(UNIX)