#include <sys/stat.h>
#include <pthread.h>
+#include "main.h"
#include "utils.h"
+#include "json.h"
#include <ucx/map.h>
#include <ucx/properties.h>
+#include <ucx/buffer.h>
+#include <ucx/utils.h>
#define CONFIG_BASE_DIR ".config"
#define UWP_CONFIG_DIR "uwplayer"
-#define UWP_CONFIG_FILE "uwplayer.properties"
+#define UWP_CONFIG_FILE "uwplayer.conf"
+
+#define JS_READ_BUFSIZE 4096
static void* player_bin_search_thread(void *data);
+static void conf_load_global_settings(void);
static char *uwp_config_dir;
+
+/*
+ * root json config object
+ */
+static JSONObject *uwp_config;
+
+/*
+ * global settings from json config converted to key/value pairs
+ */
static UcxMap *uwp_settings;
+/*
+ * default settings
+ */
+static UcxMap *uwp_default;
+
static int check_config_dir(void) {
char *home = getenv("HOME");
if(!home) {
return ret;
}
-int load_settings(void) {
+int load_config(void) {
if(check_config_dir()) {
return 1;
}
uwp_settings = ucx_map_new(16);
+ uwp_default = ucx_map_new(32);
char *cfgfile_path = util_concat_path(uwp_config_dir, UWP_CONFIG_FILE);
FILE *cfgfile = fopen(cfgfile_path, "r");
free(cfgfile_path);
- if(!cfgfile) return 0;
int ret = 0;
- if(ucx_properties_load(uwp_settings, cfgfile)) {
- fprintf(stderr, "Error: Cannot read uwplayer settings\n");
- ret = 1;
- }
- fclose(cfgfile);
-
- if(ret) {
- return ret;
+ if(cfgfile) {
+ JSONParser *parser = json_parser_new();
+
+ JSONValue *value = NULL;
+ char buf[JS_READ_BUFSIZE];
+ size_t r;
+
+ while((ret = json_read_value(parser, &value)) >= 0) {
+ if(ret == 0) {
+ r = fread(buf, 1, JS_READ_BUFSIZE, cfgfile);
+ if(r == 0) {
+ break;
+ }
+ json_parser_fill(parser, buf, r);
+ } else {
+ break;
+ }
+ }
+
+ json_parser_free(parser);
+
+ if(value) {
+ if(value->type == JSON_OBJECT) {
+ ret = 0;
+ uwp_config = &value->value.object;
+ conf_load_global_settings();
+ } else {
+ ret = 1;
+ }
+ } else {
+ ret = 1;
+ }
+
+
+ fclose(cfgfile);
+
+ if(ret) {
+ return ret;
+ }
}
+
// check if mpv or mplayer binaries are configured
char *player_bin = ucx_map_cstr_get(uwp_settings, UWP_PLAYER_BIN);
return 0;
}
+static void conf_load_global_settings(void) {
+ JSONValue *settings = json_obj_get(uwp_config, "settings");
+ if(!settings) {
+ return;
+ }
+
+ if(settings->type != JSON_OBJECT) {
+ fprintf(stderr, "Warning: 'settings' not an object\n");
+ return;
+ }
+
+ JSONObject *s = &settings->value.object;
+
+ for(size_t i=0;i<s->size;i++) {
+ JSONObjValue *gs = &s->values[i];
+ if(gs->value->type == JSON_STRING) {
+ ucx_map_cstr_put(uwp_settings, gs->name, gs->value->value.string.string);
+ }
+ }
+}
+
+static char* get_which_output(FILE *f, UcxBuffer *buf) {
+ buf->pos = 0;
+ buf->size = 0;
+ ucx_stream_copy(f, buf, (read_func)fread, (write_func)ucx_buffer_write);
+ if(!pclose(f)) {
+ ucx_buffer_putc(buf, 0);
+ size_t i;
+ for(i=0;i<buf->pos;i++) {
+ if(buf->space[i] == '\n') {
+ buf->space[i] = 0;
+ break;
+ }
+ }
+ return buf->space;
+ }
+ return NULL;
+}
+
+static Boolean finish_bin_search(XtPointer data) {
+ PlayerInfo *playerInfo = data;
+ ucx_map_cstr_put(uwp_settings, UWP_PLAYER_BIN, playerInfo->bin);
+ ucx_map_cstr_put(uwp_settings, UWP_PLAYER_TYPE, playerInfo->type);
+ free(playerInfo);
+ return 0;
+}
+
static void* player_bin_search_thread(void *data) {
- // TODO:
- //printf("search\n");
+ UcxBuffer *buf = ucx_buffer_new(NULL, 256, UCX_BUFFER_AUTOEXTEND);
+
+ FILE *f = popen("which mpv", "r");
+ if(f) {
+ char *bin = get_which_output(f, buf);
+ if(bin) {
+ PlayerInfo *playerInfo = malloc(sizeof(PlayerInfo));
+ playerInfo->bin = strdup(bin);
+ playerInfo->type = strdup("mpv");
+ AppExecProc(finish_bin_search, playerInfo);
+
+ ucx_buffer_free(buf);
+ return NULL;
+ }
+ }
+ f = popen("which mplayer", "r");
+ if(f) {
+ char *bin = get_which_output(f, buf);
+ if(bin) {
+ PlayerInfo *playerInfo = malloc(sizeof(PlayerInfo));
+ playerInfo->bin = strdup(bin);
+ playerInfo->type = strdup("mplayer");
+ AppExecProc(finish_bin_search, playerInfo);
+ }
+ }
+
+ ucx_buffer_free(buf);
return NULL;
}
+
+char* SettingsGetPlayerBin(void) {
+ return ucx_map_cstr_get(uwp_settings, UWP_PLAYER_BIN);
+}