Adding AK8975 geo-sensor info in sensors.xml.in required by geo-plugin
[platform/core/system/sensord.git] / src / linear_accel / linear_accel_sensor.h
1 /*
2  * sensord
3  *
4  * Copyright (c) 2014 Samsung Electronics Co., Ltd.
5  *
6  * Licensed under the Apache License, Version 2.0 (the "License");
7  * you may not use this file except in compliance with the License.
8  * You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software
13  * distributed under the License is distributed on an "AS IS" BASIS,
14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15  * See the License for the specific language governing permissions and
16  * limitations under the License.
17  *
18  */
19
20 #ifndef _LINEAR_ACCEL_SENSOR_H_
21 #define _LINEAR_ACCEL_SENSOR_H_
22
23 #include <sensor.h>
24 #include <vconf.h>
25 #include <string>
26
27 using std::string;
28
29 class linear_accel_sensor : public virtual_sensor
30 {
31 public:
32         linear_accel_sensor();
33         virtual ~linear_accel_sensor();
34
35         bool init();
36         sensor_type_t get_type(void);
37
38         static bool working(void *inst);
39
40         bool on_start(void);
41         bool on_stop(void);
42
43         void synthesize(const sensor_event_t &event, vector<sensor_event_t> &outs);
44
45         virtual bool add_interval(int client_id, unsigned int interval, bool is_processor = false);
46         virtual bool delete_interval(int client_id, bool is_processor = false);
47
48         int get_sensor_data(const unsigned int data_id, sensor_data_t &data);
49         bool get_properties(const unsigned int type, sensor_properties_t &properties);
50 private:
51         sensor_base *m_gravity_sensor;
52         cmutex m_value_mutex;
53
54         float m_x;
55         float m_y;
56         float m_z;
57         unsigned long long m_time;
58 };
59
60 #endif /*_LINEAR_ACCEL_SENSOR_H_*/