From: Jinkun Jang Date: Tue, 12 Mar 2013 16:46:10 +0000 (+0900) Subject: Tizen 2.1 base X-Git-Tag: submit/tizen_2.1/20130424.230548~2 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=3dbe8bd5436ee0295a371c0c16bd67c4c28adbcd;p=platform%2Fcore%2Fapi%2Fruntime-info.git Tizen 2.1 base --- diff --git a/CMakeLists.txt b/CMakeLists.txt new file mode 100755 index 0000000..a598959 --- /dev/null +++ b/CMakeLists.txt @@ -0,0 +1,96 @@ + +CMAKE_MINIMUM_REQUIRED(VERSION 2.6) +SET(fw_name "capi-system-runtime-info") + +PROJECT(${fw_name}) + +SET(CMAKE_INSTALL_PREFIX /usr) +SET(PREFIX ${CMAKE_INSTALL_PREFIX}) + +SET(INC_DIR include) +INCLUDE_DIRECTORIES(${INC_DIR}) + +SET(requires "dlog vconf capi-base-common") +SET(pc_requires "capi-base-common") + +INCLUDE(FindPkgConfig) +pkg_check_modules(${fw_name} REQUIRED ${requires}) +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_DEBUG "-O0 -g") + +IF("${ARCH}" STREQUAL "arm") + ADD_DEFINITIONS("-DTARGET") +ENDIF("${ARCH}" STREQUAL "arm") + +ADD_DEFINITIONS("-DPREFIX=\"${CMAKE_INSTALL_PREFIX}\"") +ADD_DEFINITIONS("-DSLP_DEBUG") + +SET(CMAKE_EXE_LINKER_FLAGS "-fvisibility=hidden -Wl,--as-needed -Wl,--rpath=/usr/lib") + +aux_source_directory(src SOURCES) +ADD_LIBRARY(${fw_name} SHARED ${SOURCES}) + +TARGET_LINK_LIBRARIES(${fw_name} ${${fw_name}_LDFLAGS}) + +SET_TARGET_PROPERTIES(${fw_name} + PROPERTIES + VERSION ${FULLVER} + SOVERSION ${MAJORVER} + CLEAN_DIRECT_OUTPUT 1 +) + +INSTALL(TARGETS ${fw_name} DESTINATION lib) +INSTALL( + DIRECTORY ${INC_DIR}/ DESTINATION include/system + FILES_MATCHING + PATTERN "*_private.h" EXCLUDE + PATTERN "${INC_DIR}/*.h" + ) + +SET(PC_NAME ${fw_name}) +SET(PC_REQUIRED ${pc_requires}) +SET(PC_LDFLAGS -l${fw_name}) +SET(PC_CFLAGS -I\${includedir}/system) + +CONFIGURE_FILE( + capi-system-runtime-info.pc.in + ${CMAKE_CURRENT_SOURCE_DIR}/${fw_name}.pc + @ONLY +) +INSTALL(FILES ${CMAKE_CURRENT_SOURCE_DIR}/${fw_name}.pc DESTINATION lib/pkgconfig) + +IF(UNIX) + +ADD_CUSTOM_TARGET (distclean @echo cleaning for source distribution) +ADD_CUSTOM_COMMAND( + DEPENDS clean + COMMENT "distribution clean" + COMMAND find + ARGS . + -not -name config.cmake -and \( + -name tester.c -or + -name Testing -or + -name CMakeFiles -or + -name cmake.depends -or + -name cmake.check_depends -or + -name CMakeCache.txt -or + -name cmake.check_cache -or + -name *.cmake -or + -name Makefile -or + -name core -or + -name core.* -or + -name gmon.out -or + -name install_manifest.txt -or + -name *.pc -or + -name *~ \) + | grep -v TC | xargs rm -rf + TARGET distclean + VERBATIM +) + +ENDIF(UNIX) + diff --git a/LICENSE.APLv2 b/LICENSE.APLv2 new file mode 100644 index 0000000..261eeb9 --- /dev/null +++ b/LICENSE.APLv2 @@ -0,0 +1,201 @@ + Apache License + Version 2.0, January 2004 + http://www.apache.org/licenses/ + + TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + + 1. Definitions. + + "License" shall mean the terms and conditions for use, reproduction, + and distribution as defined by Sections 1 through 9 of this document. + + "Licensor" shall mean the copyright owner or entity authorized by + the copyright owner that is granting the License. + + "Legal Entity" shall mean the union of the acting entity and all + other entities that control, are controlled by, or are under common + control with that entity. For the purposes of this definition, + "control" means (i) the power, direct or indirect, to cause the + direction or management of such entity, whether by contract or + otherwise, or (ii) ownership of fifty percent (50%) or more of the + outstanding shares, or (iii) beneficial ownership of such entity. + + "You" (or "Your") shall mean an individual or Legal Entity + exercising permissions granted by this License. + + "Source" form shall mean the preferred form for making modifications, + including but not limited to software source code, documentation + source, and configuration files. + + "Object" form shall mean any form resulting from mechanical + transformation or translation of a Source form, including but + not limited to compiled object code, generated documentation, + and conversions to other media types. + + "Work" shall mean the work of authorship, whether in Source or + Object form, made available under the License, as indicated by a + copyright notice that is included in or attached to the work + (an example is provided in the Appendix below). + + "Derivative Works" shall mean any work, whether in Source or Object + form, that is based on (or derived from) the Work and for which the + editorial revisions, annotations, elaborations, or other modifications + represent, as a whole, an original work of authorship. For the purposes + of this License, Derivative Works shall not include works that remain + separable from, or merely link (or bind by name) to the interfaces of, + the Work and Derivative Works thereof. + + "Contribution" shall mean any work of authorship, including + the original version of the Work and any modifications or additions + to that Work or Derivative Works thereof, that is intentionally + submitted to Licensor for inclusion in the Work by the copyright owner + or by an individual or Legal Entity authorized to submit on behalf of + the copyright owner. For the purposes of this definition, "submitted" + means any form of electronic, verbal, or written communication sent + to the Licensor or its representatives, including but not limited to + communication on electronic mailing lists, source code control systems, + and issue tracking systems that are managed by, or on behalf of, the + Licensor for the purpose of discussing and improving the Work, but + excluding communication that is conspicuously marked or otherwise + designated in writing by the copyright owner as "Not a Contribution." + + "Contributor" shall mean Licensor and any individual or Legal Entity + on behalf of whom a Contribution has been received by Licensor and + subsequently incorporated within the Work. + + 2. Grant of Copyright License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + copyright license to reproduce, prepare Derivative Works of, + publicly display, publicly perform, sublicense, and distribute the + Work and such Derivative Works in Source or Object form. + + 3. Grant of Patent License. Subject to the terms and conditions of + this License, each Contributor hereby grants to You a perpetual, + worldwide, non-exclusive, no-charge, royalty-free, irrevocable + (except as stated in this section) patent license to make, have made, + use, offer to sell, sell, import, and otherwise transfer the Work, + where such license applies only to those patent claims licensable + by such Contributor that are necessarily infringed by their + Contribution(s) alone or by combination of their Contribution(s) + with the Work to which such Contribution(s) was submitted. If You + institute patent litigation against any entity (including a + cross-claim or counterclaim in a lawsuit) alleging that the Work + or a Contribution incorporated within the Work constitutes direct + or contributory patent infringement, then any patent licenses + granted to You under this License for that Work shall terminate + as of the date such litigation is filed. + + 4. Redistribution. You may reproduce and distribute copies of the + Work or Derivative Works thereof in any medium, with or without + modifications, and in Source or Object form, provided that You + meet the following conditions: + + (a) You must give any other recipients of the Work or + Derivative Works a copy of this License; and + + (b) You must cause any modified files to carry prominent notices + stating that You changed the files; and + + (c) You must retain, in the Source form of any Derivative Works + that You distribute, all copyright, patent, trademark, and + attribution notices from the Source form of the Work, + excluding those notices that do not pertain to any part of + the Derivative Works; and + + (d) If the Work includes a "NOTICE" text file as part of its + distribution, then any Derivative Works that You distribute must + include a readable copy of the attribution notices contained + within such NOTICE file, excluding those notices that do not + pertain to any part of the Derivative Works, in at least one + of the following places: within a NOTICE text file distributed + as part of the Derivative Works; within the Source form or + documentation, if provided along with the Derivative Works; or, + within a display generated by the Derivative Works, if and + wherever such third-party notices normally appear. The contents + of the NOTICE file are for informational purposes only and + do not modify the License. You may add Your own attribution + notices within Derivative Works that You distribute, alongside + or as an addendum to the NOTICE text from the Work, provided + that such additional attribution notices cannot be construed + as modifying the License. + + You may add Your own copyright statement to Your modifications and + may provide additional or different license terms and conditions + for use, reproduction, or distribution of Your modifications, or + for any such Derivative Works as a whole, provided Your use, + reproduction, and distribution of the Work otherwise complies with + the conditions stated in this License. + + 5. Submission of Contributions. Unless You explicitly state otherwise, + any Contribution intentionally submitted for inclusion in the Work + by You to the Licensor shall be under the terms and conditions of + this License, without any additional terms or conditions. + Notwithstanding the above, nothing herein shall supersede or modify + the terms of any separate license agreement you may have executed + with Licensor regarding such Contributions. + + 6. Trademarks. This License does not grant permission to use the trade + names, trademarks, service marks, or product names of the Licensor, + except as required for reasonable and customary use in describing the + origin of the Work and reproducing the content of the NOTICE file. + + 7. Disclaimer of Warranty. Unless required by applicable law or + agreed to in writing, Licensor provides the Work (and each + Contributor provides its Contributions) on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or + implied, including, without limitation, any warranties or conditions + of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A + PARTICULAR PURPOSE. You are solely responsible for determining the + appropriateness of using or redistributing the Work and assume any + risks associated with Your exercise of permissions under this License. + + 8. Limitation of Liability. In no event and under no legal theory, + whether in tort (including negligence), contract, or otherwise, + unless required by applicable law (such as deliberate and grossly + negligent acts) or agreed to in writing, shall any Contributor be + liable to You for damages, including any direct, indirect, special, + incidental, or consequential damages of any character arising as a + result of this License or out of the use or inability to use the + Work (including but not limited to damages for loss of goodwill, + work stoppage, computer failure or malfunction, or any and all + other commercial damages or losses), even if such Contributor + has been advised of the possibility of such damages. + + 9. Accepting Warranty or Additional Liability. While redistributing + the Work or Derivative Works thereof, You may choose to offer, + and charge a fee for, acceptance of support, warranty, indemnity, + or other liability obligations and/or rights consistent with this + License. However, in accepting such obligations, You may act only + on Your own behalf and on Your sole responsibility, not on behalf + of any other Contributor, and only if You agree to indemnify, + defend, and hold each Contributor harmless for any liability + incurred by, or claims asserted against, such Contributor by reason + of your accepting any such warranty or additional liability. + + END OF TERMS AND CONDITIONS + + APPENDIX: How to apply the Apache License to your work. + + To apply the Apache License to your work, attach the following + boilerplate notice, with the fields enclosed by brackets "[]" + replaced with your own identifying information. (Don't include + the brackets!) The text should be enclosed in the appropriate + comment syntax for the file format. We also recommend that a + file or class name and description of purpose be included on the + same "printed page" as the copyright notice for easier + identification within third-party archives. + + Copyright [yyyy] [name of copyright owner] + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. diff --git a/NOTICE b/NOTICE new file mode 100644 index 0000000..33bd16f --- /dev/null +++ b/NOTICE @@ -0,0 +1,3 @@ +Copyright (c) 2000 - 2013 Samsung Electronics Co., Ltd. All rights reserved. +Except as noted, this software is licensed under Apache License, Version 2. +Please, see the LICENSE.APLv2 file for Apache License terms and conditions. diff --git a/capi-system-runtime-info.pc.in b/capi-system-runtime-info.pc.in new file mode 100755 index 0000000..d0610b9 --- /dev/null +++ b/capi-system-runtime-info.pc.in @@ -0,0 +1,15 @@ + +# Package Information for pkg-config + +prefix=@PREFIX@ +exec_prefix=/usr +libdir=/usr/lib +includedir=/usr/include/system + +Name: @PC_NAME@ +Description: @PACKAGE_DESCRIPTION@ +Version: @VERSION@ +Requires: @PC_REQUIRED@ +Libs: -L${libdir} @PC_LDFLAGS@ +Cflags: -I${includedir} + diff --git a/debian/README b/debian/README new file mode 100644 index 0000000..e69de29 diff --git a/debian/capi-system-runtime-info-dev.install b/debian/capi-system-runtime-info-dev.install new file mode 100644 index 0000000..761a28b --- /dev/null +++ b/debian/capi-system-runtime-info-dev.install @@ -0,0 +1,4 @@ +/usr/include/* +/usr/include/*/* +/usr/lib/pkgconfig/*.pc + diff --git a/debian/capi-system-runtime-info-dev.postinst b/debian/capi-system-runtime-info-dev.postinst new file mode 100644 index 0000000..1a24852 --- /dev/null +++ b/debian/capi-system-runtime-info-dev.postinst @@ -0,0 +1 @@ +#!/bin/sh diff --git a/debian/capi-system-runtime-info.install b/debian/capi-system-runtime-info.install new file mode 100644 index 0000000..4a755a4 --- /dev/null +++ b/debian/capi-system-runtime-info.install @@ -0,0 +1 @@ +/usr/lib/lib*.so* diff --git a/debian/capi-system-runtime-info.postinst b/debian/capi-system-runtime-info.postinst new file mode 100644 index 0000000..1a24852 --- /dev/null +++ b/debian/capi-system-runtime-info.postinst @@ -0,0 +1 @@ +#!/bin/sh diff --git a/debian/changelog b/debian/changelog new file mode 100755 index 0000000..46ad61e --- /dev/null +++ b/debian/changelog @@ -0,0 +1,97 @@ +capi-system-runtime-info (0.0.2-1) unstable; urgency=low + + * Change key name + * Git: framework/api/runtime-info + * Tag: capi-system-runtime-info_0.0.2-1 + + -- Kwanwoo Nam Tue, 22 Jan 2013 15:40:00 +0900 + +capi-system-runtime-info (0.0.1-11) unstable; urgency=low + + * Fixed prevent defect case : CID 10685 + * Git: framework/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-11 + + -- Yonghyun Yang Mon, 15 Oct 2012 15:40:00 +0900 + +capi-system-runtime-info (0.0.1-10) unstable; urgency=low + + * Applying SMACK manifest + * Git: framework/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-10 + + -- Yonghyun Yang Fri, 21 Sep 2012 09:30:00 +0900 + +capi-system-runtime-info (0.0.1-9) unstable; urgency=low + + * Applying vconf-key changes + * Git: slp/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-9 + + -- Junghyuk Park Wen, 13 Jun 2012 16:32:44 +0900 + +capi-system-runtime-info (0.0.1-8) unstable; urgency=low + + * Added charger connection feature + * Git: slp/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-8 + + -- Jinkun Jang Mon, 11 Jun 2012 13:32:44 +0900 + +capi-system-runtime-info (0.0.1-7) unstable; urgency=low + + * Added haptic vibration level + * Git: slp/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-7 + + -- Junghyuk Park Thu, 10 May 2012 21:27:44 +0900 + +capi-system-runtime-info (0.0.1-6) unstable; urgency=low + + * Added usb connection feature + * Git: slp/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-6 + + -- Jinkun Jang Tue, 08 May 2012 17:04:41 +0900 + +capi-system-runtime-info (0.0.1-5) unstable; urgency=low + + * Added tv-out, audio-jack and sliding keboard features + * Git: slp/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-5 + + -- Junghyuk Park Thu, 26 Apr 2012 20:51:41 +0900 + +capi-system-runtime-info (0.0.1-4) unstable; urgency=low + + * Updated build configuration + * Git: slp/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-4 + + -- Junghyuk Park Thu, 15 Mar 2012 11:43:57 +0900 + +capi-system-runtime-info (0.0.1-3) unstable; urgency=low + + * Added version numbering + * Git: slp/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-3 + + -- Junghyuk Park Wed, 15 Feb 2012 10:51:38 +0900 + +capi-system-runtime-info (0.0.1-2) unstable; urgency=low + + * Code refactoring + * Git: slp/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-2 + + -- Junghyuk Park Sat, 10 Dec 2011 17:09:25 +0900 + +capi-system-runtime-info (0.0.1-1) unstable; urgency=low + + * Initial upload + * Git: slp-source.sec.samsung.net:slp/api/runtime-info + * Tag: capi-system-runtime-info_0.0.1-1 + + -- Junghyuk Park Tue, 06 Dec 2011 21:16:07 +0900 + + diff --git a/debian/compat b/debian/compat new file mode 100644 index 0000000..7ed6ff8 --- /dev/null +++ b/debian/compat @@ -0,0 +1 @@ +5 diff --git a/debian/control b/debian/control new file mode 100755 index 0000000..aec44e7 --- /dev/null +++ b/debian/control @@ -0,0 +1,22 @@ + +Source: capi-system-runtime-info +Section: libs +Priority: extra +Maintainer: Woongsuk Cho , junghyuk park , Kyuhun Jung +Build-Depends: debhelper (>= 5), dlog-dev, libvconf-dev, capi-base-common-dev + +Package: capi-system-runtime-info +Architecture: any +Depends: ${shlibs:Depends}, ${misc:Depends} +Description: A Runtime Information library in Tizen Native API + +Package: capi-system-runtime-info-dev +Architecture: any +Depends: ${shlibs:Depends}, ${misc:Depends}, capi-system-runtime-info (= ${Source-Version}), capi-base-common-dev +Description: A Runtime Information library in Tizen Native API (DEV) + +Package: capi-system-runtime-info-dbg +Architecture: any +Depends: ${shlibs:Depends}, ${misc:Depends}, capi-system-runtime-info (= ${Source-Version}) +Description: A Runtime Information library in Tizen Native API (DBG) + diff --git a/debian/rules b/debian/rules new file mode 100755 index 0000000..4e32fd7 --- /dev/null +++ b/debian/rules @@ -0,0 +1,68 @@ +#!/usr/bin/make -f + +CFLAGS = -Wall -g + +ifneq (,$(findstring noopt,$(DEB_BUILD_OPTIONS))) + CFLAGS += -O0 +else + CFLAGS += -O2 +endif +CMAKE_ROOT_DIR ?= $(CURDIR) +CMAKE_BUILD_DIR ?= $(CURDIR)/cmake_build_tmp + +FULLVER ?= $(shell dpkg-parsechangelog | grep Version: | cut -d ' ' -f 2 | cut -d '-' -f 1) +MAJORVER ?= $(shell echo $(FULLVER) | cut -d '.' -f 1) + +configure: configure-stamp +configure-stamp: + dh_testdir + mkdir -p $(CMAKE_BUILD_DIR) && cd $(CMAKE_BUILD_DIR) && cmake .. -DFULLVER=${FULLVER} -DMAJORVER=${MAJORVER} + touch configure-stamp + + +build: build-stamp +build-stamp: configure-stamp + dh_testdir + cd $(CMAKE_BUILD_DIR) && $(MAKE) + touch $@ + +clean: + cd $(CMAKE_ROOT_DIR) + dh_testdir + dh_testroot + rm -f build-stamp configure-stamp + rm -f `find . -name *.pc` + rm -rf $(CMAKE_BUILD_DIR) + dh_clean + +install: build + dh_testdir + dh_testroot + dh_clean -k + dh_installdirs + + cd $(CMAKE_BUILD_DIR) && $(MAKE) DESTDIR=$(CURDIR)/debian/tmp install + +binary-indep: build install + +binary-arch: build install + dh_testdir + dh_testroot + dh_installchangelogs + dh_installdocs + dh_installexamples + dh_install --sourcedir=debian/tmp + dh_installman + dh_link + dh_strip --dbg-package=capi-system-runtime-info-dbg + dh_fixperms + dh_makeshlibs + dh_installdeb + dh_shlibdeps + dh_gencontrol + dh_md5sums + dh_builddeb + +binary: binary-indep binary-arch +.PHONY: build clean binary-indep binary-arch binary install configure + diff --git a/include/runtime_info.h b/include/runtime_info.h new file mode 100755 index 0000000..01edb0b --- /dev/null +++ b/include/runtime_info.h @@ -0,0 +1,218 @@ +/* + * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the License); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#ifndef __TIZEN_SYSTEM_RUNTIME_INFO_H__ +#define __TIZEN_SYSTEM_RUNTIME_INFO_H__ + +#include + +#ifdef __cplusplus +extern "C" +{ +#endif + + /** + * @addtogroup CAPI_SYSTEM_RUNTIME_INFO_MODULE + * @{ + */ + +/** + * @brief Enumeration of error code for runtime information + */ +typedef enum { + RUNTIME_INFO_ERROR_NONE = TIZEN_ERROR_NONE, /**< Successful */ + RUNTIME_INFO_ERROR_INVALID_PARAMETER = TIZEN_ERROR_INVALID_PARAMETER, /**< Invalid parameter */ + RUNTIME_INFO_ERROR_OUT_OF_MEMORY = TIZEN_ERROR_OUT_OF_MEMORY, /**< Out of memory */ + RUNTIME_INFO_ERROR_IO_ERROR = TIZEN_ERROR_IO_ERROR, /**< An input/output error occurred when read value from system */ +} runtime_info_error_e; + +/** + * @brief Enumeration of key for runtime information + */ +typedef enum { + RUNTIME_INFO_KEY_FLIGHT_MODE_ENABLED, /** + +#ifdef __cplusplus +extern "C" +{ +#endif + +typedef enum { + RUNTIME_INFO_DATA_TYPE_STRING, + RUNTIME_INFO_DATA_TYPE_INT, + RUNTIME_INFO_DATA_TYPE_DOUBLE, + RUNTIME_INFO_DATA_TYPE_BOOL +} runtime_info_data_type_e; + +typedef union { + int i; + bool b; + double d; + char *s; +} runtime_info_value_u; + +typedef runtime_info_value_u * runtime_info_value_h; + +typedef int (*runtime_info_func_get_value) (runtime_info_value_h value); +typedef int (*runtime_info_func_set_event_cb) (void); +typedef void (*runtime_info_func_unset_event_cb) (void); + +void runtime_info_updated(runtime_info_key_e key); + +int runtime_info_vconf_get_value_int(const char *vconf_key, int *value); +int runtime_info_vconf_get_value_bool(const char *vconf_key, bool *value); +int runtime_info_vconf_get_value_double(const char *vconf_key, double *value); +int runtime_info_vconf_get_value_string(const char *vconf_key, char **value); + +int runtime_info_vconf_set_event_cb(const char *vconf_key, runtime_info_key_e runtime_info_key, int slot); +void runtime_info_vconf_unset_event_cb(const char *vconf_key, int slot); + +int runtime_info_flightmode_get_value(runtime_info_value_h); +int runtime_info_flightmode_set_event_cb(void); +void runtime_info_flightmode_unset_event_cb(void); + +int runtime_info_audiojack_get_value(runtime_info_value_h); +int runtime_info_audiojack_set_event_cb(void); +void runtime_info_audiojack_unset_event_cb(void); + +int runtime_info_wifi_status_get_value(runtime_info_value_h); +int runtime_info_wifi_status_set_event_cb(void); +void runtime_info_wifi_status_unset_event_cb(void); + +int runtime_info_bt_enabled_get_value(runtime_info_value_h); +int runtime_info_bt_enabled_set_event_cb(void); +void runtime_info_bt_enabled_unset_event_cb(void); + +int runtime_info_wifi_hotspot_get_value(runtime_info_value_h); +int runtime_info_wifi_hotspot_set_event_cb(void); +void runtime_info_wifi_hotspot_unset_event_cb (void); + +int runtime_info_bt_hotspot_get_value(runtime_info_value_h); +int runtime_info_bt_hotspot_set_event_cb(void); +void runtime_info_bt_hotspot_unset_event_cb(void); + +int runtime_info_usb_hotspot_get_value(runtime_info_value_h); +int runtime_info_usb_hotspot_set_event_cb(void); +void runtime_info_usb_hotspot_unset_event_cb(void); + +int runtime_info_location_service_get_value(runtime_info_value_h); +int runtime_info_location_service_set_event_cb(void); +void runtime_info_location_service_unset_event_cb(void); + +int runtime_info_location_agps_get_value(runtime_info_value_h); +int runtime_info_location_agps_set_event_cb(void); +void runtime_info_location_agps_unset_event_cb(void); + +int runtime_info_location_network_get_value(runtime_info_value_h); +int runtime_info_location_network_set_event_cb(void); +void runtime_info_location_network_unset_event_cb(void); + +int runtime_info_location_sensor_get_value(runtime_info_value_h); +int runtime_info_location_sensor_set_event_cb(void); +void runtime_info_location_sensor_unset_event_cb(void); + +int runtime_info_packet_data_get_value(runtime_info_value_h); +int runtime_info_packet_data_set_event_cb(void); +void runtime_info_packet_data_unset_event_cb(void); + +int runtime_info_data_roaming_get_value(runtime_info_value_h); +int runtime_info_data_roaming_set_event_cb(void); +void runtime_info_data_roaming_unset_event_cb(void); + +int runtime_info_silent_mode_get_value(runtime_info_value_h); +int runtime_info_silent_mode_set_event_cb(void); +void runtime_info_silent_mode_unset_event_cb(void); + +int runtime_info_vibration_enabled_get_value(runtime_info_value_h); +int runtime_info_vibration_enabled_set_event_cb(void); +void runtime_info_vibration_enabled_unset_event_cb(void); + +int runtime_info_rotation_lock_enabled_get_value(runtime_info_value_h); + +int runtime_info_24hour_format_get_value(runtime_info_value_h); +int runtime_info_24hour_format_set_event_cb(void); +void runtime_info_24hour_format_unset_event_cb(void); + +int runtime_info_first_day_of_week_get_value(runtime_info_value_h); +int runtime_info_first_day_of_week_set_event_cb(void); +void runtime_info_first_day_of_week_unset_event_cb(void); + +int runtime_info_language_get_value(runtime_info_value_h); +int runtime_info_language_set_event_cb(void); +void runtime_info_language_unset_event_cb(void); + +int runtime_info_region_get_value(runtime_info_value_h); +int runtime_info_region_set_event_cb(void); +void runtime_info_region_unset_event_cb(void); + +int runtime_info_gps_status_get_value(runtime_info_value_h); +int runtime_info_gps_status_set_event_cb(void); +void runtime_info_gps_status_unset_event_cb(void); + +int runtime_info_battery_charging_get_value(runtime_info_value_h); +int runtime_info_battery_charging_set_event_cb(void); +void runtime_info_battery_charging_unset_event_cb(void); + +int runtime_info_tvout_connected_get_value(runtime_info_value_h value); +int runtime_info_tvout_connected_set_event_cb(); +void runtime_info_tvout_connected_unset_event_cb(); + +int runtime_info_audio_jack_status_get_value (runtime_info_value_h value); +int runtime_info_audio_jack_status_set_event_cb (); +void runtime_info_audio_jack_status_unset_event_cb(); + +int runtime_info_sliding_keyboard_opened_get_value(runtime_info_value_h value); +int runtime_info_sliding_keyboard_opened_set_event_cb(); +void runtime_info_sliding_keyboard_opened_unset_event_cb(); + +int runtime_info_usb_connected_get_value(runtime_info_value_h value); +int runtime_info_usb_connected_set_event_cb(); +void runtime_info_usb_connected_unset_event_cb(); + +int runtime_info_charger_connected_get_value(runtime_info_value_h value); +int runtime_info_charger_connected_set_event_cb(); +void runtime_info_charger_connected_unset_event_cb(); + +int runtime_info_vibration_level_haptic_feedback_get_value(runtime_info_value_h value); +int runtime_info_vibration_level_haptic_feedback_set_event_cb(); +void runtime_info_vibration_level_haptic_feedback_unset_event_cb(); + +int runtime_info_auto_rotation_enabled_get_value(runtime_info_value_h); +int runtime_info_auto_rotation_enabled_set_event_cb(void); +void runtime_info_auto_rotation_enabled_unset_event_cb(void); + +#ifdef __cplusplus +} +#endif + +#endif /* __TIZEN_SYSTEM_RUNTIME_INFO_PRIVATE_H__ */ diff --git a/packaging/capi-system-runtime-info.spec b/packaging/capi-system-runtime-info.spec new file mode 100755 index 0000000..8b68581 --- /dev/null +++ b/packaging/capi-system-runtime-info.spec @@ -0,0 +1,62 @@ +Name: capi-system-runtime-info +Summary: A Runtime Information library in Tizen Native API +Version: 0.0.2 +Release: 0 +Group: System/Libraries +License: Apache License, Version 2.0 +Source0: %{name}-%{version}.tar.gz +BuildRequires: cmake +BuildRequires: pkgconfig(dlog) +BuildRequires: pkgconfig(vconf) +BuildRequires: pkgconfig(capi-base-common) +Requires(post): /sbin/ldconfig +Requires(postun): /sbin/ldconfig + +%description + + +%package devel +Summary: A Runtime Information library in Tizen Native API (Development) +Group: TO_BE/FILLED_IN +Requires: %{name} = %{version}-%{release} +Requires: pkgconfig(capi-base-common) + +%description devel + + + +%prep +%setup -q + + +%build +MAJORVER=`echo %{version} | awk 'BEGIN {FS="."}{print $1}'` +cmake . -DCMAKE_INSTALL_PREFIX=/usr -DFULLVER=%{version} -DMAJORVER=${MAJORVER} + + +make %{?jobs:-j%jobs} + +%install +rm -rf %{buildroot} + +mkdir -p %{buildroot}/usr/share/license +cp -f LICENSE.APLv2 %{buildroot}/usr/share/license/%{name} + +%make_install + +%post -p /sbin/ldconfig + +%postun -p /sbin/ldconfig + + +%files +%{_libdir}/lib*.so.* +/usr/share/license/%{name} +%manifest runtime-info.manifest + +%files devel +%{_includedir}/system/*.h +%{_libdir}/pkgconfig/*.pc +%{_libdir}/lib*.so + + diff --git a/runtime-info.manifest b/runtime-info.manifest new file mode 100644 index 0000000..97e8c31 --- /dev/null +++ b/runtime-info.manifest @@ -0,0 +1,5 @@ + + + + + diff --git a/src/runtime_info.c b/src/runtime_info.c new file mode 100644 index 0000000..ff9d269 --- /dev/null +++ b/src/runtime_info.c @@ -0,0 +1,569 @@ +/* + * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the License); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include +#include +#include + +#include +#include + +#include +#include + +#ifdef LOG_TAG +#undef LOG_TAG +#endif + +#define LOG_TAG "CAPI_SYSTEM_RUNTIME_INFO" + +#define RUNTIME_INFO_MAX -1 + +typedef struct { + runtime_info_changed_cb changed_cb; + void *user_data; + runtime_info_value_h most_recent_value; +} runtime_info_event_subscription_s; + +typedef runtime_info_event_subscription_s * runtime_info_event_subscription_h; + +typedef struct { + runtime_info_key_e key; + runtime_info_data_type_e data_type; + runtime_info_func_get_value get_value; + runtime_info_func_set_event_cb set_event_cb; + runtime_info_func_unset_event_cb unset_event_cb; + runtime_info_event_subscription_h event_subscription; +} runtime_info_item_s; + +typedef runtime_info_item_s * runtime_info_item_h; + +runtime_info_item_s runtime_info_item_table[] = { + +{ + RUNTIME_INFO_KEY_FLIGHT_MODE_ENABLED, /**data_type != data_type) { + LOGE("INVALID_PARAMETER(0x%08x) : invalid data type", RUNTIME_INFO_ERROR_INVALID_PARAMETER); + return RUNTIME_INFO_ERROR_INVALID_PARAMETER; + } + + get_value = runtime_info_item->get_value; + + if (get_value == NULL) { + LOGE("IO_ERROR(0x%08x) : failed to call getter for the runtime information", RUNTIME_INFO_ERROR_IO_ERROR); + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + if (get_value(value) != RUNTIME_INFO_ERROR_NONE) { + LOGE("IO_ERROR(0x%08x) : failed to get the runtime informaion / key(%d)", RUNTIME_INFO_ERROR_IO_ERROR, key); + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_get_value_int(runtime_info_key_e key, int *value) +{ + int retcode; + runtime_info_value_u runtime_info_value; + + if (value == NULL) { + LOGE("INVALID_PARAMETER(0x%08x) : invalid output param", RUNTIME_INFO_ERROR_INVALID_PARAMETER); + return RUNTIME_INFO_ERROR_INVALID_PARAMETER; + } + + retcode = runtime_info_get_value(key, RUNTIME_INFO_DATA_TYPE_INT, &runtime_info_value); + + if (retcode == RUNTIME_INFO_ERROR_NONE) + *value = runtime_info_value.i; + + return retcode; +} + +int runtime_info_get_value_bool(runtime_info_key_e key, bool *value) +{ + int retcode; + runtime_info_value_u runtime_info_value; + + if (value == NULL) { + LOGE("INVALID_PARAMETER(0x%08x) : invalid output param", RUNTIME_INFO_ERROR_INVALID_PARAMETER); + return RUNTIME_INFO_ERROR_INVALID_PARAMETER; + } + + retcode = runtime_info_get_value(key, RUNTIME_INFO_DATA_TYPE_BOOL, &runtime_info_value); + + if (retcode == RUNTIME_INFO_ERROR_NONE) + *value = runtime_info_value.b; + + return retcode; +} + +int runtime_info_get_value_double(runtime_info_key_e key, double *value) +{ + int retcode; + runtime_info_value_u runtime_info_value; + + if (value == NULL) { + LOGE("INVALID_PARAMETER(0x%08x) : invalid output param", RUNTIME_INFO_ERROR_INVALID_PARAMETER); + return RUNTIME_INFO_ERROR_INVALID_PARAMETER; + } + + retcode = runtime_info_get_value(key, RUNTIME_INFO_DATA_TYPE_DOUBLE, &runtime_info_value); + + if (retcode == RUNTIME_INFO_ERROR_NONE) + *value = runtime_info_value.d; + + return retcode; +} + +int runtime_info_get_value_string(runtime_info_key_e key, char **value) +{ + int retcode; + runtime_info_value_u runtime_info_value; + + if (value == NULL) { + LOGE("INVALID_PARAMETER(0x%08x) : invalid output param", RUNTIME_INFO_ERROR_INVALID_PARAMETER); + return RUNTIME_INFO_ERROR_INVALID_PARAMETER; + } + + retcode = runtime_info_get_value(key, RUNTIME_INFO_DATA_TYPE_STRING, &runtime_info_value); + + if (retcode == RUNTIME_INFO_ERROR_NONE) + *value = runtime_info_value.s; + + return retcode; +} + +int runtime_info_set_changed_cb(runtime_info_key_e key, runtime_info_changed_cb callback, void *user_data) +{ + runtime_info_item_h runtime_info_item; + runtime_info_func_set_event_cb set_event_cb; + bool subscribe_event = false; + + if (callback == NULL) { + LOGE("INVALID_PARAMETER(0x%08x)", RUNTIME_INFO_ERROR_INVALID_PARAMETER); + return RUNTIME_INFO_ERROR_INVALID_PARAMETER; + } + + if (runtime_info_get_item(key, &runtime_info_item)) { + LOGE("INVALID_PARAMETER(0x%08x) : invalid key", RUNTIME_INFO_ERROR_INVALID_PARAMETER); + return RUNTIME_INFO_ERROR_INVALID_PARAMETER; + } + + set_event_cb = runtime_info_item->set_event_cb; + + if (set_event_cb == NULL) { + LOGE("IO_ERROR(0x%08x) : failed to set callback for the runtime information", RUNTIME_INFO_ERROR_IO_ERROR); + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + if (runtime_info_item->event_subscription == NULL) { + subscribe_event = true; + + runtime_info_event_subscription_h event_subscription; + event_subscription = malloc(sizeof(runtime_info_event_subscription_s)); + + if (event_subscription == NULL) { + LOGE("OUT_OF_MEMORY(0x%08x)", RUNTIME_INFO_ERROR_OUT_OF_MEMORY); + return RUNTIME_INFO_ERROR_OUT_OF_MEMORY; + } + + runtime_info_item->event_subscription = event_subscription; + runtime_info_item->event_subscription->most_recent_value = NULL; + } + + runtime_info_item->event_subscription->changed_cb = callback; + runtime_info_item->event_subscription->user_data = user_data; + + if (runtime_info_item->event_subscription->most_recent_value != NULL) + free(runtime_info_item->event_subscription->most_recent_value); + + runtime_info_item->event_subscription->most_recent_value = NULL; + + if (subscribe_event == true) + return set_event_cb(); + else + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_unset_changed_cb(runtime_info_key_e key) +{ + runtime_info_item_h runtime_info_item; + runtime_info_func_unset_event_cb unset_event_cb; + + if (runtime_info_get_item(key, &runtime_info_item)) { + LOGE("INVALID_PARAMETER(0x%08x) : invalid key", RUNTIME_INFO_ERROR_INVALID_PARAMETER); + return RUNTIME_INFO_ERROR_INVALID_PARAMETER; + } + + if (runtime_info_item->event_subscription != NULL) { + if (runtime_info_item->event_subscription->most_recent_value != NULL) { + free(runtime_info_item->event_subscription->most_recent_value); + runtime_info_item->event_subscription->most_recent_value = NULL; + } + + free(runtime_info_item->event_subscription); + runtime_info_item->event_subscription = NULL; + } + + unset_event_cb = runtime_info_item->unset_event_cb; + + if (unset_event_cb == NULL) { + LOGE("IO_ERROR(0x%08x) : failed to unset callback for the runtime information", RUNTIME_INFO_ERROR_IO_ERROR); + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + unset_event_cb(); + + return RUNTIME_INFO_ERROR_NONE; +} + +void runtime_info_updated(runtime_info_key_e key) +{ + runtime_info_item_h runtime_info_item; + runtime_info_value_u current_value; + bool dispatch_event = true; + int retcode; + + if (runtime_info_get_item(key, &runtime_info_item)) { + LOGE("INVALID_PARAMETER(0x%08x) : invalid key", RUNTIME_INFO_ERROR_INVALID_PARAMETER); + return; + } + + if (runtime_info_item->event_subscription == NULL) { + LOGE("IO_ERROR(0x%08x) : invalid event subscription", RUNTIME_INFO_ERROR_IO_ERROR); + return; + } + + memset(¤t_value, 0, sizeof(runtime_info_value_u)); + + retcode = runtime_info_get_value(key, runtime_info_item->data_type, ¤t_value); + + if (retcode != RUNTIME_INFO_ERROR_NONE) { + LOGE("IO_ERROR(0x%08x) : failed to get the runtime information", RUNTIME_INFO_ERROR_IO_ERROR); + return; + } + + if (runtime_info_item->event_subscription->most_recent_value != NULL) { + if (!memcmp(runtime_info_item->event_subscription->most_recent_value, ¤t_value, sizeof(runtime_info_value_u))) + dispatch_event = false; + } else { + runtime_info_item->event_subscription->most_recent_value = calloc(1, sizeof(runtime_info_value_u)); + + if (runtime_info_item->event_subscription->most_recent_value == NULL) { + LOGE("OUT_OF_MEMORY(0x%08x)", RUNTIME_INFO_ERROR_OUT_OF_MEMORY); + return; + } + } + + if (dispatch_event == true && runtime_info_item->event_subscription->changed_cb != NULL) { + memcpy(runtime_info_item->event_subscription->most_recent_value, ¤t_value, sizeof(runtime_info_value_u)); + runtime_info_item->event_subscription->changed_cb(key, runtime_info_item->event_subscription->user_data); + } +} diff --git a/src/runtime_info_connectivity.c b/src/runtime_info_connectivity.c new file mode 100644 index 0000000..75b964b --- /dev/null +++ b/src/runtime_info_connectivity.c @@ -0,0 +1,262 @@ +/* + * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the License); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include +#include +#include + +#include +#include + +#include +#include + +#ifdef LOG_TAG +#undef LOG_TAG +#endif + +#define LOG_TAG "CAPI_SYSTEM_RUNTIME_INFO" + +static const char *VCONF_WIFI_STATUS = VCONFKEY_WIFI_STATE; +static const char *VCONF_BT_ENABLED = VCONFKEY_BT_STATUS; +static const char *VCONF_WIFI_HOTSPOT_ENABLED = VCONFKEY_MOBILE_HOTSPOT_MODE; +static const char *VCONF_BT_HOTSPOT_ENABLED = VCONFKEY_MOBILE_HOTSPOT_MODE; +static const char *VCONF_USB_HOTSPOT_ENABLED = VCONFKEY_MOBILE_HOTSPOT_MODE; +static const char *VCONF_PACKET_DATA_ENABLED = VCONFKEY_3G_ENABLE; +static const char *VCONF_DATA_ROAMING_ENABLED = "db/setting/data_roaming"; +static const char *VCONF_GPS_STATUS = VCONFKEY_LOCATION_GPS_STATE; + +int runtime_info_wifi_status_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_WIFI_STATUS, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_WIFI_OFF: + value->i = RUNTIME_INFO_WIFI_STATUS_DISABLED; + break; + + case VCONFKEY_WIFI_UNCONNECTED: + value->i = RUNTIME_INFO_WIFI_STATUS_UNCONNECTED; + break; + + case VCONFKEY_WIFI_CONNECTED: + case VCONFKEY_WIFI_TRANSFER: + value->i = RUNTIME_INFO_WIFI_STATUS_CONNECTED; + break; + + default: + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_wifi_status_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_WIFI_STATUS, RUNTIME_INFO_KEY_WIFI_STATUS, 0); +} + +void runtime_info_wifi_status_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_WIFI_STATUS, 0); +} + +int runtime_info_bt_enabled_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_BT_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_BT_STATUS_OFF: + value->b = false; + break; + + case VCONFKEY_BT_STATUS_ON: + case VCONFKEY_BT_STATUS_BT_VISIBLE: + case VCONFKEY_BT_STATUS_TRANSFER: + value->b = true; + break; + + default: + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_bt_enabled_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_BT_ENABLED, RUNTIME_INFO_KEY_BLUETOOTH_ENABLED, 0); +} + +void runtime_info_bt_enabled_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_BT_ENABLED, 0); +} + + +int runtime_info_wifi_hotspot_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_WIFI_HOTSPOT_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = (vconf_value&VCONFKEY_MOBILE_HOTSPOT_MODE_WIFI) ? true : false; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_wifi_hotspot_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_WIFI_HOTSPOT_ENABLED, RUNTIME_INFO_KEY_WIFI_HOTSPOT_ENABLED, 0); +} + +void runtime_info_wifi_hotspot_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_WIFI_HOTSPOT_ENABLED, 0); +} + +int runtime_info_bt_hotspot_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_BT_HOTSPOT_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = (vconf_value&VCONFKEY_MOBILE_HOTSPOT_MODE_BT) ? true : false; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_bt_hotspot_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_BT_HOTSPOT_ENABLED, RUNTIME_INFO_KEY_BLUETOOTH_TETHERING_ENABLED, 0); +} + +void runtime_info_bt_hotspot_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_BT_HOTSPOT_ENABLED, 0); +} + +int runtime_info_usb_hotspot_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_USB_HOTSPOT_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = (vconf_value&VCONFKEY_MOBILE_HOTSPOT_MODE_USB) ? true : false; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_usb_hotspot_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_USB_HOTSPOT_ENABLED, RUNTIME_INFO_KEY_USB_TETHERING_ENABLED, 0); +} + +void runtime_info_usb_hotspot_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_USB_HOTSPOT_ENABLED, 0); +} + +int runtime_info_packet_data_get_value(runtime_info_value_h value) +{ + bool vconf_value; + + if (runtime_info_vconf_get_value_bool(VCONF_PACKET_DATA_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_packet_data_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_PACKET_DATA_ENABLED, RUNTIME_INFO_KEY_PACKET_DATA_ENABLED, 0); +} + +void runtime_info_packet_data_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_PACKET_DATA_ENABLED, 0); +} + +int runtime_info_data_roaming_get_value(runtime_info_value_h value) +{ + bool vconf_value; + + if (runtime_info_vconf_get_value_bool(VCONF_DATA_ROAMING_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_data_roaming_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_DATA_ROAMING_ENABLED, RUNTIME_INFO_KEY_DATA_ROAMING_ENABLED, 0); +} + +void runtime_info_data_roaming_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_DATA_ROAMING_ENABLED, 0); +} + +int runtime_info_gps_status_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_GPS_STATUS, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_LOCATION_GPS_OFF: + value->i = RUNTIME_INFO_GPS_STATUS_DISABLED; + break; + + case VCONFKEY_LOCATION_GPS_SEARCHING: + value->i = RUNTIME_INFO_GPS_STATUS_SEARCHING; + break; + + case VCONFKEY_LOCATION_GPS_CONNECTED: + value->i = RUNTIME_INFO_GPS_STATUS_CONNECTED; + break; + + default: + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_gps_status_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_GPS_STATUS, RUNTIME_INFO_KEY_GPS_STATUS, 0); +} + +void runtime_info_gps_status_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_GPS_STATUS, 0); +} + diff --git a/src/runtime_info_locale.c b/src/runtime_info_locale.c new file mode 100644 index 0000000..ea133b3 --- /dev/null +++ b/src/runtime_info_locale.c @@ -0,0 +1,173 @@ +/* + * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the License); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include +#include +#include + +#include +#include + +#include +#include + +#ifdef LOG_TAG +#undef LOG_TAG +#endif + +#define LOG_TAG "CAPI_SYSTEM_RUNTIME_INFO" + +static const char *VCONF_24HOUR_FORMAT = "db/menu_widget/regionformat_time1224"; +static const char *VCONF_FIRST_DAY_OF_WEEK = "db/setting/weekofday_format"; +static const char *VCONF_LANGUAGE = VCONFKEY_LANGSET; +static const char *VCONF_REGION = VCONFKEY_REGIONFORMAT; + +int runtime_info_24hour_format_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_24HOUR_FORMAT, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_TIME_FORMAT_12: + value->b = false; + break; + + case VCONFKEY_TIME_FORMAT_24: + value->b = true; + break; + + default: + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_24hour_format_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_24HOUR_FORMAT, RUNTIME_INFO_KEY_24HOUR_CLOCK_FORMAT_ENABLED, 0); +} + +void runtime_info_24hour_format_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_24HOUR_FORMAT, 0); +} + +int runtime_info_first_day_of_week_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_FIRST_DAY_OF_WEEK, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case SETTING_WEEKOFDAY_FORMAT_SUNDAY: + value->i = RUNTIME_INFO_FIRST_DAY_OF_WEEK_SUNDAY; + break; + + case SETTING_WEEKOFDAY_FORMAT_MONDAY: + value->i = RUNTIME_INFO_FIRST_DAY_OF_WEEK_MONDAY; + break; + + case SETTING_WEEKOFDAY_FORMAT_TUESDAY: + value->i = RUNTIME_INFO_FIRST_DAY_OF_WEEK_TUESDAY; + break; + + case SETTING_WEEKOFDAY_FORMAT_WEDNESDAY: + value->i = RUNTIME_INFO_FIRST_DAY_OF_WEEK_WEDNESDAY; + break; + + case SETTING_WEEKOFDAY_FORMAT_THURSDAY: + value->i = RUNTIME_INFO_FIRST_DAY_OF_WEEK_THURSDAY; + break; + + case SETTING_WEEKOFDAY_FORMAT_FRIDAY: + value->i = RUNTIME_INFO_FIRST_DAY_OF_WEEK_FRIDAY; + break; + + case SETTING_WEEKOFDAY_FORMAT_SATURDAY: + value->i = RUNTIME_INFO_FIRST_DAY_OF_WEEK_SATURDAY; + break; + + default: + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_first_day_of_week_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_FIRST_DAY_OF_WEEK, RUNTIME_INFO_KEY_FIRST_DAY_OF_WEEK, 0); +} + +void runtime_info_first_day_of_week_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_FIRST_DAY_OF_WEEK, 0); +} + +int runtime_info_language_get_value(runtime_info_value_h value) +{ + char *vconf_value; + char *token = NULL; + + if (runtime_info_vconf_get_value_string(VCONF_LANGUAGE, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + token = strchr(vconf_value, '.'); + + if(token) + *token = '\0'; + + value->s = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_language_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_LANGUAGE, RUNTIME_INFO_KEY_LANGUAGE, 0); +} + +void runtime_info_language_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_LANGUAGE, 0); +} + +int runtime_info_region_get_value(runtime_info_value_h value) +{ + char *vconf_value; + + if (runtime_info_vconf_get_value_string(VCONF_REGION, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->s = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_region_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_REGION, RUNTIME_INFO_KEY_REGION, 0); +} + +void runtime_info_region_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_REGION, 0); +} + diff --git a/src/runtime_info_location.c b/src/runtime_info_location.c new file mode 100644 index 0000000..c041063 --- /dev/null +++ b/src/runtime_info_location.c @@ -0,0 +1,125 @@ +/* + * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the License); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include +#include +#include + +#include +#include + +#include +#include + +#ifdef LOG_TAG +#undef LOG_TAG +#endif + +#define LOG_TAG "CAPI_SYSTEM_RUNTIME_INFO" + +static const char *VCONF_LOCATION_SERVICE_ENABLED = VCONFKEY_LOCATION_ENABLED; +static const char *VCONF_LOCATION_AGPS_ENABLED = "db/location/setting/AgpsEnabled"; +static const char *VCONF_LOCATION_NETWORK_ENABLED = VCONFKEY_LOCATION_NETWORK_ENABLED; +static const char *VCONF_LOCATION_SENSOR_ENABLED = "db/location/setting/SensorEnabled"; + +int runtime_info_location_service_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_LOCATION_SERVICE_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_location_service_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_LOCATION_SERVICE_ENABLED, RUNTIME_INFO_KEY_LOCATION_SERVICE_ENABLED, 0); +} + +void runtime_info_location_service_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_LOCATION_SERVICE_ENABLED, 0); +} + +int runtime_info_location_agps_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_LOCATION_AGPS_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_location_agps_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_LOCATION_AGPS_ENABLED, RUNTIME_INFO_KEY_LOCATION_ADVANCED_GPS_ENABLED, 0); +} + +void runtime_info_location_agps_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_LOCATION_AGPS_ENABLED, 0); +} + +int runtime_info_location_network_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_LOCATION_NETWORK_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_location_network_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_LOCATION_NETWORK_ENABLED, RUNTIME_INFO_KEY_LOCATION_NETWORK_POSITION_ENABLED, 0); +} + +void runtime_info_location_network_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_LOCATION_NETWORK_ENABLED, 0); +} + +int runtime_info_location_sensor_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_LOCATION_SENSOR_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_location_sensor_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_LOCATION_SENSOR_ENABLED, RUNTIME_INFO_KEY_LOCATION_SENSOR_AIDING_ENABLED, 0); +} + +void runtime_info_location_sensor_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_LOCATION_SENSOR_ENABLED, 0); +} + diff --git a/src/runtime_info_system.c b/src/runtime_info_system.c new file mode 100644 index 0000000..97f55b5 --- /dev/null +++ b/src/runtime_info_system.c @@ -0,0 +1,392 @@ +/* + * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the License); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include +#include +#include + +#include +#include + +#include +#include + +#ifdef LOG_TAG +#undef LOG_TAG +#endif + +#define LOG_TAG "CAPI_SYSTEM_RUNTIME_INFO" + +static const char *VCONF_FLIGHT_MODE = VCONFKEY_TELEPHONY_FLIGHT_MODE; +static const char *VCONF_AUDIO_JACK = VCONFKEY_SYSMAN_EARJACK; +static const char *VCONF_SILENT_MODE = "db/setting/sound/sound_on"; +static const char *VCONF_VIBRATION_ENABLED = "db/setting/sound/vibration_on"; +static const char *VCONF_ROTATION_LOCK_ENABLED = VCONFKEY_SETAPPL_AUTO_ROTATE_SCREEN_BOOL; +static const char *VCONF_BATTERY_CHARGING = VCONFKEY_SYSMAN_BATTERY_CHARGE_NOW; +static const char *VCONF_TVOUT_CONNECTED = VCONFKEY_SYSMAN_EARJACK; +static const char *VCONF_AUDIO_JACK_STATUS = VCONFKEY_SYSMAN_EARJACK; +static const char *VCONF_SLIDING_KEYBOARD_STATUS = VCONFKEY_SYSMAN_SLIDING_KEYBOARD; +static const char *VCONF_USB_CONNECTED = VCONFKEY_SYSMAN_USB_STATUS; +static const char *VCONF_CHARGER_CONNECTED = VCONFKEY_SYSMAN_CHARGER_STATUS; + + +int runtime_info_flightmode_get_value(runtime_info_value_h value) +{ + bool vconf_value; + + if (runtime_info_vconf_get_value_bool(VCONF_FLIGHT_MODE, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_flightmode_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_FLIGHT_MODE, RUNTIME_INFO_KEY_FLIGHT_MODE_ENABLED, 0); +} + +void runtime_info_flightmode_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_FLIGHT_MODE, 0); +} + +int runtime_info_audiojack_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_AUDIO_JACK, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_SYSMAN_EARJACK_3WIRE: + case VCONFKEY_SYSMAN_EARJACK_4WIRE: + value->b = true; + break; + + default: + value->b = false; + break; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_audiojack_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_AUDIO_JACK, RUNTIME_INFO_KEY_AUDIO_JACK_CONNECTED, 0); +} + +void runtime_info_audiojack_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_AUDIO_JACK, 0); +} + +int runtime_info_silent_mode_get_value(runtime_info_value_h value) +{ + bool vconf_value; + + if (runtime_info_vconf_get_value_bool(VCONF_SILENT_MODE, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_silent_mode_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_SILENT_MODE, RUNTIME_INFO_KEY_SILENT_MODE_ENABLED, 0); +} + +void runtime_info_silent_mode_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_SILENT_MODE, 0); +} + +int runtime_info_vibration_enabled_get_value(runtime_info_value_h value) +{ + bool vconf_value; + + if (runtime_info_vconf_get_value_bool(VCONF_VIBRATION_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_vibration_enabled_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_VIBRATION_ENABLED, RUNTIME_INFO_KEY_VIBRATION_ENABLED, 0); +} + +void runtime_info_vibration_enabled_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_VIBRATION_ENABLED, 0); +} + +int runtime_info_rotation_lock_enabled_get_value(runtime_info_value_h value) +{ + value->b = false; + + return RUNTIME_INFO_ERROR_INVALID_PARAMETER; +} + +int runtime_info_auto_rotation_enabled_get_value(runtime_info_value_h value) +{ + bool vconf_value; + + if (runtime_info_vconf_get_value_bool(VCONF_ROTATION_LOCK_ENABLED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_auto_rotation_enabled_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_ROTATION_LOCK_ENABLED, RUNTIME_INFO_KEY_AUTO_ROTATION_ENABLED, 0); +} + +void runtime_info_auto_rotation_enabled_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_ROTATION_LOCK_ENABLED, 0); +} + +int runtime_info_battery_charging_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_BATTERY_CHARGING, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->b = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_battery_charging_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_BATTERY_CHARGING, RUNTIME_INFO_KEY_BATTERY_IS_CHARGING, 0); +} + +void runtime_info_battery_charging_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_BATTERY_CHARGING, 0); +} + + +int runtime_info_tvout_connected_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_TVOUT_CONNECTED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_SYSMAN_EARJACK_TVOUT: + value->b = true; + break; + + default: + value->b = false; + break; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_tvout_connected_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_TVOUT_CONNECTED, RUNTIME_INFO_KEY_TV_OUT_CONNECTED, 1); +} + +void runtime_info_tvout_connected_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_TVOUT_CONNECTED, 1); +} + + +int runtime_info_audio_jack_status_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_AUDIO_JACK_STATUS, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_SYSMAN_EARJACK_3WIRE: + value->i = RUNTIME_INFO_AUDIO_JACK_STATUS_CONNECTED_3WIRE; + break; + + case VCONFKEY_SYSMAN_EARJACK_4WIRE: + value->i = RUNTIME_INFO_AUDIO_JACK_STATUS_CONNECTED_4WIRE; + break; + + default: + value->i = RUNTIME_INFO_AUDIO_JACK_STATUS_UNCONNECTED; + break; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_audio_jack_status_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_AUDIO_JACK_STATUS, RUNTIME_INFO_KEY_AUDIO_JACK_STATUS, 2); +} + +void runtime_info_audio_jack_status_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_AUDIO_JACK_STATUS, 2); +} + + +int runtime_info_sliding_keyboard_opened_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_SLIDING_KEYBOARD_STATUS, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_SYSMAN_SLIDING_KEYBOARD_NOT_AVAILABE: + value->b = false; + break; + + case VCONFKEY_SYSMAN_SLIDING_KEYBOAED_AVAILABLE: + value->b = true; + break; + + case VCONFKEY_SYSMAN_SLIDING_KEYBOARD_NOT_SUPPORTED: + value->b = false; + break; + + default: + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_sliding_keyboard_opened_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_SLIDING_KEYBOARD_STATUS, RUNTIME_INFO_KEY_SLIDING_KEYBOARD_OPENED, 0); +} + +void runtime_info_sliding_keyboard_opened_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_SLIDING_KEYBOARD_STATUS, 0); +} + + +int runtime_info_usb_connected_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_USB_CONNECTED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_SYSMAN_USB_DISCONNECTED: + value->b = false; + break; + + case VCONFKEY_SYSMAN_USB_CONNECTED: + value->b = false; + break; + + case VCONFKEY_SYSMAN_USB_AVAILABLE: + value->b = true; + break; + + default: + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_usb_connected_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_USB_CONNECTED, RUNTIME_INFO_KEY_USB_CONNECTED, 0); +} + +void runtime_info_usb_connected_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_USB_CONNECTED, 0); +} + +int runtime_info_charger_connected_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONF_CHARGER_CONNECTED, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + switch (vconf_value) { + case VCONFKEY_SYSMAN_CHARGER_DISCONNECTED: + value->b = false; + break; + + case VCONFKEY_SYSMAN_CHARGER_CONNECTED: + value->b = true; + break; + + default: + return RUNTIME_INFO_ERROR_IO_ERROR; + } + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_charger_connected_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONF_CHARGER_CONNECTED, RUNTIME_INFO_KEY_CHARGER_CONNECTED, 0); +} + +void runtime_info_charger_connected_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONF_CHARGER_CONNECTED, 0); +} + + +int runtime_info_vibration_level_haptic_feedback_get_value(runtime_info_value_h value) +{ + int vconf_value; + + if (runtime_info_vconf_get_value_int(VCONFKEY_SETAPPL_TOUCH_FEEDBACK_VIBRATION_LEVEL_INT, &vconf_value)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + value->i = vconf_value; + + return RUNTIME_INFO_ERROR_NONE; +} + +int runtime_info_vibration_level_haptic_feedback_set_event_cb() +{ + return runtime_info_vconf_set_event_cb(VCONFKEY_SETAPPL_TOUCH_FEEDBACK_VIBRATION_LEVEL_INT, RUNTIME_INFO_KEY_VIBRATION_LEVEL_HAPTIC_FEEDBACK, 0); +} + +void runtime_info_vibration_level_haptic_feedback_unset_event_cb() +{ + runtime_info_vconf_unset_event_cb(VCONFKEY_SETAPPL_TOUCH_FEEDBACK_VIBRATION_LEVEL_INT, 0); +} + + diff --git a/src/runtime_info_vconf.c b/src/runtime_info_vconf.c new file mode 100644 index 0000000..f2db3ef --- /dev/null +++ b/src/runtime_info_vconf.c @@ -0,0 +1,140 @@ +/* + * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved + * + * Licensed under the Apache License, Version 2.0 (the License); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an AS IS BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +#include +#include +#include + +#include +#include + +#include +#include + +#ifdef LOG_TAG +#undef LOG_TAG +#endif + +#define LOG_TAG "CAPI_SYSTEM_RUNTIME_INFO" + +int runtime_info_vconf_get_value_int(const char *vconf_key, int *value) +{ + return vconf_get_int(vconf_key, value); +} + +int runtime_info_vconf_get_value_bool(const char *vconf_key, bool *value) +{ + return vconf_get_bool(vconf_key, (int *)value); +} + +int runtime_info_vconf_get_value_double(const char *vconf_key, double *value) +{ + return vconf_get_dbl(vconf_key, value); +} + +int runtime_info_vconf_get_value_string(const char *vconf_key, char **value) +{ + char *str_value = NULL; + + str_value = vconf_get_str(vconf_key); + + if (str_value != NULL) { + *value = str_value; + return 0; + } else { + return -1; + } +} + +typedef void (*runtime_info_vconf_event_cb)(keynode_t *node, void *event_data); + +static void runtime_info_vconf_event_cb0(keynode_t *node, void *event_data) +{ + if (node != NULL) + runtime_info_updated((runtime_info_key_e)event_data); +} + +static void runtime_info_vconf_event_cb1(keynode_t *node, void *event_data) +{ + if (node != NULL) + runtime_info_updated((runtime_info_key_e)event_data); +} + +static void runtime_info_vconf_event_cb2(keynode_t *node, void *event_data) +{ + if (node != NULL) + runtime_info_updated((runtime_info_key_e)event_data); +} + +static void runtime_info_vconf_event_cb3(keynode_t *node, void *event_data) +{ + if (node != NULL) + runtime_info_updated((runtime_info_key_e)event_data); +} + +static void runtime_info_vconf_event_cb4(keynode_t *node, void *event_data) +{ + if (node != NULL) + runtime_info_updated((runtime_info_key_e)event_data); +} + +static runtime_info_vconf_event_cb runtime_info_vconf_get_event_cb_slot(int slot) +{ + switch (slot) { + case 0: + return runtime_info_vconf_event_cb0; + + case 1: + return runtime_info_vconf_event_cb1; + + case 2: + return runtime_info_vconf_event_cb2; + + case 3: + return runtime_info_vconf_event_cb3; + + case 4: + return runtime_info_vconf_event_cb4; + + default: + return NULL; + } +} + +int runtime_info_vconf_set_event_cb(const char *vconf_key, runtime_info_key_e runtime_info_key, int slot) +{ + runtime_info_vconf_event_cb vconf_event_cb; + + vconf_event_cb = runtime_info_vconf_get_event_cb_slot(slot); + + if (vconf_event_cb == NULL) + return RUNTIME_INFO_ERROR_IO_ERROR; + + if (vconf_notify_key_changed(vconf_key, vconf_event_cb, (void *)runtime_info_key)) + return RUNTIME_INFO_ERROR_IO_ERROR; + + return RUNTIME_INFO_ERROR_NONE; +} + +void runtime_info_vconf_unset_event_cb(const char *vconf_key, int slot) +{ + runtime_info_vconf_event_cb vconf_event_cb; + + vconf_event_cb = runtime_info_vconf_get_event_cb_slot(slot); + + if (vconf_event_cb != NULL) + vconf_ignore_key_changed(vconf_key, vconf_event_cb); +}