]> code.delx.au - pulseaudio/blob - src/daemon/cmdline.c
client-conf: Remove redundant function parameters
[pulseaudio] / src / daemon / cmdline.c
1 /***
2 This file is part of PulseAudio.
3
4 Copyright 2004-2006 Lennart Poettering
5
6 PulseAudio is free software; you can redistribute it and/or modify
7 it under the terms of the GNU Lesser General Public License as published
8 by the Free Software Foundation; either version 2.1 of the License,
9 or (at your option) any later version.
10
11 PulseAudio is distributed in the hope that it will be useful, but
12 WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 General Public License for more details.
15
16 You should have received a copy of the GNU Lesser General Public License
17 along with PulseAudio; if not, write to the Free Software
18 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19 USA.
20 ***/
21
22 #ifdef HAVE_CONFIG_H
23 #include <config.h>
24 #endif
25
26 #include <stdlib.h>
27 #include <stdio.h>
28 #include <getopt.h>
29
30 #include <pulse/xmalloc.h>
31 #include <pulse/util.h>
32
33 #include <pulsecore/core-util.h>
34 #include <pulsecore/i18n.h>
35 #include <pulsecore/strbuf.h>
36 #include <pulsecore/macro.h>
37
38 #include "cmdline.h"
39
40 /* Argument codes for getopt_long() */
41 enum {
42 ARG_HELP = 256,
43 ARG_VERSION,
44 ARG_DUMP_CONF,
45 ARG_DUMP_MODULES,
46 ARG_DAEMONIZE,
47 ARG_FAIL,
48 ARG_LOG_LEVEL,
49 ARG_HIGH_PRIORITY,
50 ARG_REALTIME,
51 ARG_DISALLOW_MODULE_LOADING,
52 ARG_DISALLOW_EXIT,
53 ARG_EXIT_IDLE_TIME,
54 ARG_SCACHE_IDLE_TIME,
55 ARG_LOG_TARGET,
56 ARG_LOG_META,
57 ARG_LOG_TIME,
58 ARG_LOG_BACKTRACE,
59 ARG_LOAD,
60 ARG_FILE,
61 ARG_DL_SEARCH_PATH,
62 ARG_RESAMPLE_METHOD,
63 ARG_KILL,
64 ARG_USE_PID_FILE,
65 ARG_CHECK,
66 ARG_NO_CPU_LIMIT,
67 ARG_DISABLE_SHM,
68 ARG_DUMP_RESAMPLE_METHODS,
69 ARG_SYSTEM,
70 ARG_CLEANUP_SHM,
71 ARG_START
72 };
73
74 /* Table for getopt_long() */
75 static const struct option long_options[] = {
76 {"help", 0, 0, ARG_HELP},
77 {"version", 0, 0, ARG_VERSION},
78 {"dump-conf", 0, 0, ARG_DUMP_CONF},
79 {"dump-modules", 0, 0, ARG_DUMP_MODULES},
80 {"daemonize", 2, 0, ARG_DAEMONIZE},
81 {"fail", 2, 0, ARG_FAIL},
82 {"verbose", 2, 0, ARG_LOG_LEVEL},
83 {"log-level", 2, 0, ARG_LOG_LEVEL},
84 {"high-priority", 2, 0, ARG_HIGH_PRIORITY},
85 {"realtime", 2, 0, ARG_REALTIME},
86 {"disallow-module-loading", 2, 0, ARG_DISALLOW_MODULE_LOADING},
87 {"disallow-exit", 2, 0, ARG_DISALLOW_EXIT},
88 {"exit-idle-time", 1, 0, ARG_EXIT_IDLE_TIME},
89 {"scache-idle-time", 1, 0, ARG_SCACHE_IDLE_TIME},
90 {"log-target", 1, 0, ARG_LOG_TARGET},
91 {"log-meta", 2, 0, ARG_LOG_META},
92 {"log-time", 2, 0, ARG_LOG_TIME},
93 {"log-backtrace", 1, 0, ARG_LOG_BACKTRACE},
94 {"load", 1, 0, ARG_LOAD},
95 {"file", 1, 0, ARG_FILE},
96 {"dl-search-path", 1, 0, ARG_DL_SEARCH_PATH},
97 {"resample-method", 1, 0, ARG_RESAMPLE_METHOD},
98 {"kill", 0, 0, ARG_KILL},
99 {"start", 0, 0, ARG_START},
100 {"use-pid-file", 2, 0, ARG_USE_PID_FILE},
101 {"check", 0, 0, ARG_CHECK},
102 {"system", 2, 0, ARG_SYSTEM},
103 {"no-cpu-limit", 2, 0, ARG_NO_CPU_LIMIT},
104 {"disable-shm", 2, 0, ARG_DISABLE_SHM},
105 {"dump-resample-methods", 2, 0, ARG_DUMP_RESAMPLE_METHODS},
106 {"cleanup-shm", 2, 0, ARG_CLEANUP_SHM},
107 {NULL, 0, 0, 0}
108 };
109
110 void pa_cmdline_help(const char *argv0) {
111 pa_assert(argv0);
112
113 printf(_("%s [options]\n\n"
114 "COMMANDS:\n"
115 " -h, --help Show this help\n"
116 " --version Show version\n"
117 " --dump-conf Dump default configuration\n"
118 " --dump-modules Dump list of available modules\n"
119 " --dump-resample-methods Dump available resample methods\n"
120 " --cleanup-shm Cleanup stale shared memory segments\n"
121 " --start Start the daemon if it is not running\n"
122 " -k --kill Kill a running daemon\n"
123 " --check Check for a running daemon (only returns exit code)\n\n"
124
125 "OPTIONS:\n"
126 " --system[=BOOL] Run as system-wide instance\n"
127 " -D, --daemonize[=BOOL] Daemonize after startup\n"
128 " --fail[=BOOL] Quit when startup fails\n"
129 " --high-priority[=BOOL] Try to set high nice level\n"
130 " (only available as root, when SUID or\n"
131 " with elevated RLIMIT_NICE)\n"
132 " --realtime[=BOOL] Try to enable realtime scheduling\n"
133 " (only available as root, when SUID or\n"
134 " with elevated RLIMIT_RTPRIO)\n"
135 " --disallow-module-loading[=BOOL] Disallow module user requested module\n"
136 " loading/unloading after startup\n"
137 " --disallow-exit[=BOOL] Disallow user requested exit\n"
138 " --exit-idle-time=SECS Terminate the daemon when idle and this\n"
139 " time passed\n"
140 " --scache-idle-time=SECS Unload autoloaded samples when idle and\n"
141 " this time passed\n"
142 " --log-level[=LEVEL] Increase or set verbosity level\n"
143 " -v --verbose Increase the verbosity level\n"
144 " --log-target={auto,syslog,stderr,file:PATH,newfile:PATH}\n"
145 " Specify the log target\n"
146 " --log-meta[=BOOL] Include code location in log messages\n"
147 " --log-time[=BOOL] Include timestamps in log messages\n"
148 " --log-backtrace=FRAMES Include a backtrace in log messages\n"
149 " -p, --dl-search-path=PATH Set the search path for dynamic shared\n"
150 " objects (plugins)\n"
151 " --resample-method=METHOD Use the specified resampling method\n"
152 " (See --dump-resample-methods for\n"
153 " possible values)\n"
154 " --use-pid-file[=BOOL] Create a PID file\n"
155 " --no-cpu-limit[=BOOL] Do not install CPU load limiter on\n"
156 " platforms that support it.\n"
157 " --disable-shm[=BOOL] Disable shared memory support.\n\n"
158
159 "STARTUP SCRIPT:\n"
160 " -L, --load=\"MODULE ARGUMENTS\" Load the specified plugin module with\n"
161 " the specified argument\n"
162 " -F, --file=FILENAME Run the specified script\n"
163 " -C Open a command line on the running TTY\n"
164 " after startup\n\n"
165
166 " -n Don't load default script file\n"),
167 pa_path_get_filename(argv0));
168 }
169
170 int pa_cmdline_parse(pa_daemon_conf *conf, int argc, char *const argv [], int *d) {
171 pa_strbuf *buf = NULL;
172 int c;
173 int b;
174
175 pa_assert(conf);
176 pa_assert(argc > 0);
177 pa_assert(argv);
178
179 buf = pa_strbuf_new();
180
181 if (conf->script_commands)
182 pa_strbuf_puts(buf, conf->script_commands);
183
184 while ((c = getopt_long(argc, argv, "L:F:ChDnp:kv", long_options, NULL)) != -1) {
185 switch (c) {
186 case ARG_HELP:
187 case 'h':
188 conf->cmd = PA_CMD_HELP;
189 break;
190
191 case ARG_VERSION:
192 conf->cmd = PA_CMD_VERSION;
193 break;
194
195 case ARG_DUMP_CONF:
196 conf->cmd = PA_CMD_DUMP_CONF;
197 break;
198
199 case ARG_DUMP_MODULES:
200 conf->cmd = PA_CMD_DUMP_MODULES;
201 break;
202
203 case ARG_DUMP_RESAMPLE_METHODS:
204 conf->cmd = PA_CMD_DUMP_RESAMPLE_METHODS;
205 break;
206
207 case ARG_CLEANUP_SHM:
208 conf->cmd = PA_CMD_CLEANUP_SHM;
209 break;
210
211 case 'k':
212 case ARG_KILL:
213 conf->cmd = PA_CMD_KILL;
214 break;
215
216 case ARG_START:
217 conf->cmd = PA_CMD_START;
218 conf->daemonize = true;
219 break;
220
221 case ARG_CHECK:
222 conf->cmd = PA_CMD_CHECK;
223 break;
224
225 case ARG_LOAD:
226 case 'L':
227 pa_strbuf_printf(buf, "load-module %s\n", optarg);
228 break;
229
230 case ARG_FILE:
231 case 'F': {
232 char *p;
233 pa_strbuf_printf(buf, ".include %s\n", p = pa_make_path_absolute(optarg));
234 pa_xfree(p);
235 break;
236 }
237
238 case 'C':
239 pa_strbuf_puts(buf, "load-module module-cli exit_on_eof=1\n");
240 break;
241
242 case ARG_DAEMONIZE:
243 case 'D':
244 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
245 pa_log(_("--daemonize expects boolean argument"));
246 goto fail;
247 }
248 conf->daemonize = !!b;
249 break;
250
251 case ARG_FAIL:
252 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
253 pa_log(_("--fail expects boolean argument"));
254 goto fail;
255 }
256 conf->fail = !!b;
257 break;
258
259 case 'v':
260 case ARG_LOG_LEVEL:
261
262 if (optarg) {
263 if (pa_daemon_conf_set_log_level(conf, optarg) < 0) {
264 pa_log(_("--log-level expects log level argument (either numeric in range 0..4 or one of debug, info, notice, warn, error)."));
265 goto fail;
266 }
267 } else {
268 if (conf->log_level < PA_LOG_LEVEL_MAX-1)
269 conf->log_level++;
270 }
271
272 break;
273
274 case ARG_HIGH_PRIORITY:
275 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
276 pa_log(_("--high-priority expects boolean argument"));
277 goto fail;
278 }
279 conf->high_priority = !!b;
280 break;
281
282 case ARG_REALTIME:
283 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
284 pa_log(_("--realtime expects boolean argument"));
285 goto fail;
286 }
287 conf->realtime_scheduling = !!b;
288 break;
289
290 case ARG_DISALLOW_MODULE_LOADING:
291 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
292 pa_log(_("--disallow-module-loading expects boolean argument"));
293 goto fail;
294 }
295 conf->disallow_module_loading = !!b;
296 break;
297
298 case ARG_DISALLOW_EXIT:
299 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
300 pa_log(_("--disallow-exit expects boolean argument"));
301 goto fail;
302 }
303 conf->disallow_exit = !!b;
304 break;
305
306 case ARG_USE_PID_FILE:
307 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
308 pa_log(_("--use-pid-file expects boolean argument"));
309 goto fail;
310 }
311 conf->use_pid_file = !!b;
312 break;
313
314 case 'p':
315 case ARG_DL_SEARCH_PATH:
316 pa_xfree(conf->dl_search_path);
317 conf->dl_search_path = *optarg ? pa_xstrdup(optarg) : NULL;
318 break;
319
320 case 'n':
321 conf->load_default_script_file = false;
322 break;
323
324 case ARG_LOG_TARGET:
325 if (pa_daemon_conf_set_log_target(conf, optarg) < 0) {
326 #ifdef HAVE_JOURNAL
327 pa_log(_("Invalid log target: use either 'syslog', 'journal','stderr' or 'auto' or a valid file name 'file:<path>', 'newfile:<path>'."));
328 #else
329 pa_log(_("Invalid log target: use either 'syslog', 'stderr' or 'auto' or a valid file name 'file:<path>', 'newfile:<path>'."));
330 #endif
331 goto fail;
332 }
333 break;
334
335 case ARG_LOG_TIME:
336 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
337 pa_log(_("--log-time expects boolean argument"));
338 goto fail;
339 }
340 conf->log_time = !!b;
341 break;
342
343 case ARG_LOG_META:
344 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
345 pa_log(_("--log-meta expects boolean argument"));
346 goto fail;
347 }
348 conf->log_meta = !!b;
349 break;
350
351 case ARG_LOG_BACKTRACE:
352 conf->log_backtrace = (unsigned) atoi(optarg);
353 break;
354
355 case ARG_EXIT_IDLE_TIME:
356 conf->exit_idle_time = atoi(optarg);
357 break;
358
359 case ARG_SCACHE_IDLE_TIME:
360 conf->scache_idle_time = atoi(optarg);
361 break;
362
363 case ARG_RESAMPLE_METHOD:
364 if (pa_daemon_conf_set_resample_method(conf, optarg) < 0) {
365 pa_log(_("Invalid resample method '%s'."), optarg);
366 goto fail;
367 }
368 break;
369
370 case ARG_SYSTEM:
371 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
372 pa_log(_("--system expects boolean argument"));
373 goto fail;
374 }
375 conf->system_instance = !!b;
376 break;
377
378 case ARG_NO_CPU_LIMIT:
379 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
380 pa_log(_("--no-cpu-limit expects boolean argument"));
381 goto fail;
382 }
383 conf->no_cpu_limit = !!b;
384 break;
385
386 case ARG_DISABLE_SHM:
387 if ((b = optarg ? pa_parse_boolean(optarg) : 1) < 0) {
388 pa_log(_("--disable-shm expects boolean argument"));
389 goto fail;
390 }
391 conf->disable_shm = !!b;
392 break;
393
394 default:
395 goto fail;
396 }
397 }
398
399 pa_xfree(conf->script_commands);
400 conf->script_commands = pa_strbuf_tostring_free(buf);
401
402 *d = optind;
403
404 return 0;
405
406 fail:
407 if (buf)
408 pa_strbuf_free(buf);
409
410 return -1;
411 }