1 #ifndef foodaemonconfhfoo
2 #define foodaemonconfhfoo
7 This file is part of PulseAudio.
9 Copyright 2004-2006 Lennart Poettering
10 Copyright 2006 Pierre Ossman <ossman@cendio.se> for Cendio AB
12 PulseAudio is free software; you can redistribute it and/or modify
13 it under the terms of the GNU Lesser General Public License as published
14 by the Free Software Foundation; either version 2 of the License,
15 or (at your option) any later version.
17 PulseAudio is distributed in the hope that it will be useful, but
18 WITHOUT ANY WARRANTY; without even the implied warranty of
19 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
20 General Public License for more details.
22 You should have received a copy of the GNU Lesser General Public License
23 along with PulseAudio; if not, write to the Free Software
24 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
28 #include <pulsecore/log.h>
30 #ifdef HAVE_SYS_RESOURCE_H
31 #include <sys/resource.h>
34 /* The actual command to execute */
35 typedef enum pa_daemon_conf_cmd {
36 PA_CMD_DAEMON, /* the default */
43 } pa_daemon_conf_cmd_t;
45 #ifdef HAVE_SYS_RESOURCE_H
46 typedef struct pa_rlimit {
52 /* A structure containing configuration data for the PulseAudio server . */
53 typedef struct pa_daemon_conf {
54 pa_daemon_conf_cmd_t cmd;
58 disallow_module_loading,
67 char *script_commands, *dl_search_path, *default_script_file;
68 pa_log_target_t log_target;
69 pa_log_level_t log_level;
73 #ifdef HAVE_SYS_RESOURCE_H
74 pa_rlimit rlimit_as, rlimit_core, rlimit_data, rlimit_fsize, rlimit_nofile, rlimit_stack;
76 pa_rlimit rlimit_nproc;
79 pa_rlimit rlimit_memlock;
85 /* Allocate a new structure and fill it with sane defaults */
86 pa_daemon_conf* pa_daemon_conf_new(void);
87 void pa_daemon_conf_free(pa_daemon_conf*c);
89 /* Load configuration data from the specified file overwriting the
90 * current settings in *c. If filename is NULL load the default daemon
91 * configuration file */
92 int pa_daemon_conf_load(pa_daemon_conf *c, const char *filename);
94 /* Pretty print the current configuration data of the daemon. The
95 * returned string has to be freed manually. The output of this
96 * function may be parsed with pa_daemon_conf_load(). */
97 char *pa_daemon_conf_dump(pa_daemon_conf *c);
99 /* Load the configuration data from the process' environment
100 * overwriting the current settings in *c. */
101 int pa_daemon_conf_env(pa_daemon_conf *c);
103 /* Set these configuration variables in the structure by passing a string */
104 int pa_daemon_conf_set_log_target(pa_daemon_conf *c, const char *string);
105 int pa_daemon_conf_set_log_level(pa_daemon_conf *c, const char *string);
106 int pa_daemon_conf_set_resample_method(pa_daemon_conf *c, const char *string);