-
Notifications
You must be signed in to change notification settings - Fork 10
/
plugin-quirks.c
190 lines (162 loc) · 4.72 KB
/
plugin-quirks.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
/** @file plugin-quirks.c
*
* mce-plugin-libhybris - Libhybris plugin for Mode Control Entity
* <p>
* Copyright (c) 2017 Jolla Ltd.
* Copyright (c) 2024 Jollyboys Ltd.
* <p>
* @author Simo Piiroinen <[email protected]>
*
* mce-plugin-libhybris is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License.
*
* mce-plugin-libhybris is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with mce-plugin-libhybris; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#include "plugin-quirks.h"
#include "plugin-config.h"
#include "plugin-logging.h"
#include <stdlib.h>
#include <stdbool.h>
#include <string.h>
/* ========================================================================= *
* QUIRKS
* ========================================================================= */
/** Strings that should be treated as "1" when evaluating quirk settings */
static const char * const quirk_true_lut[] =
{
"true", "yes", "enabled", 0
};
/** Strings that should be treated as "0" when evaluating quirk settings */
static const char * const quirk_false_lut[] =
{
"false", "no", "disabled", 0
};
/** Quirk enum id to settings ini-file key lookup table */
static const char * const quirk_name_lut[QUIRK_COUNT] =
{
[QUIRK_BREATHING_ENABLED] = MCE_CONF_LED_CONFIG_HYBRIS_BREATHING_ENABLED,
[QUIRK_BREATHING_TYPE] = MCE_CONF_LED_CONFIG_HYBRIS_BREATHING_TYPE,
};
/** Flag array for: quirk setting has been defined in mce config */
static bool quirk_defined_lut[QUIRK_COUNT];
/** Value array for: quirk settings defined in mce config */
static int quirk_value_lut[QUIRK_COUNT];
/** Helper for checking string exists in an array
*
* @param vec Array of strings
* @param str String to look for
*
* @return true if string exists in array, false otherwise
*/
static bool
quirk_in_array(const char * const *vec, const char *str)
{
for( ; *vec; ++vec )
if( !strcmp(*vec, str) )
return true;
return false;
}
/** Helper for parsing integer quirk setting values
*
* To allow improved readability, various aliases for boolean
* type values are converted to true/1 or false/0.
*
* @param str String value from ini-file
*
* @return Integer value, or zero as fallback value
*/
static int
quirk_parse_value(const char *str)
{
int val = false;
if( !str )
goto EXIT;
if( quirk_in_array(quirk_false_lut, str) )
goto EXIT;
val = true;
if( quirk_in_array(quirk_true_lut, str) )
goto EXIT;
val = strtol(str, 0, 0);
EXIT:
return val;
}
/** Populate quirk value array using data from mce configuration files
*/
static void
plugin_quirk_init(void)
{
for( quirk_t id = 0; id < QUIRK_COUNT; ++id ) {
gchar *val = plugin_config_get_string(MCE_CONF_LED_CONFIG_HYBRIS_GROUP,
quirk_name_lut[id], 0);
if( !val )
continue;
quirk_defined_lut[id] = true;
quirk_value_lut[id] = quirk_parse_value(val);
mce_log(LOG_DEBUG, "set %s = %d",
quirk_name_lut[id],
quirk_value_lut[id]);
g_free(val);
}
}
/** Predicat for: numerical quirk id is valid
*
* @param id Quirk ID
*
* @return true if id is valid, false otherwise
*/
static bool
quirk_is_valid(quirk_t id)
{
return id > QUIRK_INVALID && id < QUIRK_COUNT && quirk_name_lut[id];
}
/** Predicat for: Value for quirk id has been defined in configuration
*
* @param id Quirk ID
*
* @return true if id is valid and defined, false otherwise
*/
static bool
quirk_is_defined(quirk_t id)
{
return quirk_is_valid(id) && quirk_defined_lut[id];
}
/** Get human readable name for a quirk id
*
* @param id Quirk ID
*
* @return quirk name used in setting ini-files, or "QuirkInvalid"
*/
const char *
quirk_name(quirk_t id)
{
const char *repr = 0;
if( quirk_is_valid(id) )
repr = quirk_name_lut[id];
return repr ?: "QuirkInvalid";
}
/* Get value associated with quirk id
*
* @param id Quirk ID
* @param def Fallback value
*
* @return Configured quirk value, or the caller provided default value
*/
int
quirk_value(quirk_t id, int def)
{
static bool done = false;
if( !done ) {
done = true;
plugin_quirk_init();
}
return quirk_is_defined(id) ? quirk_value_lut[id] : def;
}