clean up for 2.0 beta
[platform/core/multimedia/libmm-player.git] / src / mm_player_ini.c
1 /*
2  * libmm-player
3  *
4  * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
5  *
6  * Contact: JongHyuk Choi <jhchoi.choi@samsung.com>, YeJin Cho <cho.yejin@samsung.com>, YoungHwan An <younghwan_.an@samsung.com>
7  *
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  * http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  *
20  */
21
22 #ifndef __MM_PLAYER_INI_C__
23 #define __MM_PLAYER_INI_C__
24
25 /* includes here */
26 #include <glib.h>
27 #include <stdlib.h>
28 #include "iniparser.h"
29 #include <mm_player_ini.h>
30 #include "mm_debug.h"
31 #include <mm_error.h>
32 #include <glib/gstdio.h>
33
34 /* global variables here */
35 static mm_player_ini_t g_player_ini;
36
37 /* internal functions, macros here */
38 static gboolean __generate_default_ini(void);
39 static void     __get_string_list(gchar** out_list, gchar* str);
40 static void __mm_player_ini_check_ini_status(void);
41 //static void __mm_player_ini_force_setting(void);
42
43 /* macro */
44 #define MMPLAYER_INI_GET_STRING( x_item, x_ini, x_default ) \
45 do \
46 { \
47         gchar* str = iniparser_getstring(dict, x_ini, x_default); \
48  \
49         if ( str &&  \
50                 ( strlen( str ) > 0 ) && \
51                 ( strlen( str ) < PLAYER_INI_MAX_STRLEN ) ) \
52         { \
53                 strcpy ( x_item, str ); \
54         } \
55         else \
56         { \
57                 strcpy ( x_item, x_default ); \
58         } \
59 }while(0)
60
61 /* x_ini is the list of index to set TRUE at x_list[index] */
62 #define MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( x_list, x_list_max, x_ini, x_default ) \
63 do \
64 { \
65                 int index = 0; \
66                 const char *delimiters = " ,"; \
67                 char *usr_ptr = NULL; \
68                 char *token = NULL; \
69                 gchar temp_arr[PLAYER_INI_MAX_STRLEN] = {0}; \
70                 MMPLAYER_INI_GET_STRING(temp_arr, x_ini, x_default); \
71                 token = strtok_r( temp_arr, delimiters, &usr_ptr ); \
72                 while (token) \
73                 { \
74                         index = atoi(token); \
75                         if (index < 0 || index > x_list_max -1) \
76                         { \
77                                 debug_warning("%d is not valid index\n", index); \
78                         } \
79                         else \
80                         { \
81                                 x_list[index] = TRUE; \
82                         } \
83                         token = strtok_r( NULL, delimiters, &usr_ptr ); \
84                 } \
85 }while(0)
86
87 /* x_ini is the list of value to be set at x_list[index] */
88 #define MMPLAYER_INI_GET_INT_FROM_LIST( x_list, x_list_max, x_ini, x_default ) \
89 do \
90 { \
91                 int index = 0; \
92                 int value = 0; \
93                 const char *delimiters = " ,"; \
94                 char *usr_ptr = NULL; \
95                 char *token = NULL; \
96                 gchar temp_arr[PLAYER_INI_MAX_STRLEN] = {0}; \
97                 MMPLAYER_INI_GET_STRING(temp_arr, x_ini, x_default); \
98                 token = strtok_r( temp_arr, delimiters, &usr_ptr ); \
99                 while (token) \
100                 { \
101                         if ( index > x_list_max -1) \
102                         { \
103                                 debug_error("%d is not valid index\n", index); \
104                                 break; \
105                         } \
106                         else \
107                         { \
108                                 value = atoi(token); \
109                                 x_list[index] = value; \
110                                 index++; \
111                         } \
112                         token = strtok_r( NULL, delimiters, &usr_ptr ); \
113                 } \
114 }while(0)
115
116 int 
117 mm_player_ini_load(void)
118 {
119         static gboolean loaded = FALSE;
120         dictionary * dict = NULL;
121         gint idx = 0;
122
123         if ( loaded )
124                 return MM_ERROR_NONE;
125
126         dict = NULL;
127
128         /* disabling ini parsing for launching */
129 #if 1 //debianize
130         /* get player ini status because system will be crashed 
131          * if ini file is corrupted. 
132          */
133         /* FIXIT : the api actually deleting illregular ini. but the function name said it's just checking. */
134         __mm_player_ini_check_ini_status();
135
136         /* first, try to load existing ini file */
137         dict = iniparser_load(MM_PLAYER_INI_DEFAULT_PATH);
138
139         /* if no file exists. create one with set of default values */
140         if ( !dict )
141         {
142                 #if 0
143                 debug_log("No inifile found. player will create default inifile.\n");
144                 if ( FALSE == __generate_default_ini() )
145                 {       
146                         debug_warning("Creating default inifile failed. Player will use default values.\n");
147                 }
148                 else
149                 {
150                         /* load default ini */
151                         dict = iniparser_load(MM_PLAYER_INI_DEFAULT_PATH);      
152                 }
153                 #else
154                 debug_log("No inifile found. \n");
155
156                 return MM_ERROR_FILE_NOT_FOUND;
157                 #endif
158         }
159 #endif
160
161         /* get ini values */
162         memset( &g_player_ini, 0, sizeof(mm_player_ini_t) );
163
164         if ( dict ) /* if dict is available */
165         {
166                 /* general */
167                 g_player_ini.use_decodebin = iniparser_getboolean(dict, "general:use decodebin", DEFAULT_USE_DECODEBIN);
168                 g_player_ini.disable_segtrap = iniparser_getboolean(dict, "general:disable segtrap", DEFAULT_DISABLE_SEGTRAP);
169                 g_player_ini.skip_rescan = iniparser_getboolean(dict, "general:skip rescan", DEFAULT_SKIP_RESCAN);
170                 g_player_ini.video_surface = DEFAULT_VIDEO_SURFACE;
171                 g_player_ini.generate_dot = iniparser_getboolean(dict, "general:generate dot", DEFAULT_GENERATE_DOT);
172                 g_player_ini.provide_clock= iniparser_getboolean(dict, "general:provide clock", DEFAULT_PROVIDE_CLOCK);
173                 g_player_ini.live_state_change_timeout = iniparser_getint(dict, "general:live state change timeout", DEFAULT_LIVE_STATE_CHANGE_TIMEOUT);
174                 g_player_ini.localplayback_state_change_timeout = iniparser_getint(dict, "general:localplayback state change timeout", DEFAULT_LOCALPLAYBACK_STATE_CHANGE_TIMEOUT);
175                 g_player_ini.eos_delay = iniparser_getint(dict, "general:eos delay", DEFAULT_EOS_DELAY);
176                 g_player_ini.async_start = iniparser_getboolean(dict, "general:async start", DEFAULT_ASYNC_START);
177                 g_player_ini.multiple_codec_supported = iniparser_getboolean(dict, "general:multiple codec supported", DEFAULT_MULTIPLE_CODEC_SUPPORTED);
178
179                 g_player_ini.delay_before_repeat = iniparser_getint(dict, "general:delay before repeat", DEFAULT_DELAY_BEFORE_REPEAT);
180
181                 MMPLAYER_INI_GET_STRING( g_player_ini.videosink_element_x, "general:videosink element x", DEFAULT_VIDEOSINK_X);
182                 MMPLAYER_INI_GET_STRING( g_player_ini.videosink_element_evas, "general:videosink element evas", DEFAULT_VIDEOSINK_EVAS);
183                 MMPLAYER_INI_GET_STRING( g_player_ini.videosink_element_fake, "general:videosink element fake", DEFAULT_VIDEOSINK_FAKE);
184                 MMPLAYER_INI_GET_STRING( g_player_ini.name_of_drmsrc, "general:drmsrc element", DEFAULT_DRMSRC );
185                 MMPLAYER_INI_GET_STRING( g_player_ini.name_of_audiosink, "general:audiosink element", DEFAULT_AUDIOSINK );
186                 MMPLAYER_INI_GET_STRING( g_player_ini.name_of_video_converter, "general:video converter element", DEFAULT_VIDEO_CONVERTER );
187
188                 __get_string_list( (gchar**) g_player_ini.exclude_element_keyword, 
189                         iniparser_getstring(dict, "general:element exclude keyword", DEFAULT_EXCLUDE_KEYWORD));
190
191                 MMPLAYER_INI_GET_STRING( g_player_ini.gst_param[0], "general:gstparam1", DEFAULT_GST_PARAM );
192                 MMPLAYER_INI_GET_STRING( g_player_ini.gst_param[1], "general:gstparam2", DEFAULT_GST_PARAM );
193                 MMPLAYER_INI_GET_STRING( g_player_ini.gst_param[2], "general:gstparam3", DEFAULT_GST_PARAM );
194                 MMPLAYER_INI_GET_STRING( g_player_ini.gst_param[3], "general:gstparam4", DEFAULT_GST_PARAM );
195                 MMPLAYER_INI_GET_STRING( g_player_ini.gst_param[4], "general:gstparam5", DEFAULT_GST_PARAM );
196
197                 /* audio filter (Preset)*/
198                 g_player_ini.use_audio_filter_preset = iniparser_getboolean(dict, "sound effect:audio filter preset", DEFAULT_USE_AUDIO_FILTER_PRESET);
199                 if (g_player_ini.use_audio_filter_preset)
200                 {
201                         MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( g_player_ini.audio_filter_preset_list, MM_AUDIO_FILTER_PRESET_NUM,
202                                         "sound effect:audio filter preset list", DEFAULT_AUDIO_FILTER_PRESET_LIST );
203                         MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( g_player_ini.audio_filter_preset_earphone_only_list, MM_AUDIO_FILTER_PRESET_NUM,
204                                         "sound effect:audio filter preset earphone only", DEFAULT_AUDIO_FILTER_PRESET_LIST_EARPHONE_ONLY );
205                 }
206                 /* for audio filter custom (EQ / Extension filters) */
207                 g_player_ini.use_audio_filter_custom = iniparser_getboolean(dict, "sound effect:audio filter custom", DEFAULT_USE_AUDIO_FILTER_CUSTOM);
208                 if (g_player_ini.use_audio_filter_custom)
209                 {
210                         MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( g_player_ini.audio_filter_custom_list, MM_AUDIO_FILTER_CUSTOM_NUM,
211                                         "sound effect:audio filter custom list", DEFAULT_AUDIO_FILTER_CUSTOM_LIST );
212                         MMPLAYER_INI_GET_BOOLEAN_FROM_LIST( g_player_ini.audio_filter_custom_earphone_only_list, MM_AUDIO_FILTER_CUSTOM_NUM,
213                                         "sound effect:audio filter custom earphone only", DEFAULT_AUDIO_FILTER_CUSTOM_LIST_EARPHONE_ONLY );
214                         /* for audio filter custom : EQ */
215                         if (g_player_ini.audio_filter_custom_list[MM_AUDIO_FILTER_CUSTOM_EQ])
216                         {
217                                 g_player_ini.audio_filter_custom_eq_num = iniparser_getint(dict, "sound effect:audio filter eq num",
218                                                 DEFAULT_AUDIO_FILTER_CUSTOM_EQ_NUM);
219                                 if (g_player_ini.audio_filter_custom_eq_num < DEFAULT_AUDIO_FILTER_CUSTOM_EQ_NUM || g_player_ini.audio_filter_custom_eq_num > MM_AUDIO_FILTER_EQ_BAND_MAX)
220                                 {
221                                         debug_error("audio_filter_custom_eq_num(%d) is not valid range(%d - %d), set the value %d",
222                                                 g_player_ini.audio_filter_custom_eq_num, DEFAULT_AUDIO_FILTER_CUSTOM_EQ_NUM, MM_AUDIO_FILTER_EQ_BAND_MAX, DEFAULT_AUDIO_FILTER_CUSTOM_EQ_NUM);
223                                         g_player_ini.audio_filter_custom_eq_num = DEFAULT_AUDIO_FILTER_CUSTOM_EQ_NUM;
224                                 }
225                         }
226                         /* for audio filter custom : extension filters */
227                         g_player_ini.audio_filter_custom_ext_num = iniparser_getint(dict, "sound effect:audio filter ext num",
228                                         DEFAULT_AUDIO_FILTER_CUSTOM_EXT_NUM);
229                         if (g_player_ini.audio_filter_custom_ext_num > 0)
230                         {
231                                 MMPLAYER_INI_GET_INT_FROM_LIST( g_player_ini.audio_filter_custom_min_level_list, MM_AUDIO_FILTER_CUSTOM_NUM,
232                                                 "sound effect:audio filter custom min list", DEFAULT_AUDIO_FILTER_CUSTOM_LIST );
233                                 MMPLAYER_INI_GET_INT_FROM_LIST( g_player_ini.audio_filter_custom_max_level_list, MM_AUDIO_FILTER_CUSTOM_NUM,
234                                                 "sound effect:audio filter custom max list", DEFAULT_AUDIO_FILTER_CUSTOM_LIST );
235                         }
236                 }
237 #if 0
238                 int i;
239                 for (i=0; i<MM_AUDIO_FILTER_PRESET_NUM; i++)
240                 {
241                         debug_log("audio_filter_preset_list: %d (is it for earphone only?(%d))\n", g_player_ini.audio_filter_preset_list[i], g_player_ini.audio_filter_preset_earphone_only_list[i]);
242                 }
243                 for (i=0; i<MM_AUDIO_FILTER_CUSTOM_NUM; i++)
244                 {
245                         debug_log("audio_filter_custom_list : %d (is it for earphone only?(%d))\n", g_player_ini.audio_filter_custom_list[i], g_player_ini.audio_filter_custom_earphone_only_list[i]);
246                 }
247                 debug_log("audio_filter_custom : eq_num(%d), ext_num(%d)\n", g_player_ini.audio_filter_custom_eq_num, g_player_ini.audio_filter_custom_ext_num )
248                 for (i=0; i<MM_AUDIO_FILTER_CUSTOM_NUM; i++)
249                 {
250                         debug_log("aaudio_filter_custom_level_min_max_list : min(%d), max(%d)\n", g_player_ini.audio_filter_custom_min_level_list[i], g_player_ini.audio_filter_custom_max_level_list[i]);
251                 }
252 #endif
253
254                 /* http streaming */
255                 MMPLAYER_INI_GET_STRING( g_player_ini.name_of_httpsrc, "http streaming:httpsrc element", DEFAULT_HTTPSRC );
256                 MMPLAYER_INI_GET_STRING( g_player_ini.http_file_buffer_path, "http streaming:http file buffer path", DEFAULT_HTTP_FILE_BUFFER_PATH );
257                 g_player_ini.http_buffering_limit = iniparser_getdouble(dict, "http streaming:http buffering high limit", DEFAULT_HTTP_BUFFERING_LIMIT);
258                 g_player_ini.http_max_size_bytes = iniparser_getint(dict, "http streaming:http max size bytes", DEFAULT_HTTP_MAX_SIZE_BYTES);
259                 g_player_ini.http_buffering_time = iniparser_getdouble(dict, "http streaming:http buffering time", DEFAULT_HTTP_BUFFERING_TIME);                
260                 g_player_ini.http_timeout = iniparser_getint(dict, "http streaming:http timeout", DEFAULT_HTTP_TIMEOUT);
261
262                 /* rtsp streaming */
263                 MMPLAYER_INI_GET_STRING( g_player_ini.name_of_rtspsrc, "rtsp streaming:rtspsrc element", DEFAULT_RTSPSRC );
264                 g_player_ini.rtsp_buffering_time = iniparser_getint(dict, "rtsp streaming:rtsp buffering time", DEFAULT_RTSP_BUFFERING);
265                 g_player_ini.rtsp_rebuffering_time = iniparser_getint(dict, "rtsp streaming:rtsp rebuffering time", DEFAULT_RTSP_REBUFFERING);
266                 g_player_ini.rtsp_do_typefinding = iniparser_getboolean(dict, "rtsp streaming:rtsp do typefinding", DEFAULT_RTSP_DO_TYPEFINDING);
267                 g_player_ini.rtsp_error_concealment = iniparser_getboolean(dict, "rtsp streaming:rtsp error concealment", DEFAULT_RTSP_ERROR_CONCEALMENT);
268         }       
269         else /* if dict is not available just fill the structure with default value */
270         {
271                 debug_warning("failed to load ini. using hardcoded default\n");
272
273                 /* general */
274                 g_player_ini.use_decodebin = DEFAULT_USE_DECODEBIN;
275                 g_player_ini.disable_segtrap = DEFAULT_DISABLE_SEGTRAP;
276                 g_player_ini.use_audio_filter_preset = DEFAULT_USE_AUDIO_FILTER_PRESET;
277                 g_player_ini.use_audio_filter_custom = DEFAULT_USE_AUDIO_FILTER_CUSTOM;
278                 g_player_ini.skip_rescan = DEFAULT_SKIP_RESCAN;
279                 g_player_ini.video_surface = DEFAULT_VIDEO_SURFACE;
280                 strncpy( g_player_ini.videosink_element_x, DEFAULT_VIDEOSINK_X, PLAYER_INI_MAX_STRLEN - 1 );
281                 strncpy( g_player_ini.videosink_element_evas, DEFAULT_VIDEOSINK_EVAS, PLAYER_INI_MAX_STRLEN - 1 );
282                 strncpy( g_player_ini.videosink_element_fake, DEFAULT_VIDEOSINK_FAKE, PLAYER_INI_MAX_STRLEN - 1 );
283                 g_player_ini.generate_dot = DEFAULT_GENERATE_DOT;
284                 g_player_ini.provide_clock= DEFAULT_PROVIDE_CLOCK;
285                 g_player_ini.live_state_change_timeout = DEFAULT_LIVE_STATE_CHANGE_TIMEOUT;
286                 g_player_ini.localplayback_state_change_timeout = DEFAULT_LOCALPLAYBACK_STATE_CHANGE_TIMEOUT;
287                 g_player_ini.eos_delay = DEFAULT_EOS_DELAY;
288                 g_player_ini.multiple_codec_supported = DEFAULT_MULTIPLE_CODEC_SUPPORTED;
289                 g_player_ini.async_start = DEFAULT_ASYNC_START;
290                 g_player_ini.delay_before_repeat = DEFAULT_DELAY_BEFORE_REPEAT;
291
292
293                 strncpy( g_player_ini.name_of_drmsrc, DEFAULT_DRMSRC, PLAYER_INI_MAX_STRLEN - 1 );
294                 strncpy( g_player_ini.name_of_audiosink, DEFAULT_AUDIOSINK, PLAYER_INI_MAX_STRLEN -1 );
295                 strncpy( g_player_ini.name_of_video_converter, DEFAULT_VIDEO_CONVERTER, PLAYER_INI_MAX_STRLEN -1 );
296
297                 {
298                         __get_string_list( (gchar**) g_player_ini.exclude_element_keyword, DEFAULT_EXCLUDE_KEYWORD);
299                 }
300
301
302                 strncpy( g_player_ini.gst_param[0], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
303                 strncpy( g_player_ini.gst_param[1], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
304                 strncpy( g_player_ini.gst_param[2], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
305                 strncpy( g_player_ini.gst_param[3], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
306                 strncpy( g_player_ini.gst_param[4], DEFAULT_GST_PARAM, PLAYER_INI_MAX_PARAM_STRLEN - 1 );
307
308                 /* http streaming */
309                 strncpy( g_player_ini.name_of_httpsrc, DEFAULT_HTTPSRC, PLAYER_INI_MAX_STRLEN - 1 );
310                 strncpy( g_player_ini.http_file_buffer_path, DEFAULT_HTTP_FILE_BUFFER_PATH, PLAYER_INI_MAX_STRLEN - 1 );
311                 g_player_ini.http_buffering_limit = DEFAULT_HTTP_BUFFERING_LIMIT;
312                 g_player_ini.http_max_size_bytes = DEFAULT_HTTP_MAX_SIZE_BYTES;
313                 g_player_ini.http_buffering_time = DEFAULT_HTTP_BUFFERING_TIME;         
314                 g_player_ini.http_timeout = DEFAULT_HTTP_TIMEOUT;
315                 
316                 /* rtsp streaming */
317                 strncpy( g_player_ini.name_of_rtspsrc, DEFAULT_RTSPSRC, PLAYER_INI_MAX_STRLEN - 1 );
318                 g_player_ini.rtsp_buffering_time = DEFAULT_RTSP_BUFFERING;
319                 g_player_ini.rtsp_rebuffering_time = DEFAULT_RTSP_REBUFFERING;
320                 g_player_ini.rtsp_do_typefinding = DEFAULT_RTSP_DO_TYPEFINDING;
321                 g_player_ini.rtsp_error_concealment = DEFAULT_RTSP_ERROR_CONCEALMENT;
322         }
323
324         /* free dict as we got our own structure */
325         iniparser_freedict (dict);
326
327         loaded = TRUE;
328
329         /* The simulator uses a separate ini file. */
330         //__mm_player_ini_force_setting();
331
332
333         /* dump structure */
334         debug_log("player settings -----------------------------------\n");
335
336         /* general */
337         debug_log("use_decodebin : %d\n", g_player_ini.use_decodebin);
338         debug_log("use_audio_filter_preset : %d\n", g_player_ini.use_audio_filter_preset);
339         debug_log("use_audio_filter_custom : %d\n", g_player_ini.use_audio_filter_custom);
340         debug_log("disable_segtrap : %d\n", g_player_ini.disable_segtrap);
341         debug_log("skip rescan : %d\n", g_player_ini.skip_rescan);
342         debug_log("video surface(0:X, 1:EVAS, 2:GL, 3:NULL) : %d\n", g_player_ini.video_surface);
343         debug_log("videosink element x: %s\n", g_player_ini.videosink_element_x);
344         debug_log("videosink element evas: %s\n", g_player_ini.videosink_element_evas);
345         debug_log("videosink element fake: %s\n", g_player_ini.videosink_element_fake);
346         debug_log("generate_dot : %d\n", g_player_ini.generate_dot);
347         debug_log("provide_clock : %d\n", g_player_ini.provide_clock);
348         debug_log("live_state_change_timeout(sec) : %d\n", g_player_ini.live_state_change_timeout);
349         debug_log("localplayback_state_change_timeout(sec) : %d\n", g_player_ini.localplayback_state_change_timeout);   
350         debug_log("eos_delay(msec) : %d\n", g_player_ini.eos_delay);
351         debug_log("delay_before_repeat(msec) : %d\n", g_player_ini.delay_before_repeat);
352         debug_log("name_of_drmsrc : %s\n", g_player_ini.name_of_drmsrc);
353         debug_log("name_of_audiosink : %s\n", g_player_ini.name_of_audiosink);
354         debug_log("name_of_video_converter : %s\n", g_player_ini.name_of_video_converter);
355         debug_log("async_start : %d\n", g_player_ini.async_start);
356         debug_log("multiple_codec_supported : %d\n", g_player_ini.multiple_codec_supported);    
357
358         debug_log("gst_param1 : %s\n", g_player_ini.gst_param[0]);
359         debug_log("gst_param2 : %s\n", g_player_ini.gst_param[1]);
360         debug_log("gst_param3 : %s\n", g_player_ini.gst_param[2]);
361         debug_log("gst_param4 : %s\n", g_player_ini.gst_param[3]);
362         debug_log("gst_param5 : %s\n", g_player_ini.gst_param[4]);
363
364         for ( idx = 0; g_player_ini.exclude_element_keyword[idx][0] != '\0'; idx++ )
365         {
366                 debug_log("exclude_element_keyword [%d] : %s\n", idx, g_player_ini.exclude_element_keyword[idx]);
367         }
368         
369         /* http streaming */
370         debug_log("name_of_httpsrc : %s\n", g_player_ini.name_of_httpsrc);
371         debug_log("http_file_buffer_path : %s \n", g_player_ini.http_file_buffer_path);
372         debug_log("http_buffering_limit : %f \n", g_player_ini.http_buffering_limit);
373         debug_log("http_max_size_bytes : %d \n", g_player_ini.http_max_size_bytes);
374         debug_log("http_buffering_time : %f \n", g_player_ini.http_buffering_time);
375         debug_log("http_timeout : %d \n", g_player_ini.http_timeout);
376         
377         /* rtsp streaming */
378         debug_log("name_of_rtspsrc : %s\n", g_player_ini.name_of_rtspsrc);
379         debug_log("rtsp_buffering_time(msec) : %d\n", g_player_ini.rtsp_buffering_time);
380         debug_log("rtsp_rebuffering_time(msec) : %d\n", g_player_ini.rtsp_rebuffering_time);
381         debug_log("rtsp_do_typefinding : %d \n", g_player_ini.rtsp_do_typefinding);
382         debug_log("rtsp_error_concealment : %d \n", g_player_ini.rtsp_error_concealment);
383
384         debug_log("---------------------------------------------------\n");     
385
386         return MM_ERROR_NONE;
387 }
388
389
390 static
391 void __mm_player_ini_check_ini_status(void)
392 {
393         struct stat ini_buff;
394         
395         if ( g_stat(MM_PLAYER_INI_DEFAULT_PATH, &ini_buff) < 0 )
396         {
397                 debug_warning("failed to get player ini status\n");
398         }
399         else
400         {
401                 if ( ini_buff.st_size < 5 )
402                 {
403                         debug_warning("player.ini file size=%d, Corrupted! So, Removed\n", (int)ini_buff.st_size);
404                         
405                         g_remove( MM_PLAYER_INI_DEFAULT_PATH );
406                 }
407         }
408 }
409
410 #if 0
411 static 
412 void __mm_player_ini_force_setting(void)
413 {
414         //TODO:IF NEEDED
415 }
416 #endif
417
418 mm_player_ini_t* 
419 mm_player_ini_get_structure(void)
420 {
421         return &g_player_ini;
422 }
423
424 static 
425 gboolean __generate_default_ini(void)
426 {
427         FILE* fp = NULL;
428         gchar* default_ini = MM_PLAYER_DEFAULT_INI;
429
430
431         /* create new file */
432         fp = fopen(MM_PLAYER_INI_DEFAULT_PATH, "wt");
433
434         if ( !fp )
435         {
436                 return FALSE;
437         }
438
439         /* writing default ini file */
440         if ( strlen(default_ini) != fwrite(default_ini, 1, strlen(default_ini), fp) )
441         {
442                 fclose(fp);
443                 return FALSE;
444         }
445
446         fclose(fp);
447         return TRUE;
448 }
449
450 static 
451 void    __get_string_list(gchar** out_list, gchar* str)
452 {
453         gchar** list = NULL;
454         gchar** walk = NULL;
455         gint i = 0;
456         gchar* strtmp = NULL;
457
458
459         if ( ! str )
460                 return;
461
462         if ( strlen( str ) < 1 )
463                 return;
464
465         strtmp = g_strdup (str);
466
467         /* trimming. it works inplace */
468         g_strstrip( strtmp );
469
470
471         /* split */
472         list = g_strsplit( strtmp, ",", 10 );
473
474         if ( !list )
475         {
476                 if (strtmp)
477                         g_free(strtmp);
478
479                 return;
480         }
481
482         /* copy list */
483         for( walk = list; *walk; walk++ )
484         {
485                 strncpy( g_player_ini.exclude_element_keyword[i], *walk, (PLAYER_INI_MAX_STRLEN - 1) );
486
487                 g_strstrip( g_player_ini.exclude_element_keyword[i] );
488
489                 g_player_ini.exclude_element_keyword[i][PLAYER_INI_MAX_STRLEN - 1] = '\0';
490
491                 i++;
492         }
493
494         /* mark last item to NULL */
495         g_player_ini.exclude_element_keyword[i][0] = '\0';
496
497         g_strfreev( list );
498         if (strtmp)
499                 g_free (strtmp);
500 }
501
502 #endif
503
504
505