mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-13 16:03:23 -05:00
add -a switch for mac .app bundle
This commit is contained in:
parent
d4b78197b2
commit
a1e2bc3799
26
src/conf.c
26
src/conf.c
@ -75,6 +75,7 @@ static pthread_mutex_t conf_mutex = PTHREAD_MUTEX_INITIALIZER;
|
|||||||
#define CONF_T_STRING 1
|
#define CONF_T_STRING 1
|
||||||
#define CONF_T_EXISTPATH 2 /** a path that must exist */
|
#define CONF_T_EXISTPATH 2 /** a path that must exist */
|
||||||
#define CONF_T_MULTICOMMA 3 /** multiple entries separated by commas */
|
#define CONF_T_MULTICOMMA 3 /** multiple entries separated by commas */
|
||||||
|
#define CONF_T_MULTIPATH 4 /** multiple comma separated paths */
|
||||||
|
|
||||||
typedef struct _CONF_ELEMENTS {
|
typedef struct _CONF_ELEMENTS {
|
||||||
int required;
|
int required;
|
||||||
@ -104,7 +105,7 @@ static CONF_ELEMENTS conf_elements[] = {
|
|||||||
{ 1, 0, CONF_T_EXISTPATH,"general","web_root" },
|
{ 1, 0, CONF_T_EXISTPATH,"general","web_root" },
|
||||||
{ 0, 0, CONF_T_INT,"general","port" },
|
{ 0, 0, CONF_T_INT,"general","port" },
|
||||||
{ 0, 0, CONF_T_STRING,"general","admin_pw" },
|
{ 0, 0, CONF_T_STRING,"general","admin_pw" },
|
||||||
{ 1, 0, CONF_T_MULTICOMMA,"general","mp3_dir" },
|
{ 1, 0, CONF_T_MULTIPATH,"general","mp3_dir" },
|
||||||
{ 0, 1, CONF_T_EXISTPATH,"general","db_dir" },
|
{ 0, 1, CONF_T_EXISTPATH,"general","db_dir" },
|
||||||
{ 0, 0, CONF_T_STRING,"general","db_type" },
|
{ 0, 0, CONF_T_STRING,"general","db_type" },
|
||||||
{ 0, 0, CONF_T_EXISTPATH,"general","db_parms" }, /* this isn't right */
|
{ 0, 0, CONF_T_EXISTPATH,"general","db_parms" }, /* this isn't right */
|
||||||
@ -318,6 +319,8 @@ int _conf_exists(LL_HANDLE pll, char *section, char *key) {
|
|||||||
|
|
||||||
int _conf_verify_element(char *section, char *key, char *value) {
|
int _conf_verify_element(char *section, char *key, char *value) {
|
||||||
CONF_ELEMENTS *pce;
|
CONF_ELEMENTS *pce;
|
||||||
|
int index;
|
||||||
|
char **valuearray;
|
||||||
|
|
||||||
pce = _conf_get_keyinfo(section, key);
|
pce = _conf_get_keyinfo(section, key);
|
||||||
if(!pce) {
|
if(!pce) {
|
||||||
@ -341,6 +344,20 @@ int _conf_verify_element(char *section, char *key, char *value) {
|
|||||||
return CONF_E_SUCCESS;
|
return CONF_E_SUCCESS;
|
||||||
return CONF_E_INTEXPECTED;
|
return CONF_E_INTEXPECTED;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case CONF_T_MULTIPATH:
|
||||||
|
if(_conf_split(value,",",&valuearray) >= 0) {
|
||||||
|
index = 0;
|
||||||
|
while(valuearray[index]) {
|
||||||
|
if(!_conf_existdir(valuearray[index])) {
|
||||||
|
_conf_dispose_split(valuearray);
|
||||||
|
return CONF_E_PATHEXPECTED;
|
||||||
|
}
|
||||||
|
index++;
|
||||||
|
}
|
||||||
|
_conf_dispose_split(valuearray);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
|
||||||
case CONF_T_EXISTPATH:
|
case CONF_T_EXISTPATH:
|
||||||
if(!_conf_existdir(value))
|
if(!_conf_existdir(value))
|
||||||
@ -705,6 +722,7 @@ int conf_read(char *file) {
|
|||||||
key_type = pce->type;
|
key_type = pce->type;
|
||||||
|
|
||||||
switch(key_type) {
|
switch(key_type) {
|
||||||
|
case CONF_T_MULTIPATH:
|
||||||
case CONF_T_MULTICOMMA:
|
case CONF_T_MULTICOMMA:
|
||||||
/* first, see if we already have a tree... */
|
/* first, see if we already have a tree... */
|
||||||
pli = ll_fetch_item(pllcurrent,term);
|
pli = ll_fetch_item(pllcurrent,term);
|
||||||
@ -1024,7 +1042,7 @@ int conf_set_string(char *section, char *key, char *value, int verify) {
|
|||||||
key_type = pce->type;
|
key_type = pce->type;
|
||||||
|
|
||||||
/* apply the config change, if necessary */
|
/* apply the config change, if necessary */
|
||||||
if(key_type != CONF_T_MULTICOMMA) {
|
if((key_type != CONF_T_MULTICOMMA) && (key_type != CONF_T_MULTIPATH)) {
|
||||||
/* let's apply it */
|
/* let's apply it */
|
||||||
polditem = _conf_fetch_item(conf_main,section,key);
|
polditem = _conf_fetch_item(conf_main,section,key);
|
||||||
if(polditem)
|
if(polditem)
|
||||||
@ -1071,7 +1089,7 @@ int conf_set_string(char *section, char *key, char *value, int verify) {
|
|||||||
section_ll = psection->value.as_ll;
|
section_ll = psection->value.as_ll;
|
||||||
}
|
}
|
||||||
/* have the section, now add it */
|
/* have the section, now add it */
|
||||||
if(key_type == CONF_T_MULTICOMMA) {
|
if((key_type == CONF_T_MULTICOMMA) || (key_type == CONF_T_MULTIPATH)) {
|
||||||
if((err = ll_create(&temp_ll)) != LL_E_SUCCESS) {
|
if((err = ll_create(&temp_ll)) != LL_E_SUCCESS) {
|
||||||
DPRINTF(E_FATAL,L_CONF,"conf_set_string: could not create ll\n");
|
DPRINTF(E_FATAL,L_CONF,"conf_set_string: could not create ll\n");
|
||||||
}
|
}
|
||||||
@ -1095,7 +1113,7 @@ int conf_set_string(char *section, char *key, char *value, int verify) {
|
|||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
/* we have the item, let's update it */
|
/* we have the item, let's update it */
|
||||||
if(key_type == CONF_T_MULTICOMMA) {
|
if((key_type == CONF_T_MULTICOMMA) || (key_type = CONF_T_MULTIPATH)) {
|
||||||
/* delete whatever is there, then add from commas */
|
/* delete whatever is there, then add from commas */
|
||||||
ll_destroy(pitem->value.as_ll);
|
ll_destroy(pitem->value.as_ll);
|
||||||
if(ll_create(&pitem->value.as_ll) != LL_E_SUCCESS) {
|
if(ll_create(&pitem->value.as_ll) != LL_E_SUCCESS) {
|
||||||
|
17
src/main.c
17
src/main.c
@ -182,6 +182,7 @@ int main_auth(WS_CONNINFO *pwsc, char *username, char *password) {
|
|||||||
void usage(char *program) {
|
void usage(char *program) {
|
||||||
printf("Usage: %s [options]\n\n",program);
|
printf("Usage: %s [options]\n\n",program);
|
||||||
printf("Options:\n");
|
printf("Options:\n");
|
||||||
|
printf(" -a Set cwd to app dir before starting\n");
|
||||||
printf(" -d <number> Debuglevel (0-9)\n");
|
printf(" -d <number> Debuglevel (0-9)\n");
|
||||||
printf(" -D <mod,mod..> Debug modules\n");
|
printf(" -D <mod,mod..> Debug modules\n");
|
||||||
printf(" -m Disable mDNS\n");
|
printf(" -m Disable mDNS\n");
|
||||||
@ -230,6 +231,7 @@ int main(int argc, char *argv[]) {
|
|||||||
char **mp3_dir_array;
|
char **mp3_dir_array;
|
||||||
char *servername, *iface;
|
char *servername, *iface;
|
||||||
int index;
|
int index;
|
||||||
|
int appdir = 0;
|
||||||
|
|
||||||
char txtrecord[255];
|
char txtrecord[255];
|
||||||
|
|
||||||
@ -239,13 +241,17 @@ int main(int argc, char *argv[]) {
|
|||||||
|
|
||||||
int err;
|
int err;
|
||||||
char *perr=NULL;
|
char *perr=NULL;
|
||||||
|
char *apppath;
|
||||||
|
|
||||||
config.use_mdns=1;
|
config.use_mdns=1;
|
||||||
err_setlevel(1);
|
err_setlevel(1);
|
||||||
|
|
||||||
config.foreground=0;
|
config.foreground=0;
|
||||||
while((option=getopt(argc,argv,"D:d:c:P:mfrysiuv")) != -1) {
|
while((option=getopt(argc,argv,"D:d:c:P:mfrysiuva")) != -1) {
|
||||||
switch(option) {
|
switch(option) {
|
||||||
|
case 'a':
|
||||||
|
appdir = 1;
|
||||||
|
break;
|
||||||
case 'd':
|
case 'd':
|
||||||
err_setlevel(atoi(optarg));
|
err_setlevel(atoi(optarg));
|
||||||
break;
|
break;
|
||||||
@ -318,6 +324,15 @@ int main(int argc, char *argv[]) {
|
|||||||
config.stats.start_time=start_time=(int)time(NULL);
|
config.stats.start_time=start_time=(int)time(NULL);
|
||||||
config.stop=0;
|
config.stop=0;
|
||||||
|
|
||||||
|
/* set appdir first, that way config resolves relative to appdir */
|
||||||
|
if(appdir) {
|
||||||
|
apppath = os_apppath(argv[0]);
|
||||||
|
DPRINTF(E_INF,L_MAIN,"Changing cwd to %s\n",apppath);
|
||||||
|
chdir(apppath);
|
||||||
|
free(apppath);
|
||||||
|
configfile="mt-daapd.conf";
|
||||||
|
}
|
||||||
|
|
||||||
if(conf_read(configfile) != CONF_E_SUCCESS) {
|
if(conf_read(configfile) != CONF_E_SUCCESS) {
|
||||||
fprintf(stderr,"Error reading config file (%s)\n",configfile);
|
fprintf(stderr,"Error reading config file (%s)\n",configfile);
|
||||||
exit(EXIT_FAILURE);
|
exit(EXIT_FAILURE);
|
||||||
|
@ -48,6 +48,10 @@
|
|||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#include <sys/resource.h>
|
#include <sys/resource.h>
|
||||||
|
|
||||||
|
#ifdef MAC
|
||||||
|
#include "CoreFoundation/CoreFoundation.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "conf.h"
|
#include "conf.h"
|
||||||
#include "err.h"
|
#include "err.h"
|
||||||
#include "daapd.h"
|
#include "daapd.h"
|
||||||
@ -466,3 +470,26 @@ int os_islocaladdr(char *hostaddr) {
|
|||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef MAC
|
||||||
|
char *os_apppath(char *parm) {
|
||||||
|
CFURLRef pluginRef = CFBundleCopyBundleURL(CFBundleGetMainBundle());
|
||||||
|
CFStringRef macPath = CFURLCopyFileSystemPath(pluginRef,
|
||||||
|
kCFURLPOSIXPathStyle);
|
||||||
|
const char *pathPtr = CFStringGetCStringPtr(macPath,
|
||||||
|
CFStringGetSystemEncoding());
|
||||||
|
|
||||||
|
return strdup(pathPtr);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
char *os_apppath(char *parm) {
|
||||||
|
char path[MAX_PATH];
|
||||||
|
|
||||||
|
realpath(param,path);
|
||||||
|
if(strrchr(path,'/')) {
|
||||||
|
*strrchr(path,'/') = '/0';
|
||||||
|
}
|
||||||
|
|
||||||
|
return strdup(path);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
@ -627,6 +627,18 @@ char *os_configpath(void) {
|
|||||||
return os_config_file;
|
return os_config_file;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* get the path of the executable. Caller must free.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
char *os_apppath(char *junk) {
|
||||||
|
char app_path[MAX_PATH];
|
||||||
|
|
||||||
|
GetModuleFileName(NULL,app_path,MAX_PATH);
|
||||||
|
return strdup(app_path);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Determine if an address is local or not
|
* Determine if an address is local or not
|
||||||
*
|
*
|
||||||
|
Loading…
Reference in New Issue
Block a user