]> code.delx.au - pulseaudio/blob - src/daemon/daemon-conf.h
* add new --system command line parameter to the daemon for running PulseAudio as...
[pulseaudio] / src / daemon / daemon-conf.h
1 #ifndef foodaemonconfhfoo
2 #define foodaemonconfhfoo
3
4 /* $Id$ */
5
6 /***
7 This file is part of PulseAudio.
8
9 PulseAudio is free software; you can redistribute it and/or modify
10 it under the terms of the GNU Lesser General Public License as published
11 by the Free Software Foundation; either version 2 of the License,
12 or (at your option) any later version.
13
14 PulseAudio is distributed in the hope that it will be useful, but
15 WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 General Public License for more details.
18
19 You should have received a copy of the GNU Lesser General Public License
20 along with PulseAudio; if not, write to the Free Software
21 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
22 USA.
23 ***/
24
25 #include <pulsecore/log.h>
26
27 /* The actual command to execute */
28 typedef enum pa_daemon_conf_cmd {
29 PA_CMD_DAEMON, /* the default */
30 PA_CMD_HELP,
31 PA_CMD_VERSION,
32 PA_CMD_DUMP_CONF,
33 PA_CMD_DUMP_MODULES,
34 PA_CMD_KILL,
35 PA_CMD_CHECK
36 } pa_daemon_conf_cmd_t;
37
38 /* A structure containing configuration data for the PulseAudio server . */
39 typedef struct pa_daemon_conf {
40 pa_daemon_conf_cmd_t cmd;
41 int daemonize,
42 fail,
43 high_priority,
44 disallow_module_loading,
45 exit_idle_time,
46 module_idle_time,
47 scache_idle_time,
48 auto_log_target,
49 use_pid_file,
50 system_instance;
51 char *script_commands, *dl_search_path, *default_script_file;
52 pa_log_target_t log_target;
53 pa_log_level_t log_level;
54 int resample_method;
55 char *config_file;
56 } pa_daemon_conf;
57
58 /* Allocate a new structure and fill it with sane defaults */
59 pa_daemon_conf* pa_daemon_conf_new(void);
60 void pa_daemon_conf_free(pa_daemon_conf*c);
61
62 /* Load configuration data from the specified file overwriting the
63 * current settings in *c. If filename is NULL load the default daemon
64 * configuration file */
65 int pa_daemon_conf_load(pa_daemon_conf *c, const char *filename);
66
67 /* Pretty print the current configuration data of the daemon. The
68 * returned string has to be freed manually. The output of this
69 * function may be parsed with pa_daemon_conf_load(). */
70 char *pa_daemon_conf_dump(pa_daemon_conf *c);
71
72 /* Load the configuration data from the process' environment
73 * overwriting the current settings in *c. */
74 int pa_daemon_conf_env(pa_daemon_conf *c);
75
76 /* Set these configuration variables in the structure by passing a string */
77 int pa_daemon_conf_set_log_target(pa_daemon_conf *c, const char *string);
78 int pa_daemon_conf_set_log_level(pa_daemon_conf *c, const char *string);
79 int pa_daemon_conf_set_resample_method(pa_daemon_conf *c, const char *string);
80
81 #endif