1 #ifndef foodaemonconfhfoo
2 #define foodaemonconfhfoo
7 This file is part of PulseAudio.
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.
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.
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
25 #include <pulsecore/log.h>
27 #ifdef HAVE_SYS_RESOURCE_H
28 #include <sys/resource.h>
31 /* The actual command to execute */
32 typedef enum pa_daemon_conf_cmd
{
33 PA_CMD_DAEMON
, /* the default */
40 } pa_daemon_conf_cmd_t
;
42 #ifdef HAVE_SYS_RESOURCE_H
43 typedef struct pa_rlimit
{
49 /* A structure containing configuration data for the PulseAudio server . */
50 typedef struct pa_daemon_conf
{
51 pa_daemon_conf_cmd_t cmd
;
55 disallow_module_loading
,
64 char *script_commands
, *dl_search_path
, *default_script_file
;
65 pa_log_target_t log_target
;
66 pa_log_level_t log_level
;
70 #ifdef HAVE_SYS_RESOURCE_H
71 pa_rlimit rlimit_as
, rlimit_core
, rlimit_data
, rlimit_fsize
, rlimit_nofile
, rlimit_stack
;
73 pa_rlimit rlimit_nproc
;
76 pa_rlimit rlimit_memlock
;
82 /* Allocate a new structure and fill it with sane defaults */
83 pa_daemon_conf
* pa_daemon_conf_new(void);
84 void pa_daemon_conf_free(pa_daemon_conf
*c
);
86 /* Load configuration data from the specified file overwriting the
87 * current settings in *c. If filename is NULL load the default daemon
88 * configuration file */
89 int pa_daemon_conf_load(pa_daemon_conf
*c
, const char *filename
);
91 /* Pretty print the current configuration data of the daemon. The
92 * returned string has to be freed manually. The output of this
93 * function may be parsed with pa_daemon_conf_load(). */
94 char *pa_daemon_conf_dump(pa_daemon_conf
*c
);
96 /* Load the configuration data from the process' environment
97 * overwriting the current settings in *c. */
98 int pa_daemon_conf_env(pa_daemon_conf
*c
);
100 /* Set these configuration variables in the structure by passing a string */
101 int pa_daemon_conf_set_log_target(pa_daemon_conf
*c
, const char *string
);
102 int pa_daemon_conf_set_log_level(pa_daemon_conf
*c
, const char *string
);
103 int pa_daemon_conf_set_resample_method(pa_daemon_conf
*c
, const char *string
);