]> git.sesse.net Git - vlc/blob - src/libvlc.h
bae56bc089ae9d46cf7b65ddffb7e82b4f5dbf19
[vlc] / src / libvlc.h
1 /*****************************************************************************
2  * libvlc.h: main libvlc header
3  *****************************************************************************
4  * Copyright (C) 1998-2002 VideoLAN
5  * $Id: libvlc.h,v 1.10 2002/08/04 17:23:44 sam Exp $
6  *
7  * Authors: Vincent Seguin <seguin@via.ecp.fr>
8  *          Samuel Hocevar <sam@zoy.org>
9  *          Gildas Bazin <gbazin@netcourrier.com>
10  *
11  * This program is free software; you can redistribute it and/or modify
12  * it under the terms of the GNU General Public License as published by
13  * the Free Software Foundation; either version 2 of the License, or
14  * (at your option) any later version.
15  *
16  * This program is distributed in the hope that it will be useful,
17  * but WITHOUT ANY WARRANTY; without even the implied warranty of
18  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
19  * GNU General Public License for more details.
20  *
21  * You should have received a copy of the GNU General Public License
22  * along with this program; if not, write to the Free Software
23  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
24  *****************************************************************************/
25
26 #define Nothing here, this is just to prevent update-po from being stupid
27
28 /*****************************************************************************
29  * Configuration options for the main program. Each module will also separatly
30  * define its own configuration options.
31  * Look into configuration.h if you need to know more about the following
32  * macros.
33  *****************************************************************************/
34 #define INTF_TEXT N_("interface module")
35 #define INTF_LONGTEXT N_( \
36     "This option allows you to select the interface used by vlc. " \
37     "The default behavior is to automatically select the best module " \
38     "available.")
39
40 #define VERBOSE_TEXT N_("be verbose")
41 #define VERBOSE_LONGTEXT N_( \
42     "This options activates the output of information messages.")
43
44 #define QUIET_TEXT N_("be quiet")
45 #define QUIET_LONGTEXT N_( \
46     "This options turns off all warning and information messages.")
47
48 #define COLOR_TEXT N_("color messages")
49 #define COLOR_LONGTEXT N_( \
50     "When this option is turned on, the messages sent to the console will " \
51     "be colorized. Your terminal needs Linux color support for this to work.")
52
53 #define INTF_PATH_TEXT N_("interface default search path")
54 #define INTF_PATH_LONGTEXT N_( \
55     "This option allows you to set the default path that the interface will " \
56     "open when looking for a file.")
57
58 #define PLUGIN_PATH_TEXT N_("plugin search path")
59 #define PLUGIN_PATH_LONGTEXT N_( \
60     "This option allows you to specify an additional path for vlc to look" \
61     "for its plugins.")
62
63 #define AOUT_TEXT N_("audio output module")
64 #define AOUT_LONGTEXT N_( \
65     "This option allows you to select the audio output method used by vlc. " \
66     "The default behavior is to automatically select the best method " \
67     "available.")
68
69 #define AUDIO_TEXT N_("enable audio")
70 #define AUDIO_LONGTEXT N_( \
71     "You can completely disable the audio output. In this case the audio " \
72     "decoding stage won't be done, and it will save some processing power.")
73
74 #define MONO_TEXT N_("force mono audio")
75 #define MONO_LONGTEXT N_("This will force a mono audio output")
76
77 #define VOLUME_TEXT N_("audio output volume")
78 #define VOLUME_LONGTEXT N_( \
79     "You can set the default audio output volume here, in a range from 0 to " \
80     "1024.")
81
82 #define FORMAT_TEXT N_("audio output format")
83 #define FORMAT_LONGTEXT N_( \
84     "You can force the audio output format here.\n" \
85     "0 -> 16 bits signed native endian (default)\n" \
86     "1 ->  8 bits unsigned\n"                       \
87     "2 -> 16 bits signed little endian\n"           \
88     "3 -> 16 bits signed big endian\n"              \
89     "4 ->  8 bits signed\n"                         \
90     "5 -> 16 bits unsigned little endian\n"         \
91     "6 -> 16 bits unsigned big endian\n"            \
92     "7 -> MPEG2 audio (unsupported)\n"              \
93     "8 -> A52 pass-through")
94
95 #define RATE_TEXT N_("audio output frequency (Hz)")
96 #define RATE_LONGTEXT N_( \
97     "You can force the audio output frequency here. Common values are " \
98     "48000, 44100, 32000, 22050, 16000, 11025, 8000.")
99
100 #define DESYNC_TEXT N_("compensate desynchronization of audio (in ms)")
101 #define DESYNC_LONGTEXT N_( \
102     "This option allows you to delay the audio output. This can be handy if " \
103     "you notice a lag between the video and the audio.")
104
105 #define VOUT_TEXT N_("video output module")
106 #define VOUT_LONGTEXT N_( \
107     "This option allows you to select the video output method used by vlc. " \
108     "The default behavior is to automatically select the best " \
109     "method available.")
110
111 #define VIDEO_TEXT N_("enable video")
112 #define VIDEO_LONGTEXT N_( \
113     "You can completely disable the video output. In this case the video " \
114     "decoding stage won't be done, which will save some processing power.")
115
116 #define DISPLAY_TEXT N_("display identifier")
117 #define DISPLAY_LONGTEXT N_( \
118     "This is the local display port that will be used for X11 drawing. " \
119     "For instance :0.1.")
120
121 #define WIDTH_TEXT N_("video width")
122 #define WIDTH_LONGTEXT N_( \
123     "You can enforce the video width here. By default vlc will " \
124     "adapt to the video characteristics.")
125
126 #define HEIGHT_TEXT N_("video height")
127 #define HEIGHT_LONGTEXT N_( \
128     "You can enforce the video height here. By default vlc will " \
129     "adapt to the video characteristics.")
130
131 #define ZOOM_TEXT N_("zoom video")
132 #define ZOOM_LONGTEXT N_( \
133     "You can zoom the video by the specified factor.")
134
135 #define GRAYSCALE_TEXT N_("grayscale video output")
136 #define GRAYSCALE_LONGTEXT N_( \
137     "When enabled, the color information from the video won't be decoded " \
138     "(this can also allow you to save some processing power).")
139
140 #define FULLSCREEN_TEXT N_("fullscreen video output")
141 #define FULLSCREEN_LONGTEXT N_( \
142     "If this option is enabled, vlc will always start a video in fullscreen " \
143     "mode.")
144
145 #define OVERLAY_TEXT N_("overlay video output")
146 #define OVERLAY_LONGTEXT N_( \
147     "If enabled, vlc will try to take advantage of the overlay capabilities " \
148     "of you graphics card.")
149
150 #define SPUMARGIN_TEXT N_("force SPU position")
151 #define SPUMARGIN_LONGTEXT N_( \
152     "You can use this option to place the subtitles under the movie, " \
153     "instead of over the movie. Try several positions.")
154
155 #define FILTER_TEXT N_("video filter module")
156 #define FILTER_LONGTEXT N_( \
157     "This will allow you to add a post-processing filter to enhance the " \
158     "picture quality, for instance deinterlacing, or to clone or distort " \
159     "the video window.")
160
161 #define SERVER_PORT_TEXT N_("server port")
162 #define SERVER_PORT_LONGTEXT N_( \
163     "This is the port used for UDP streams. By default, we chose 1234.")
164
165 #define MTU_TEXT N_("MTU of the interface")
166 #define MTU_LONGTEXT N_( \
167     "This is the typical size of UDP packets that we expect. On Ethernet " \
168     "it is usually 1500.")
169
170 #define NETCHANNEL_TEXT N_("enable network channel mode")
171 #define NETCHANNEL_LONGTEXT N_( \
172     "Activate this option if you want to use the VideoLAN Channel Server.")
173
174 #define CHAN_SERV_TEXT N_("channel server address")
175 #define CHAN_SERV_LONGTEXT N_( \
176     "Indicate here the address of the VideoLAN Channel Server.")
177
178 #define CHAN_PORT_TEXT N_("channel server port")
179 #define CHAN_PORT_LONGTEXT N_( \
180     "Indicate here the port on which the VideoLAN Channel Server runs.")
181
182 #define IFACE_TEXT N_("network interface")
183 #define IFACE_LONGTEXT N_( \
184     "If you have several interfaces on your Linux machine and use the " \
185     "VLAN solution, you may indicate here which interface to use.")
186
187 #define INPUT_PROGRAM_TEXT N_("choose program (SID)")
188 #define INPUT_PROGRAM_LONGTEXT N_( \
189     "Choose the program to select by giving its Service ID.")
190
191 #define INPUT_AUDIO_TEXT N_("choose audio")
192 #define INPUT_AUDIO_LONGTEXT N_( \
193     "Give the default type of audio you want to use in a DVD.")
194
195 #define INPUT_CHAN_TEXT N_("choose channel")
196 #define INPUT_CHAN_LONGTEXT N_( \
197     "Give the stream number of the audio channel you want to use in a DVD " \
198     "(from 1 to n).")
199
200 #define INPUT_SUBT_TEXT N_("choose subtitles")
201 #define INPUT_SUBT_LONGTEXT N_( \
202     "Give the stream number of the subtitle channel you want to use in a " \
203     "DVD (from 1 to n).")
204
205 #define DVD_DEV_TEXT N_("DVD device")
206 #define DVD_DEV_LONGTEXT N_( \
207     "This is the default DVD device to use.")
208
209 #define VCD_DEV_TEXT N_("VCD device")
210 #define VCD_DEV_LONGTEXT N_( \
211     "This is the default VCD device to use.")
212
213 #define IPV6_TEXT N_("force IPv6")
214 #define IPV6_LONGTEXT N_( \
215     "If you check this box, IPv6 will be used by default for all UDP and " \
216     "HTTP connections.")
217
218 #define IPV4_TEXT N_("force IPv4")
219 #define IPV4_LONGTEXT N_( \
220     "If you check this box, IPv4 will be used by default for all UDP and " \
221     "HTTP connections.")
222
223 #define CODEC_TEXT N_("choose preferred codec list")
224 #define CODEC_LONGTEXT N_( \
225     "This allows you to select the order in which vlc will choose its " \
226     "codecs. For instance, 'a52old,a52,any' will try the old a52 codec " \
227     "before the new one. Please be aware that vlc does not make any " \
228     "difference between audio or video codecs, so you should always specify " \
229     "'any' at the end of the list to make sure there is a fallback for the " \
230     "types you didn't specify.")
231
232 #define MMX_TEXT N_("enable CPU MMX support")
233 #define MMX_LONGTEXT N_( \
234     "If your processor supports the MMX instructions set, vlc can take " \
235     "advantage of them.")
236
237 #define THREE_DN_TEXT N_("enable CPU 3D Now! support")
238 #define THREE_DN_LONGTEXT N_( \
239     "If your processor supports the 3D Now! instructions set, vlc can take "\
240     "advantage of them.")
241
242 #define MMXEXT_TEXT N_("enable CPU MMX EXT support")
243 #define MMXEXT_LONGTEXT N_( \
244     "If your processor supports the MMX EXT instructions set, vlc can take "\
245     "advantage of them.")
246
247 #define SSE_TEXT N_("enable CPU SSE support")
248 #define SSE_LONGTEXT N_( \
249     "If your processor supports the SSE instructions set, vlc can take " \
250     "can take advantage of them.")
251
252 #define ALTIVEC_TEXT N_("enable CPU AltiVec support")
253 #define ALTIVEC_LONGTEXT N_( \
254     "If your processor supports the AltiVec instructions set, vlc can take "\
255     "advantage of them.")
256
257 #define PL_LAUNCH_TEXT N_("launch playlist on startup")
258 #define PL_LAUNCH_LONGTEXT N_( \
259     "If you want vlc to start playing on startup, then enable this option.")
260
261 #define PL_ENQUEUE_TEXT N_("enqueue items in playlist")
262 #define PL_ENQUEUE_LONGTEXT N_( \
263     "If you want vlc to add items to the playlist as you open them, then " \
264     "enable this option.")
265
266 #define PL_LOOP_TEXT N_("loop playlist on end")
267 #define PL_LOOP_LONGTEXT N_( \
268     "If you want vlc to keep playing the playlist indefinitely then enable " \
269     "this option.")
270
271 #define MEMCPY_TEXT N_("memory copy module")
272 #define MEMCPY_LONGTEXT N_( \
273     "You can select wich memory copy module you want to use. By default vlc " \
274     "will select the fastest one supported by your hardware.")
275
276 #define ACCESS_TEXT N_("access module")
277 #define ACCESS_LONGTEXT N_( \
278     "This is a legacy entry to let you configure access modules")
279
280 #define DEMUX_TEXT N_("demux module")
281 #define DEMUX_LONGTEXT N_( \
282     "This is a legacy entry to let you configure demux modules")
283
284 #define FAST_MUTEX_TEXT N_("fast mutex on NT/2K/XP (developpers only)")
285 #define FAST_MUTEX_LONGTEXT N_( \
286     "On Windows NT/2K/XP we use a slow mutex implementation but which " \
287     "allows us to correctely implement condition variables. " \
288     "You can also use the faster Win9x implementation but you might " \
289     "experience problems with it.")
290
291 #define WIN9X_CV_TEXT N_("Condition variables implementation for Win9x " \
292     "(developpers only)")
293 #define WIN9X_CV_LONGTEXT N_( \
294     "On Windows 9x/Me we use a fast but not correct condition variables " \
295     "implementation (more precisely there is a possibility for a race " \
296     "condition to happen). " \
297     "However it is possible to use slower alternatives which should be more " \
298     "robust. " \
299     "Currently you can choose between implementation 0 (which is the " \
300     "default and the fastest), 1 and 2.")
301
302 #define PLAYLIST_USAGE N_("\nPlaylist items:" \
303     "\n  *.mpg, *.vob                   plain MPEG-1/2 files" \
304     "\n  [dvd:][device][@raw_device][@[title][,[chapter][,angle]]]" \
305     "\n                                 DVD device" \
306     "\n  [vcd:][device][@[title][,[chapter]]" \
307     "\n                                 VCD device" \
308     "\n  udpstream:[@[<bind address>][:<bind port>]]" \
309     "\n                                 UDP stream sent by VLS" \
310     "\n  vlc:loop                       loop execution of the " \
311     "playlist" \
312     "\n  vlc:pause                      pause execution of " \
313     "playlist items" \
314     "\n  vlc:quit                       quit VLC" \
315     "\n")
316
317 /*
318  * Quick usage guide for the configuration options:
319  *
320  * add_category_hint( N_(text), N_(longtext) );
321  * add_subcategory_hint( N_(text), N_(longtext) );
322  * add_usage_hint( N_(text) );
323  * add_string( option_name, value, p_callback, N_(text), N_(longtext) );
324  * add_file( option_name, psz_value, p_callback, N_(text), N_(longtext) );
325  * add_module( option_name, psz_value, i_capability, p_callback,
326  *             N_(text), N_(longtext) );
327  * add_integer( option_name, i_value, p_callback, N_(text), N_(longtext) );
328  * add_bool( option_name, b_value, p_callback, N_(text), N_(longtext) );
329  */
330
331 vlc_module_begin();
332     /* Interface options */
333     add_category_hint( N_("Interface"), NULL);
334     add_module_with_short( "intf", 'I', "interface", NULL, NULL,
335                            INTF_TEXT, INTF_LONGTEXT );
336     add_bool_with_short( "verbose", 'v', 0, NULL,
337                          VERBOSE_TEXT, VERBOSE_LONGTEXT );
338     add_bool_with_short( "quiet", 'q', 0, NULL, QUIET_TEXT, QUIET_LONGTEXT );
339     add_bool( "color", 0, NULL, COLOR_TEXT, COLOR_LONGTEXT );
340     add_string( "search-path", NULL, NULL, INTF_PATH_TEXT, INTF_PATH_LONGTEXT );
341     add_string( "plugin-path", NULL, NULL,
342                 PLUGIN_PATH_TEXT, PLUGIN_PATH_LONGTEXT );
343
344     /* Audio options */
345     add_category_hint( N_("Audio"), NULL);
346     add_module_with_short( "aout", 'A', "audio output", NULL, NULL,
347                            AOUT_TEXT, AOUT_LONGTEXT );
348     add_bool( "audio", 1, NULL, AUDIO_TEXT, AUDIO_LONGTEXT );
349     add_bool( "mono", 0, NULL, MONO_TEXT, MONO_LONGTEXT );
350     add_integer( "volume", VOLUME_DEFAULT, NULL, VOLUME_TEXT, VOLUME_LONGTEXT );
351     add_integer( "rate", 44100, NULL, RATE_TEXT, RATE_LONGTEXT );
352     add_integer( "desync", 0, NULL, DESYNC_TEXT, DESYNC_LONGTEXT );
353     add_integer( "audio-format", 0, NULL, FORMAT_TEXT, FORMAT_LONGTEXT );
354
355     /* Video options */
356     add_category_hint( N_("Video"), NULL );
357     add_module_with_short( "vout", 'V', "video output", NULL, NULL,
358                            VOUT_TEXT, VOUT_LONGTEXT );
359     add_bool( "video", 1, NULL, VIDEO_TEXT, VIDEO_LONGTEXT );
360     add_integer( "width", -1, NULL, WIDTH_TEXT, WIDTH_LONGTEXT );
361     add_integer( "height", -1, NULL, HEIGHT_TEXT, HEIGHT_LONGTEXT );
362     add_float( "zoom", 1, NULL, ZOOM_TEXT, ZOOM_LONGTEXT );
363     add_bool( "grayscale", 0, NULL, GRAYSCALE_TEXT, GRAYSCALE_LONGTEXT );
364     add_bool( "fullscreen", 0, NULL, FULLSCREEN_TEXT, FULLSCREEN_LONGTEXT );
365     add_bool( "overlay", 1, NULL, OVERLAY_TEXT, OVERLAY_LONGTEXT );
366     add_integer( "spumargin", -1, NULL, SPUMARGIN_TEXT, SPUMARGIN_LONGTEXT );
367     add_module( "filter", "video filter", NULL, NULL,
368                 FILTER_TEXT, FILTER_LONGTEXT );
369
370     /* Input options */
371     add_category_hint( N_("Input"), NULL );
372     add_integer( "server-port", 1234, NULL,
373                  SERVER_PORT_TEXT, SERVER_PORT_LONGTEXT );
374     add_bool( "network-channel", 0, NULL,
375               NETCHANNEL_TEXT, NETCHANNEL_LONGTEXT );
376     add_string( "channel-server", "localhost", NULL,
377                 CHAN_SERV_TEXT, CHAN_SERV_LONGTEXT );
378     add_integer( "channel-port", 6010, NULL,
379                  CHAN_PORT_TEXT, CHAN_PORT_LONGTEXT );
380     add_integer( "mtu", 1500, NULL, MTU_TEXT, MTU_LONGTEXT );
381     add_string( "iface", "eth0", NULL, IFACE_TEXT, IFACE_LONGTEXT );
382
383     add_integer( "program", 0, NULL,
384                  INPUT_PROGRAM_TEXT, INPUT_PROGRAM_LONGTEXT );
385     add_integer( "audio-type", -1, NULL,
386                  INPUT_AUDIO_TEXT, INPUT_AUDIO_LONGTEXT );
387     add_integer( "audio-channel", -1, NULL,
388                  INPUT_CHAN_TEXT, INPUT_CHAN_LONGTEXT );
389     add_integer( "spu-channel", -1, NULL,
390                  INPUT_SUBT_TEXT, INPUT_SUBT_LONGTEXT );
391
392     add_string( "dvd", DVD_DEVICE, NULL, DVD_DEV_TEXT, DVD_DEV_LONGTEXT );
393     add_string( "vcd", VCD_DEVICE, NULL, VCD_DEV_TEXT, VCD_DEV_LONGTEXT );
394
395     add_bool_with_short( "ipv6", '6', 0, NULL, IPV6_TEXT, IPV6_LONGTEXT );
396     add_bool_with_short( "ipv4", '4', 0, NULL, IPV4_TEXT, IPV4_LONGTEXT );
397
398     /* Decoder options */
399     add_category_hint( N_("Decoders"), NULL );
400     add_module( "codec", "decoder", NULL, NULL, CODEC_TEXT, CODEC_LONGTEXT );
401
402     /* CPU options */
403     add_category_hint( N_("CPU"), NULL );
404 #if defined( __i386__ )
405     add_bool( "mmx", 1, NULL, MMX_TEXT, MMX_LONGTEXT );
406     add_bool( "3dn", 1, NULL, THREE_DN_TEXT, THREE_DN_LONGTEXT );
407     add_bool( "mmxext", 1, NULL, MMXEXT_TEXT, MMXEXT_LONGTEXT );
408     add_bool( "sse", 1, NULL, SSE_TEXT, SSE_LONGTEXT );
409 #endif
410 #if defined( __powerpc__ ) || defined( SYS_DARWIN )
411     add_bool( "altivec", 1, NULL, ALTIVEC_TEXT, ALTIVEC_LONGTEXT );
412 #endif
413
414     /* Playlist options */
415     add_category_hint( N_("Playlist"), NULL );
416     add_bool( "playlist", 0, NULL, PL_LAUNCH_TEXT, PL_LAUNCH_LONGTEXT );
417     add_bool( "enqueue", 0, NULL, PL_ENQUEUE_TEXT, PL_ENQUEUE_LONGTEXT );
418     add_bool( "loop", 0, NULL, PL_LOOP_TEXT, PL_LOOP_LONGTEXT );
419
420     /* Misc options */
421     add_category_hint( N_("Miscellaneous"), NULL );
422     add_module( "memcpy", "memcpy", NULL, NULL, MEMCPY_TEXT, MEMCPY_LONGTEXT );
423     add_module( "access", "access", NULL, NULL, ACCESS_TEXT, ACCESS_LONGTEXT );
424     add_module( "demux", "demux", NULL, NULL, DEMUX_TEXT, DEMUX_LONGTEXT );
425
426 #if defined(WIN32)
427     add_bool( "fast-mutex", 0, NULL, FAST_MUTEX_TEXT, FAST_MUTEX_LONGTEXT );
428     add_integer( "win9x-cv-method", 0, NULL, WIN9X_CV_TEXT, WIN9X_CV_LONGTEXT );
429 #endif
430
431     /* Usage (mainly useful for cmd line stuff) */
432     add_usage_hint( PLAYLIST_USAGE );
433
434     set_description( N_("main program") );
435     set_capability( "main", 100 );
436 vlc_module_end();
437
438 static module_config_t p_help_config[] =
439 {
440     { CONFIG_ITEM_BOOL, NULL, "help", 'h', N_("print help") },
441     { CONFIG_ITEM_BOOL, NULL, "longhelp", 'H', N_("print detailed help") },
442     { CONFIG_ITEM_BOOL, NULL, "list", 'l',
443                               N_("print a list of available modules") },
444     { CONFIG_ITEM_STRING, NULL, "module", 'p', N_("print help on module") },
445     { CONFIG_ITEM_BOOL, NULL, "version", '\0',
446                               N_("print version information") },
447     { CONFIG_HINT_END, NULL, NULL, '\0' }
448 };
449
450 /*****************************************************************************
451  * End configuration.
452  *****************************************************************************/