4 * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
6 * Contact: JongHyuk Choi <jhchoi.choi@samsung.com>, YeJin Cho <cho.yejin@samsung.com>,
7 * Seungbae Shin <seungbae.shin@samsung.com>, YoungHwan An <younghwan_.an@samsung.com>
9 * Licensed under the Apache License, Version 2.0 (the "License");
10 * you may not use this file except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
23 #ifndef __MM_PLAYER_INI_C__
24 #define __MM_PLAYER_INI_C__
30 #include "iniparser.h"
31 #include <mm_player_ini.h>
33 #include <glib/gstdio.h>
35 /* internal functions, macros here */
36 #ifdef MM_PLAYER_DEFAULT_INI
37 static gboolean __generate_default_ini(void);
39 static void __get_element_list(mm_player_ini_t* ini, gchar* str, int keyword_type);
41 static void __mm_player_ini_check_ini_status(void);
44 #define MMPLAYER_INI_GET_STRING( x_dict, x_item, x_ini, x_default ) \
47 gchar* str = iniparser_getstring(x_dict, x_ini, x_default); \
50 ( strlen( str ) > 0 ) && \
51 ( strlen( str ) < PLAYER_INI_MAX_STRLEN ) ) \
53 strncpy ( x_item, str, PLAYER_INI_MAX_STRLEN-1 ); \
57 strncpy ( x_item, x_default, PLAYER_INI_MAX_STRLEN-1 ); \
61 #define MMPLAYER_INI_GET_COLOR( x_dict, x_item, x_ini, x_default ) \
64 gchar* str = iniparser_getstring(x_dict, x_ini, x_default); \
67 ( strlen( str ) > 0 ) && \
68 ( strlen( str ) < PLAYER_INI_MAX_STRLEN ) ) \
70 x_item = (guint) strtoul(str, NULL, 16); \
74 x_item = (guint) strtoul(x_default, NULL, 16); \
78 /* x_ini is the list of index to set TRUE at x_list[index] */
79 #define MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( x_dict, x_list, x_list_max, x_ini, x_default ) \
83 const char *delimiters = " ,"; \
84 char *usr_ptr = NULL; \
86 gchar temp_arr[PLAYER_INI_MAX_STRLEN] = {0}; \
87 MMPLAYER_INI_GET_STRING( x_dict, temp_arr, x_ini, x_default); \
88 token = strtok_r( temp_arr, delimiters, &usr_ptr ); \
91 index = atoi(token); \
92 if (index < 0 || index > x_list_max -1) \
94 LOGW("%d is not valid index\n", index); \
98 x_list[index] = TRUE; \
100 token = strtok_r( NULL, delimiters, &usr_ptr ); \
104 /* x_ini is the list of value to be set at x_list[index] */
105 #define MMPLAYER_INI_GET_INT_FROM_LIST( x_dict, x_list, x_list_max, x_ini, x_default ) \
110 const char *delimiters = " ,"; \
111 char *usr_ptr = NULL; \
112 char *token = NULL; \
113 gchar temp_arr[PLAYER_INI_MAX_STRLEN] = {0}; \
114 MMPLAYER_INI_GET_STRING(x_dict, temp_arr, x_ini, x_default); \
115 token = strtok_r( temp_arr, delimiters, &usr_ptr ); \
118 if ( index > x_list_max -1) \
120 LOGE("%d is not valid index\n", index); \
125 value = atoi(token); \
126 x_list[index] = value; \
129 token = strtok_r( NULL, delimiters, &usr_ptr ); \
134 mm_player_ini_load(mm_player_ini_t* ini)
136 dictionary * dict = NULL;
139 __mm_player_ini_check_ini_status();
141 /* first, try to load existing ini file */
142 dict = iniparser_load(MM_PLAYER_INI_DEFAULT_PATH);
144 /* if no file exists. create one with set of default values */
147 #ifdef MM_PLAYER_DEFAULT_INI
148 LOGD("No inifile found. player will create default inifile.\n");
149 if ( FALSE == __generate_default_ini() )
151 LOGW("Creating default inifile failed. Player will use default values.\n");
155 /* load default ini */
156 dict = iniparser_load(MM_PLAYER_INI_DEFAULT_PATH);
159 LOGD("No ini file found. \n");
160 return MM_ERROR_FILE_NOT_FOUND;
165 memset( ini, 0, sizeof(mm_player_ini_t) );
167 if ( dict ) /* if dict is available */
170 ini->disable_segtrap = iniparser_getboolean(dict, "general:disable segtrap", DEFAULT_DISABLE_SEGTRAP);
171 ini->skip_rescan = iniparser_getboolean(dict, "general:skip rescan", DEFAULT_SKIP_RESCAN);
172 ini->generate_dot = iniparser_getboolean(dict, "general:generate dot", DEFAULT_GENERATE_DOT);
173 ini->use_system_clock = iniparser_getboolean(dict, "general:use system clock", DEFAULT_USE_SYSTEM_CLOCK);
174 ini->live_state_change_timeout = iniparser_getint(dict, "general:live state change timeout", DEFAULT_LIVE_STATE_CHANGE_TIMEOUT);
175 ini->localplayback_state_change_timeout = iniparser_getint(dict, "general:localplayback state change timeout", DEFAULT_LOCALPLAYBACK_STATE_CHANGE_TIMEOUT);
176 ini->eos_delay = iniparser_getint(dict, "general:eos delay", DEFAULT_EOS_DELAY);
177 ini->async_start = iniparser_getboolean(dict, "general:async start", DEFAULT_ASYNC_START);
178 ini->video_playback_supported = iniparser_getboolean(dict, "general:video playback supported", DEFAULT_VIDEO_PLAYBACK_SUPPORTED);
179 ini->delay_before_repeat = iniparser_getint(dict, "general:delay before repeat", DEFAULT_DELAY_BEFORE_REPEAT);
180 ini->pcm_buffer_size = iniparser_getint(dict, "general:pcm buffer size", DEFAULT_PCM_BUFFER_SIZE);
181 ini->num_of_video_bo = iniparser_getint(dict, "general:video bo max", DEFAULT_NUM_OF_VIDEO_BO);
182 ini->video_bo_timeout = iniparser_getint(dict, "general:video bo timeout", DEFAULT_TIMEOUT_OF_VIDEO_BO);
184 MMPLAYER_INI_GET_STRING(dict, ini->videosink_element_overlay, "general:videosink element overlay", DEFAULT_VIDEOSINK_OVERLAY);
185 MMPLAYER_INI_GET_STRING(dict, ini->videosink_element_evas, "general:videosink element evas", DEFAULT_VIDEOSINK_EVAS);
186 MMPLAYER_INI_GET_STRING(dict, ini->videosink_element_fake, "general:videosink element fake", DEFAULT_VIDEOSINK_FAKE);
187 MMPLAYER_INI_GET_STRING(dict, ini->videosink_element_remote, "general:videosink element remote", DEFAULT_VIDEOSINK_REMOTE);
188 MMPLAYER_INI_GET_STRING(dict, ini->videosrc_element_remote, "general:videosrc element remote", DEFAULT_VIDEOSRC_REMOTE);
189 MMPLAYER_INI_GET_STRING(dict, ini->audioresampler_element, "general:audio resampler element", DEFAULT_AUDIORESAMPLER );
190 MMPLAYER_INI_GET_STRING(dict, ini->audiosink_element, "general:audiosink element", DEFAULT_AUDIOSINK );
191 MMPLAYER_INI_GET_STRING(dict, ini->videoconverter_element, "general:video converter element", DEFAULT_VIDEO_CONVERTER );
193 __get_element_list(ini,
194 iniparser_getstring(dict, "general:element exclude keyword", DEFAULT_EXCLUDE_KEYWORD), KEYWORD_EXCLUDE);
196 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[0], "general:gstparam1", DEFAULT_GST_PARAM );
197 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[1], "general:gstparam2", DEFAULT_GST_PARAM );
198 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[2], "general:gstparam3", DEFAULT_GST_PARAM );
199 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[3], "general:gstparam4", DEFAULT_GST_PARAM );
200 MMPLAYER_INI_GET_STRING(dict, ini->gst_param[4], "general:gstparam5", DEFAULT_GST_PARAM );
203 MMPLAYER_INI_GET_STRING( dict, ini->httpsrc_element, "http streaming:httpsrc element", DEFAULT_HTTPSRC );
204 ini->http_use_file_buffer = iniparser_getboolean(dict, "http streaming:http use file buffer", DEFAULT_HTTP_USE_FILE_BUFFER);
205 ini->http_ring_buffer_size = iniparser_getint(dict, "http streaming:http ring buffer size", DEFAULT_HTTP_RING_BUFFER_SIZE);
206 ini->http_buffering_limit = iniparser_getdouble(dict, "http streaming:http buffering high limit", DEFAULT_HTTP_BUFFERING_LIMIT);
207 ini->http_max_size_bytes = iniparser_getint(dict, "http streaming:http max size bytes", DEFAULT_HTTP_MAX_SIZE_BYTES);
208 ini->http_buffering_time = iniparser_getdouble(dict, "http streaming:http buffering time", DEFAULT_HTTP_BUFFERING_TIME);
209 ini->http_timeout = iniparser_getint(dict, "http streaming:http timeout", DEFAULT_HTTP_TIMEOUT);
211 /* dump buffer for debug */
212 __get_element_list(ini,
213 iniparser_getstring(dict, "general:dump element keyword", DEFAULT_EXCLUDE_KEYWORD), KEYWORD_DUMP);
215 MMPLAYER_INI_GET_STRING(dict, ini->dump_element_path, "general:dump element path", DEFAULT_DUMP_ELEMENT_PATH);
217 else /* if dict is not available just fill the structure with default value */
219 LOGW("failed to load ini. using hardcoded default\n");
222 ini->disable_segtrap = DEFAULT_DISABLE_SEGTRAP;
223 ini->skip_rescan = DEFAULT_SKIP_RESCAN;
224 strncpy( ini->videosink_element_overlay, DEFAULT_VIDEOSINK_OVERLAY, PLAYER_INI_MAX_STRLEN - 1 );
225 strncpy( ini->videosink_element_evas, DEFAULT_VIDEOSINK_EVAS, PLAYER_INI_MAX_STRLEN - 1 );
226 strncpy( ini->videosink_element_fake, DEFAULT_VIDEOSINK_FAKE, PLAYER_INI_MAX_STRLEN - 1 );
227 strncpy( ini->videosink_element_remote, DEFAULT_VIDEOSINK_REMOTE, PLAYER_INI_MAX_STRLEN - 1 );
228 strncpy( ini->videosrc_element_remote, DEFAULT_VIDEOSRC_REMOTE, PLAYER_INI_MAX_STRLEN - 1 );
229 ini->generate_dot = DEFAULT_GENERATE_DOT;
230 ini->use_system_clock = DEFAULT_USE_SYSTEM_CLOCK;
231 ini->live_state_change_timeout = DEFAULT_LIVE_STATE_CHANGE_TIMEOUT;
232 ini->localplayback_state_change_timeout = DEFAULT_LOCALPLAYBACK_STATE_CHANGE_TIMEOUT;
233 ini->eos_delay = DEFAULT_EOS_DELAY;
234 ini->async_start = DEFAULT_ASYNC_START;
235 ini->delay_before_repeat = DEFAULT_DELAY_BEFORE_REPEAT;
236 ini->video_playback_supported = DEFAULT_VIDEO_PLAYBACK_SUPPORTED;
237 ini->pcm_buffer_size = DEFAULT_PCM_BUFFER_SIZE;
238 ini->num_of_video_bo = DEFAULT_NUM_OF_VIDEO_BO;
239 ini->video_bo_timeout = DEFAULT_TIMEOUT_OF_VIDEO_BO;
241 strncpy( ini->audioresampler_element, DEFAULT_AUDIORESAMPLER, PLAYER_INI_MAX_STRLEN -1 );
242 strncpy( ini->audiosink_element, DEFAULT_AUDIOSINK, PLAYER_INI_MAX_STRLEN -1 );
243 strncpy( ini->videoconverter_element, DEFAULT_VIDEO_CONVERTER, PLAYER_INI_MAX_STRLEN -1 );
245 __get_element_list(ini, DEFAULT_EXCLUDE_KEYWORD, KEYWORD_EXCLUDE);
247 strncpy( ini->gst_param[0], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
248 strncpy( ini->gst_param[1], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
249 strncpy( ini->gst_param[2], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
250 strncpy( ini->gst_param[3], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
251 strncpy( ini->gst_param[4], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
254 strncpy( ini->httpsrc_element, DEFAULT_HTTPSRC, PLAYER_INI_MAX_STRLEN - 1 );
255 ini->http_buffering_limit = DEFAULT_HTTP_BUFFERING_LIMIT;
256 ini->http_use_file_buffer = DEFAULT_HTTP_USE_FILE_BUFFER;
257 ini->http_ring_buffer_size = DEFAULT_HTTP_RING_BUFFER_SIZE;
258 ini->http_max_size_bytes = DEFAULT_HTTP_MAX_SIZE_BYTES;
259 ini->http_buffering_time = DEFAULT_HTTP_BUFFERING_TIME;
260 ini->http_timeout = DEFAULT_HTTP_TIMEOUT;
262 /* dump buffer for debug */
263 __get_element_list(ini, DEFAULT_DUMP_ELEMENT_KEYWORD, KEYWORD_DUMP);
264 strncpy(ini->dump_element_path, DEFAULT_DUMP_ELEMENT_PATH, PLAYER_INI_MAX_STRLEN - 1);
267 /* free dict as we got our own structure */
268 iniparser_freedict (dict);
271 LOGD("player settings -----------------------------------\n");
274 LOGD("disable segtrap : %d\n", ini->disable_segtrap);
275 LOGD("skip rescan : %d\n", ini->skip_rescan);
276 LOGD("videosink element overlay: %s\n", ini->videosink_element_overlay);
277 LOGD("videosink element evas: %s\n", ini->videosink_element_evas);
278 LOGD("videosink element fake: %s\n", ini->videosink_element_fake);
279 LOGD("videosink element remote: %s\n", ini->videosink_element_remote);
280 LOGD("videosrc element remote: %s\n", ini->videosrc_element_remote);
281 LOGD("video converter element : %s\n", ini->videoconverter_element);
282 LOGD("audio resampler element : %s\n", ini->audioresampler_element);
283 LOGD("audiosink element : %s\n", ini->audiosink_element);
284 LOGD("generate dot : %d\n", ini->generate_dot);
285 LOGD("use system clock(video only) : %d\n", ini->use_system_clock);
286 LOGD("live state change timeout(sec) : %d\n", ini->live_state_change_timeout);
287 LOGD("localplayback state change timeout(sec) : %d\n", ini->localplayback_state_change_timeout);
288 LOGD("eos_delay(msec) : %d\n", ini->eos_delay);
289 LOGD("delay before repeat(msec) : %d\n", ini->delay_before_repeat);
290 LOGD("async_start : %d\n", ini->async_start);
291 LOGD("video_playback_supported : %d\n", ini->video_playback_supported);
292 LOGD("pcm buffer size(bytes) : %d\n", ini->pcm_buffer_size);
293 LOGD("num of video bo : %d\n", ini->num_of_video_bo);
294 LOGD("video bo timeout : %d\n", ini->video_bo_timeout);
295 LOGD("gst param1 : %s\n", ini->gst_param[0]);
296 LOGD("gst param2 : %s\n", ini->gst_param[1]);
297 LOGD("gst param3 : %s\n", ini->gst_param[2]);
298 LOGD("gst param4 : %s\n", ini->gst_param[3]);
299 LOGD("gst param5 : %s\n", ini->gst_param[4]);
301 for ( idx = 0; ini->exclude_element_keyword[idx][0] != '\0'; idx++ )
303 LOGD("exclude_element_keyword [%d] : %s\n", idx, ini->exclude_element_keyword[idx]);
306 for ( idx = 0; ini->dump_element_keyword[idx][0] != '\0'; idx++ )
308 LOGD("dump_element_keyword [%d] : %s\n", idx, ini->dump_element_keyword[idx]);
312 LOGD("httpsrc element : %s\n", ini->httpsrc_element);
313 LOGD("http buffering limit : %f \n", ini->http_buffering_limit);
314 LOGD("http use file buffer : %d \n", ini->http_use_file_buffer);
315 LOGD("http ring buffer size : %d \n", ini->http_ring_buffer_size);
316 LOGD("http max_size bytes : %d \n", ini->http_max_size_bytes);
317 LOGD("http buffering time : %f \n", ini->http_buffering_time);
318 LOGD("http timeout : %d \n", ini->http_timeout);
320 return MM_ERROR_NONE;
324 mm_player_audio_effect_ini_load(mm_player_ini_t* ini)
326 dictionary * dict_audioeffect = NULL;
328 dict_audioeffect = iniparser_load(MM_PLAYER_INI_DEFAULT_AUDIOEFFECT_PATH);
329 if ( !dict_audioeffect )
331 LOGE("No audio effect ini file found. \n");
332 return MM_ERROR_FILE_NOT_FOUND;
335 /* audio effect element name */
336 MMPLAYER_INI_GET_STRING( dict_audioeffect, ini->audioeffect_element, "audio effect:audio effect element", DEFAULT_AUDIO_EFFECT_ELEMENT );
337 if (!ini->audioeffect_element[0])
339 LOGW("could not parse name of audio effect. \n");
340 iniparser_freedict (dict_audioeffect);
341 /* NOTE : in this case, we are not going to create audio filter element */
342 return MM_ERROR_NONE;
345 /* audio effect (Preset)*/
346 ini->use_audio_effect_preset = iniparser_getboolean(dict_audioeffect, "audio effect:audio effect preset", DEFAULT_USE_AUDIO_EFFECT_PRESET);
347 if (ini->use_audio_effect_preset)
349 MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( dict_audioeffect, ini->audio_effect_preset_list, MM_AUDIO_EFFECT_PRESET_NUM,
350 "audio effect:audio effect preset list", DEFAULT_AUDIO_EFFECT_PRESET_LIST );
351 MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( dict_audioeffect, ini->audio_effect_preset_earphone_only_list, MM_AUDIO_EFFECT_PRESET_NUM,
352 "audio effect:audio effect preset earphone only", DEFAULT_AUDIO_EFFECT_PRESET_LIST_EARPHONE_ONLY );
355 /* audio effect user (EQ / Extension effects) */
356 ini->use_audio_effect_custom = iniparser_getboolean(dict_audioeffect, "audio effect:audio effect custom", DEFAULT_USE_AUDIO_EFFECT_CUSTOM);
357 if (ini->use_audio_effect_custom)
359 MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( dict_audioeffect, ini->audio_effect_custom_list, MM_AUDIO_EFFECT_CUSTOM_NUM,
360 "audio effect:audio effect custom list", DEFAULT_AUDIO_EFFECT_CUSTOM_LIST );
361 MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( dict_audioeffect, ini->audio_effect_custom_earphone_only_list, MM_AUDIO_EFFECT_CUSTOM_NUM,
362 "audio effect:audio effect custom earphone only", DEFAULT_AUDIO_EFFECT_CUSTOM_LIST_EARPHONE_ONLY );
364 /* audio effect custom : EQ */
365 if (ini->audio_effect_custom_list[MM_AUDIO_EFFECT_CUSTOM_EQ])
367 ini->audio_effect_custom_eq_band_num = iniparser_getint(dict_audioeffect, "audio effect:audio effect custom eq band num",
368 DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM);
369 if (ini->audio_effect_custom_eq_band_num < DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM ||
370 ini->audio_effect_custom_eq_band_num > MM_AUDIO_EFFECT_EQ_BAND_NUM_MAX)
372 LOGE("audio_effect_custom_eq_band_num(%d) is not valid range(%d - %d), set the value %d",
373 ini->audio_effect_custom_eq_band_num, DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM, MM_AUDIO_EFFECT_EQ_BAND_NUM_MAX, DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM);
374 ini->audio_effect_custom_eq_band_num = DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_NUM;
376 iniparser_freedict (dict_audioeffect);
377 return MM_ERROR_PLAYER_INTERNAL;
381 if (ini->audio_effect_custom_eq_band_num)
383 MMPLAYER_INI_GET_INT_FROM_LIST( dict_audioeffect, ini->audio_effect_custom_eq_band_width, MM_AUDIO_EFFECT_EQ_BAND_NUM_MAX,
384 "audio effect:audio effect custom eq band width", DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_WIDTH );
385 MMPLAYER_INI_GET_INT_FROM_LIST( dict_audioeffect, ini->audio_effect_custom_eq_band_freq, MM_AUDIO_EFFECT_EQ_BAND_NUM_MAX,
386 "audio effect:audio effect custom eq band freq", DEFAULT_AUDIO_EFFECT_CUSTOM_EQ_BAND_FREQ );
391 /* audio effect custom : Extension effects */
392 ini->audio_effect_custom_ext_num = iniparser_getint(dict_audioeffect, "audio effect:audio effect custom ext num",
393 DEFAULT_AUDIO_EFFECT_CUSTOM_EXT_NUM);
395 /* Min/Max value list of EQ / Extension effects */
396 if (ini->audio_effect_custom_eq_band_num || ini->audio_effect_custom_ext_num)
399 MMPLAYER_INI_GET_INT_FROM_LIST( dict_audioeffect, ini->audio_effect_custom_min_level_list, MM_AUDIO_EFFECT_CUSTOM_NUM,
400 "audio effect:audio effect custom min list", DEFAULT_AUDIO_EFFECT_CUSTOM_LIST );
401 MMPLAYER_INI_GET_INT_FROM_LIST( dict_audioeffect, ini->audio_effect_custom_max_level_list, MM_AUDIO_EFFECT_CUSTOM_NUM,
402 "audio effect:audio effect custom max list", DEFAULT_AUDIO_EFFECT_CUSTOM_LIST );
406 /* audio effect element name */
407 MMPLAYER_INI_GET_STRING(dict_audioeffect, ini->audioeffect_element_custom, "audio effect:audio effect element custom", DEFAULT_AUDIO_EFFECT_ELEMENT );
408 if (!ini->audioeffect_element_custom[0])
410 LOGW("no secondary audio effect \n");
414 LOGD("audioeffect element custom : %s\n", ini->audioeffect_element_custom);
418 LOGD("audioeffect element : %s\n", ini->audioeffect_element);
419 LOGD("audio effect preset mode : %d\n", ini->use_audio_effect_preset);
420 LOGD("audio effect custom mode : %d\n", ini->use_audio_effect_custom);
423 for (i=0; i<MM_AUDIO_EFFECT_PRESET_NUM; i++)
425 LOGD("audio_effect_preset_list: %d (is it for earphone only?(%d))\n", ini->audio_effect_preset_list[i], ini->audio_effect_preset_earphone_only_list[i]);
427 for (i=0; i<MM_AUDIO_EFFECT_CUSTOM_NUM; i++)
429 LOGD("audio_effect_custom_list : %d (is it for earphone only?(%d))\n", ini->audio_effect_custom_list[i], ini->audio_effect_custom_earphone_only_list[i]);
431 LOGD("audio_effect_custom : eq_band_num(%d), ext_num(%d)\n", ini->audio_effect_custom_eq_band_num, ini->audio_effect_custom_ext_num );
432 LOGD("audio_effect_custom_EQ : width(Hz) / central frequency(Hz)");
433 for (i=0; i<ini->audio_effect_custom_eq_band_num; i++)
435 LOGD(" EQ band index(%d) : %8d / %8d", i, ini->audio_effect_custom_eq_band_width[i], ini->audio_effect_custom_eq_band_freq[i]);
437 for (i=0; i<MM_AUDIO_EFFECT_CUSTOM_NUM; i++)
439 LOGD("audio_effect_custom_level_min_max(idx:%d) : Min(%d), Max(%d)\n", i, ini->audio_effect_custom_min_level_list[i], ini->audio_effect_custom_max_level_list[i]);
442 iniparser_freedict (dict_audioeffect);
444 return MM_ERROR_NONE;
449 void __mm_player_ini_check_ini_status(void)
451 struct stat ini_buff;
453 if ( g_stat(MM_PLAYER_INI_DEFAULT_PATH, &ini_buff) < 0 )
455 LOGW("failed to get player ini status\n");
459 if ( ini_buff.st_size < 5 )
461 LOGW("player.ini file size=%d, Corrupted! So, Removed\n", (int)ini_buff.st_size);
463 if ( g_remove( MM_PLAYER_INI_DEFAULT_PATH ) == -1)
465 LOGE("failed to delete corrupted ini");
471 #ifdef MM_PLAYER_DEFAULT_INI
473 gboolean __generate_default_ini(void)
476 gchar* default_ini = MM_PLAYER_DEFAULT_INI;
479 /* create new file */
480 fp = fopen(MM_PLAYER_INI_DEFAULT_PATH, "wt");
487 /* writing default ini file */
488 if ( strlen(default_ini) != fwrite(default_ini, 1, strlen(default_ini), fp) )
500 void __get_element_list(mm_player_ini_t* ini, gchar* str, int keyword_type)
505 gchar* strtmp = NULL;
510 if ( strlen( str ) < 1 )
513 strtmp = g_strdup (str);
515 /* trimming. it works inplace */
516 g_strstrip( strtmp );
520 list = g_strsplit( strtmp, ",", 10 );
531 switch (keyword_type)
533 case KEYWORD_EXCLUDE:
535 for( walk = list; *walk; walk++ )
537 strncpy( ini->exclude_element_keyword[i], *walk, (PLAYER_INI_MAX_STRLEN - 1) );
539 g_strstrip( ini->exclude_element_keyword[i] );
541 ini->exclude_element_keyword[i][PLAYER_INI_MAX_STRLEN -1]= '\0';
545 /* mark last item to NULL */
546 ini->exclude_element_keyword[i][0] = '\0';
552 for( walk = list; *walk; walk++ )
554 strncpy( ini->dump_element_keyword[i], *walk, (PLAYER_INI_MAX_STRLEN - 1) );
556 g_strstrip( ini->dump_element_keyword[i] );
558 ini->dump_element_keyword[i][PLAYER_INI_MAX_STRLEN -1]= '\0';
562 /* mark last item to NULL */
563 ini->dump_element_keyword[i][0] = '\0';