libvlc.h 26.5 KB
Newer Older
1 2 3 4
/*****************************************************************************
 * libvlc.h: main libvlc header
 *****************************************************************************
 * Copyright (C) 1998-2002 VideoLAN
5
 * $Id: libvlc.h,v 1.69 2003/05/21 13:19:32 sigmunau Exp $
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25
 *
 * Authors: Vincent Seguin <seguin@via.ecp.fr>
 *          Samuel Hocevar <sam@zoy.org>
 *          Gildas Bazin <gbazin@netcourrier.com>
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA.
 *****************************************************************************/

26 27
#define Nothing here, this is just to prevent update-po from being stupid

Laurent Aimar's avatar
Laurent Aimar committed
28 29 30
static char *ppsz_sout_acodec[] = { "", "mpga", "a52", NULL };
static char *ppsz_sout_vcodec[] = { "", "mpgv", "mp4v", "DIV3", "h263", NULL };

31
static char *ppsz_language[] = { "auto", "de", "en_GB", "fr", "it",
32
                                 "ja", "nl", "no", "pl", "ru", "sv", NULL };
33

34 35 36 37 38 39
/*****************************************************************************
 * Configuration options for the main program. Each module will also separatly
 * define its own configuration options.
 * Look into configuration.h if you need to know more about the following
 * macros.
 *****************************************************************************/
40
#define INTF_TEXT N_("Interface module")
41
#define INTF_LONGTEXT N_( \
42
    "This option allows you to select the interface used by VLC. " \
43 44 45
    "The default behavior is to automatically select the best module " \
    "available.")

46
#define EXTRAINTF_TEXT N_("Extra interface modules")
47
#define EXTRAINTF_LONGTEXT N_( \
48
    "This option allows you to select additional interfaces used by VLC. " \
Sam Hocevar's avatar
Sam Hocevar committed
49
    "They will be launched in the background in addition to the default " \
50 51
    "interface. Use a comma separated list of interface modules.")

52
#define VERBOSE_TEXT N_("Verbosity (0,1,2)")
53
#define VERBOSE_LONGTEXT N_( \
54
    "This options sets the verbosity level (0=only errors and " \
55
    "standard messages, 1=warnings, 2=debug).")
56

57
#define QUIET_TEXT N_("Be quiet")
58 59 60
#define QUIET_LONGTEXT N_( \
    "This options turns off all warning and information messages.")

61 62 63 64
#define LANGUAGE_TEXT N_("Language")
#define LANGUAGE_LONGTEXT N_( "This option allows you to set the language " \
    "of the interface. The system language is auto-detected if \"auto\" is " \
    "specified here." )
Gildas Bazin's avatar
 
Gildas Bazin committed
65

66
#define COLOR_TEXT N_("Color messages")
67 68 69 70
#define COLOR_LONGTEXT N_( \
    "When this option is turned on, the messages sent to the console will " \
    "be colorized. Your terminal needs Linux color support for this to work.")

71
#define ADVANCED_TEXT N_("Show advanced options")
72 73 74 75
#define ADVANCED_LONGTEXT N_( \
    "When this option is turned on, the interfaces will show all the " \
    "available options, including those that most users should never touch")

76
#define INTF_PATH_TEXT N_("Interface default search path")
77 78 79 80
#define INTF_PATH_LONGTEXT N_( \
    "This option allows you to set the default path that the interface will " \
    "open when looking for a file.")

81
#define PLUGIN_PATH_TEXT N_("Plugin search path")
82
#define PLUGIN_PATH_LONGTEXT N_( \
83
    "This option allows you to specify an additional path for VLC to look " \
84 85
    "for its plugins.")

86
#define AOUT_TEXT N_("Audio output module")
87
#define AOUT_LONGTEXT N_( \
88
    "This option allows you to select the audio output method used by VLC. " \
89 90
    "The default behavior is to automatically select the best method " \
    "available.")
91

92
#define AUDIO_TEXT N_("Enable audio")
93 94 95 96
#define AUDIO_LONGTEXT N_( \
    "You can completely disable the audio output. In this case the audio " \
    "decoding stage won't be done, and it will save some processing power.")

97
#define MONO_TEXT N_("Force mono audio")
98 99
#define MONO_LONGTEXT N_("This will force a mono audio output")

100
#define VOLUME_TEXT N_("Audio output volume")
101 102 103 104
#define VOLUME_LONGTEXT N_( \
    "You can set the default audio output volume here, in a range from 0 to " \
    "1024.")

105
#define VOLUME_SAVE_TEXT N_("Audio output saved volume")
106 107 108
#define VOLUME_SAVE_LONGTEXT N_( \
    "This saves the audio output volume when you select mute.")

109
#define AOUT_RATE_TEXT N_("Audio output frequency (Hz)")
110
#define AOUT_RATE_LONGTEXT N_( \
111
    "You can force the audio output frequency here. Common values are " \
Gildas Bazin's avatar
 
Gildas Bazin committed
112
    "-1 (default), 48000, 44100, 32000, 22050, 16000, 11025, 8000.")
113

Gildas Bazin's avatar
 
Gildas Bazin committed
114 115 116 117 118 119 120
#if !defined( SYS_DARWIN )
#define AOUT_RESAMP_TEXT N_("High quality audio resampling")
#define AOUT_RESAMP_LONGTEXT N_( \
    "High quality audio resampling can be processor intensive so you can " \
    "disable it and a cheaper resampling algorithm will be used instead.")
#endif

121
#define DESYNC_TEXT N_("Compensate desynchronization of audio (in ms)")
122 123 124 125
#define DESYNC_LONGTEXT N_( \
    "This option allows you to delay the audio output. This can be handy if " \
    "you notice a lag between the video and the audio.")

126
#define SPDIF_TEXT N_("Use the S/PDIF audio output when available")
Gildas Bazin's avatar
 
Gildas Bazin committed
127 128 129 130
#define SPDIF_LONGTEXT N_( \
    "This option allows you to use the S/PDIF audio output by default when " \
    "your hardware supports it as well as the audio stream being played.")

131
#define HEADPHONE_TEXT N_("Headphone virtual spatialization effect")
132 133 134 135 136 137 138 139
#define HEADPHONE_LONGTEXT N_( \
    "This effect gives you the feeling that you stands in a real room " \
    "with a complete 5.1 speaker set when using only a headphone, " \
    "providing a more realistic sound experience. It should also be " \
    "more comfortable and less tiring when listening to music for " \
    "long periods of time.\nIt works with any source format from mono " \
    "to 5.1.")

140
#define VOUT_TEXT N_("Video output module")
141
#define VOUT_LONGTEXT N_( \
142
    "This option allows you to select the video output method used by VLC. " \
143 144 145
    "The default behavior is to automatically select the best " \
    "method available.")

146
#define VIDEO_TEXT N_("Enable video")
147 148 149 150
#define VIDEO_LONGTEXT N_( \
    "You can completely disable the video output. In this case the video " \
    "decoding stage won't be done, which will save some processing power.")

151
#define WIDTH_TEXT N_("Video width")
152
#define WIDTH_LONGTEXT N_( \
153
    "You can enforce the video width here. By default VLC will " \
154 155
    "adapt to the video characteristics.")

156
#define HEIGHT_TEXT N_("Video height")
157
#define HEIGHT_LONGTEXT N_( \
158
    "You can enforce the video height here. By default VLC will " \
159 160
    "adapt to the video characteristics.")

161
#define ZOOM_TEXT N_("Zoom video")
162 163 164
#define ZOOM_LONGTEXT N_( \
    "You can zoom the video by the specified factor.")

165
#define GRAYSCALE_TEXT N_("Grayscale video output")
166 167 168 169
#define GRAYSCALE_LONGTEXT N_( \
    "When enabled, the color information from the video won't be decoded " \
    "(this can also allow you to save some processing power).")

170
#define FULLSCREEN_TEXT N_("Fullscreen video output")
171
#define FULLSCREEN_LONGTEXT N_( \
172
    "If this option is enabled, VLC will always start a video in fullscreen " \
173 174
    "mode.")

175
#define OVERLAY_TEXT N_("Overlay video output")
176
#define OVERLAY_LONGTEXT N_( \
177
    "If enabled, VLC will try to take advantage of the overlay capabilities " \
178
    "of your graphic card.")
179

180
#define SPUMARGIN_TEXT N_("Force SPU position")
181 182 183 184
#define SPUMARGIN_LONGTEXT N_( \
    "You can use this option to place the subtitles under the movie, " \
    "instead of over the movie. Try several positions.")

185
#define FILTER_TEXT N_("Video filter module")
186 187 188 189 190
#define FILTER_LONGTEXT N_( \
    "This will allow you to add a post-processing filter to enhance the " \
    "picture quality, for instance deinterlacing, or to clone or distort " \
    "the video window.")

191
#define ASPECT_RATIO_TEXT N_("Source aspect ratio")
192 193 194 195 196 197 198 199 200
#define ASPECT_RATIO_LONGTEXT N_( \
    "This will force the source aspect ratio. For instance, some DVDs claim " \
    "to be 16:9 while they are actually 4:3. This can also be used as a " \
    "hint for VLC when a movie does not have aspect ratio information. " \
    "Accepted formats are x:y (4:3, 16:9, etc.) expressing the global image " \
    "aspect, or a float value (1.25, 1.3333, etc.) expressing pixel " \
    "squareness.")

#if 0
201
#define PIXEL_RATIO_TEXT N_("Destination aspect ratio")
202 203 204 205 206 207 208 209
#define PIXEL_RATIO_LONGTEXT N_( \
    "This will force the destination pixel size. By default VLC assumes " \
    "your pixels are square, unless your hardware has a way to tell it " \
    "otherwise. This may be used when you output VLC's signal to another " \
    "device such as a TV set. Accepted format is a float value (1, 1.25, " \
    "1.3333, etc.) expressing pixel squareness.")
#endif

210
#define SERVER_PORT_TEXT N_("Server port")
211 212 213
#define SERVER_PORT_LONGTEXT N_( \
    "This is the port used for UDP streams. By default, we chose 1234.")

Sam Hocevar's avatar
Sam Hocevar committed
214
#define MTU_TEXT N_("MTU of the network interface")
Christophe Massiot's avatar
Christophe Massiot committed
215 216 217 218
#define MTU_LONGTEXT N_( \
    "This is the typical size of UDP packets that we expect. On Ethernet " \
    "it is usually 1500.")

219
#define IFACE_ADDR_TEXT N_("Network interface address")
220 221 222
#define IFACE_ADDR_LONGTEXT N_( \
    "If you have several interfaces on your machine and use the " \
    "multicast solution, you will probably have to indicate the IP address " \
223
    "of your multicasting interface here.")
224

225
#define TTL_TEXT N_("Time to live")
226 227 228 229
#define TTL_LONGTEXT N_( \
    "Indicate here the Time To Live of the multicast packets sent by " \
    "the stream output.")

230
#define INPUT_PROGRAM_TEXT N_("Choose program (SID)")
231 232 233
#define INPUT_PROGRAM_LONGTEXT N_( \
    "Choose the program to select by giving its Service ID.")

234
#define INPUT_AUDIO_TEXT N_("Choose audio")
235 236 237
#define INPUT_AUDIO_LONGTEXT N_( \
    "Give the default type of audio you want to use in a DVD.")

238
#define INPUT_CHAN_TEXT N_("Choose channel")
239 240 241 242
#define INPUT_CHAN_LONGTEXT N_( \
    "Give the stream number of the audio channel you want to use in a DVD " \
    "(from 1 to n).")

243
#define INPUT_SUBT_TEXT N_("Choose subtitles")
244 245 246 247 248
#define INPUT_SUBT_LONGTEXT N_( \
    "Give the stream number of the subtitle channel you want to use in a " \
    "DVD (from 1 to n).")

#define DVD_DEV_TEXT N_("DVD device")
Gildas Bazin's avatar
 
Gildas Bazin committed
249 250 251 252 253
#ifdef WIN32
#define DVD_DEV_LONGTEXT N_( \
    "This is the default DVD drive (or file) to use. Don't forget the colon " \
    "after the drive letter (eg D:)")
#else
254 255
#define DVD_DEV_LONGTEXT N_( \
    "This is the default DVD device to use.")
Gildas Bazin's avatar
 
Gildas Bazin committed
256
#endif
257 258 259 260 261

#define VCD_DEV_TEXT N_("VCD device")
#define VCD_DEV_LONGTEXT N_( \
    "This is the default VCD device to use.")

262
#define IPV6_TEXT N_("Force IPv6")
263 264 265 266
#define IPV6_LONGTEXT N_( \
    "If you check this box, IPv6 will be used by default for all UDP and " \
    "HTTP connections.")

267
#define IPV4_TEXT N_("Force IPv4")
268 269 270 271
#define IPV4_LONGTEXT N_( \
    "If you check this box, IPv4 will be used by default for all UDP and " \
    "HTTP connections.")

272
#define CODEC_TEXT N_("Choose preferred codec list")
273
#define CODEC_LONGTEXT N_( \
274
    "This allows you to select the order in which VLC will choose its " \
275
    "codecs. For instance, 'a52old,a52,any' will try the old a52 codec " \
276
    "before the new one. Please be aware that VLC does not make any " \
277 278 279
    "difference between audio or video codecs, so you should always specify " \
    "'any' at the end of the list to make sure there is a fallback for the " \
    "types you didn't specify.")
280

281
#define ENCODER_VIDEO_TEXT N_("Choose preferred video encoder list")
282
#define ENCODER_VIDEO_LONGTEXT N_( \
283
    "This allows you to select the order in which VLC will choose its " \
284
    "codecs. " )
285
#define ENCODER_AUDIO_TEXT N_("Choose preferred audio encoder list")
286
#define ENCODER_AUDIO_LONGTEXT N_( \
287
    "This allows you to select the order in which VLC will choose its " \
288 289
    "codecs. " )

290
#define SOUT_TEXT N_("Choose a stream output")
291 292
#define SOUT_LONGTEXT N_( \
    "Empty if no stream output.")
Gildas Bazin's avatar
 
Gildas Bazin committed
293

294
#define SOUT_DISPLAY_TEXT N_("Display while streaming")
295 296 297
#define SOUT_DISPLAY_LONGTEXT N_( \
    "This allows you to play the stream while streaming it.")

298
#define SOUT_VIDEO_TEXT N_("Enable video stream output")
Gildas Bazin's avatar
 
Gildas Bazin committed
299 300 301 302
#define SOUT_VIDEO_LONGTEXT N_( \
    "This allows you to choose if the video stream should be redirected to " \
    "the stream output facility when this last one is enabled.")

303
#define SOUT_VCODEC_TEXT N_("Video encoding codec" )
304 305 306
#define SOUT_VCODEC_LONGTEXT N_( \
    "This allows you to force video encoding")

307
#define SOUT_VBITRATE_TEXT N_("Video bitrate encoding (kB/s)" )
308 309 310
#define SOUT_VBITRATE_LONGTEXT N_( \
    "This allows you to specify video bitrate in kB/s.")

311
#define SOUT_AUDIO_TEXT N_("Enable audio stream output")
Gildas Bazin's avatar
 
Gildas Bazin committed
312 313 314 315
#define SOUT_AUDIO_LONGTEXT N_( \
    "This allows you to choose if the video stream should be redirected to " \
    "the stream output facility when this last one is enabled.")

316
#define SOUT_ACODEC_TEXT N_("Audio encoding codec" )
317 318 319
#define SOUT_ACODEC_LONGTEXT N_( \
    "This allows you to force audio encoding")

320
#define SOUT_ABITRATE_TEXT N_("Audio bitrate encoding (kB/s)" )
321 322 323
#define SOUT_ABITRATE_LONGTEXT N_( \
    "This allows you to specify audio bitrate in kB/s.")

324
#define PACKETIZER_TEXT N_("Choose preferred packetizer list")
325
#define PACKETIZER_LONGTEXT N_( \
326
    "This allows you to select the order in which VLC will choose its " \
327
    "packetizers."  )
Gildas Bazin's avatar
 
Gildas Bazin committed
328

329
#define MUX_TEXT N_("Mux module")
330 331
#define MUX_LONGTEXT N_( \
    "This is a legacy entry to let you configure mux modules")
Gildas Bazin's avatar
 
Gildas Bazin committed
332

333
#define ACCESS_OUTPUT_TEXT N_("Access output module")
334 335 336
#define ACCESS_OUTPUT_LONGTEXT N_( \
    "This is a legacy entry to let you configure access output modules")

337

338
#define MMX_TEXT N_("Enable CPU MMX support")
339
#define MMX_LONGTEXT N_( \
340
    "If your processor supports the MMX instructions set, VLC can take " \
341 342
    "advantage of them.")

343
#define THREE_DN_TEXT N_("Enable CPU 3D Now! support")
344
#define THREE_DN_LONGTEXT N_( \
345
    "If your processor supports the 3D Now! instructions set, VLC can take " \
346 347
    "advantage of them.")

348
#define MMXEXT_TEXT N_("Enable CPU MMX EXT support")
349
#define MMXEXT_LONGTEXT N_( \
350
    "If your processor supports the MMX EXT instructions set, VLC can take " \
351 352
    "advantage of them.")

353
#define SSE_TEXT N_("Enable CPU SSE support")
354
#define SSE_LONGTEXT N_( \
355
    "If your processor supports the SSE instructions set, VLC can take " \
356
    "advantage of them.")
357

358
#define ALTIVEC_TEXT N_("Enable CPU AltiVec support")
359
#define ALTIVEC_LONGTEXT N_( \
360
    "If your processor supports the AltiVec instructions set, VLC can take " \
361 362
    "advantage of them.")

363
#define RANDOM_TEXT N_("Play files randomly forever")
364
#define RANDOM_LONGTEXT N_( \
365
    "When selected, VLC will randomly play files in the playlist until " \
366 367
    "interrupted.")

368
#define ENQUEUE_TEXT N_("Enqueue items in playlist")
369
#define ENQUEUE_LONGTEXT N_( \
370
    "If you want VLC to add items to the playlist as you open them, then " \
371 372
    "enable this option.")

373
#define LOOP_TEXT N_("Loop playlist on end")
374
#define LOOP_LONGTEXT N_( \
375
    "If you want VLC to keep playing the playlist indefinitely then enable " \
376 377
    "this option.")

378
#define MEMCPY_TEXT N_("Memory copy module")
379
#define MEMCPY_LONGTEXT N_( \
380 381
    "You can select which memory copy module you want to use. By default " \
    "VLC will select the fastest one supported by your hardware.")
382

383
#define ACCESS_TEXT N_("Access module")
384 385 386
#define ACCESS_LONGTEXT N_( \
    "This is a legacy entry to let you configure access modules")

387
#define DEMUX_TEXT N_("Demux module")
388 389 390
#define DEMUX_LONGTEXT N_( \
    "This is a legacy entry to let you configure demux modules")

391
#define FAST_MUTEX_TEXT N_("Dast mutex on NT/2K/XP (developers only)")
Gildas Bazin's avatar
 
Gildas Bazin committed
392 393 394 395 396 397 398
#define FAST_MUTEX_LONGTEXT N_( \
    "On Windows NT/2K/XP we use a slow mutex implementation but which " \
    "allows us to correctely implement condition variables. " \
    "You can also use the faster Win9x implementation but you might " \
    "experience problems with it.")

#define WIN9X_CV_TEXT N_("Condition variables implementation for Win9x " \
399
    "(developers only)")
Gildas Bazin's avatar
 
Gildas Bazin committed
400 401 402 403 404 405 406 407
#define WIN9X_CV_LONGTEXT N_( \
    "On Windows 9x/Me we use a fast but not correct condition variables " \
    "implementation (more precisely there is a possibility for a race " \
    "condition to happen). " \
    "However it is possible to use slower alternatives which should be more " \
    "robust. " \
    "Currently you can choose between implementation 0 (which is the " \
    "default and the fastest), 1 and 2.")
408

409 410
#define RT_PRIORITY_TEXT N_("Real-time priority")

Gildas Bazin's avatar
 
Gildas Bazin committed
411 412 413 414 415 416 417 418 419 420 421 422 423
#define PLAYLIST_USAGE N_("\nPlaylist items:" \
    "\n  *.mpg, *.vob                   plain MPEG-1/2 files" \
    "\n  [dvd:][device][@raw_device][@[title][,[chapter][,angle]]]" \
    "\n                                 DVD device" \
    "\n  [vcd:][device][@[title][,[chapter]]" \
    "\n                                 VCD device" \
    "\n  udpstream:[@[<bind address>][:<bind port>]]" \
    "\n                                 UDP stream sent by VLS" \
    "\n  vlc:pause                      pause execution of " \
    "playlist items" \
    "\n  vlc:quit                       quit VLC" \
    "\n")

424

425 426 427
/*
 * Quick usage guide for the configuration options:
 *
428 429 430 431 432 433 434 435 436
 * add_category_hint( N_(text), N_(longtext) );
 * add_subcategory_hint( N_(text), N_(longtext) );
 * add_usage_hint( N_(text) );
 * add_string( option_name, value, p_callback, N_(text), N_(longtext) );
 * add_file( option_name, psz_value, p_callback, N_(text), N_(longtext) );
 * add_module( option_name, psz_value, i_capability, p_callback,
 *             N_(text), N_(longtext) );
 * add_integer( option_name, i_value, p_callback, N_(text), N_(longtext) );
 * add_bool( option_name, b_value, p_callback, N_(text), N_(longtext) );
437 438
 */

439 440
vlc_module_begin();
    /* Interface options */
441
    add_category_hint( N_("Interface"), NULL, VLC_FALSE );
442
    add_module_with_short( "intf", 'I', "interface", NULL, NULL,
443 444
                           INTF_TEXT, INTF_LONGTEXT, VLC_TRUE );
    add_string( "extraintf", NULL, NULL, EXTRAINTF_TEXT, EXTRAINTF_LONGTEXT, VLC_TRUE );
445
    add_integer_with_short( "verbose", 'v', -1, NULL,
446 447
                            VERBOSE_TEXT, VERBOSE_LONGTEXT, VLC_FALSE );
    add_bool_with_short( "quiet", 'q', 0, NULL, QUIET_TEXT, QUIET_LONGTEXT, VLC_TRUE );
448
    add_string_from_list( "language", "auto", ppsz_language, NULL, LANGUAGE_TEXT, LANGUAGE_LONGTEXT, VLC_FALSE );
449 450 451
    add_bool( "color", 0, NULL, COLOR_TEXT, COLOR_LONGTEXT, VLC_TRUE );
    add_bool( "advanced", 0, NULL, ADVANCED_TEXT, ADVANCED_LONGTEXT, VLC_FALSE );
    add_string( "search-path", NULL, NULL, INTF_PATH_TEXT, INTF_PATH_LONGTEXT, VLC_TRUE );
452
    add_string( "plugin-path", NULL, NULL,
453
                PLUGIN_PATH_TEXT, PLUGIN_PATH_LONGTEXT, VLC_TRUE );
454 455

    /* Audio options */
456
    add_category_hint( N_("Audio"), NULL, VLC_FALSE );
457
    add_module_with_short( "aout", 'A', "audio output", NULL, NULL,
458 459
                           AOUT_TEXT, AOUT_LONGTEXT, VLC_FALSE );
    add_bool( "audio", 1, NULL, AUDIO_TEXT, AUDIO_LONGTEXT, VLC_TRUE );
460 461
    add_integer_with_range( "volume", AOUT_VOLUME_DEFAULT, AOUT_VOLUME_MIN,
                            AOUT_VOLUME_MAX, NULL, VOLUME_TEXT,
462
                            VOLUME_LONGTEXT, VLC_FALSE );
463 464
    add_integer_with_range( "saved-volume", AOUT_VOLUME_DEFAULT,
                            AOUT_VOLUME_MIN, AOUT_VOLUME_MAX, NULL,
465 466
                            VOLUME_SAVE_TEXT, VOLUME_SAVE_LONGTEXT, VLC_TRUE );
    add_integer( "aout-rate", -1, NULL, AOUT_RATE_TEXT, AOUT_RATE_LONGTEXT, VLC_TRUE );
Gildas Bazin's avatar
 
Gildas Bazin committed
467 468 469
#if !defined( SYS_DARWIN )
    add_bool( "hq-resampling", 1, NULL, AOUT_RESAMP_TEXT, AOUT_RESAMP_LONGTEXT, VLC_TRUE );
#endif
470
    add_integer( "desync", 0, NULL, DESYNC_TEXT, DESYNC_LONGTEXT, VLC_TRUE );
Gildas Bazin's avatar
 
Gildas Bazin committed
471
    add_bool( "spdif", 0, NULL, SPDIF_TEXT, SPDIF_LONGTEXT, VLC_FALSE );
472
    add_bool( "headphone-opt", 0, NULL, HEADPHONE_TEXT, HEADPHONE_LONGTEXT, VLC_FALSE );
473 474

    /* Video options */
475
    add_category_hint( N_("Video"), NULL, VLC_FALSE );
476
    add_module_with_short( "vout", 'V', "video output", NULL, NULL,
477 478 479 480 481 482 483 484 485
                           VOUT_TEXT, VOUT_LONGTEXT, VLC_FALSE );
    add_bool( "video", 1, NULL, VIDEO_TEXT, VIDEO_LONGTEXT, VLC_TRUE );
    add_integer( "width", -1, NULL, WIDTH_TEXT, WIDTH_LONGTEXT, VLC_TRUE );
    add_integer( "height", -1, NULL, HEIGHT_TEXT, HEIGHT_LONGTEXT, VLC_TRUE );
    add_float( "zoom", 1, NULL, ZOOM_TEXT, ZOOM_LONGTEXT, VLC_TRUE );
    add_bool( "grayscale", 0, NULL, GRAYSCALE_TEXT, GRAYSCALE_LONGTEXT, VLC_TRUE );
    add_bool( "fullscreen", 0, NULL, FULLSCREEN_TEXT, FULLSCREEN_LONGTEXT, VLC_FALSE );
    add_bool( "overlay", 1, NULL, OVERLAY_TEXT, OVERLAY_LONGTEXT, VLC_TRUE );
    add_integer( "spumargin", -1, NULL, SPUMARGIN_TEXT, SPUMARGIN_LONGTEXT, VLC_TRUE );
486
    add_module( "filter", "video filter", NULL, NULL,
487
                FILTER_TEXT, FILTER_LONGTEXT, VLC_TRUE );
488
    add_string( "aspect-ratio", "", NULL,
489
                ASPECT_RATIO_TEXT, ASPECT_RATIO_LONGTEXT, VLC_TRUE );
490 491 492
#if 0
    add_string( "pixel-ratio", "1", NULL, PIXEL_RATIO_TEXT, PIXEL_RATIO_TEXT );
#endif
493 494

    /* Input options */
495
    add_category_hint( N_("Input"), NULL, VLC_FALSE );
496
    add_integer( "server-port", 1234, NULL,
497 498 499 500
                 SERVER_PORT_TEXT, SERVER_PORT_LONGTEXT, VLC_FALSE );
    add_integer( "mtu", 1500, NULL, MTU_TEXT, MTU_LONGTEXT, VLC_TRUE );
    add_string( "iface-addr", "", NULL, IFACE_ADDR_TEXT, IFACE_ADDR_LONGTEXT, VLC_TRUE );
    add_integer( "ttl", 1, NULL, TTL_TEXT, TTL_LONGTEXT, VLC_TRUE );
501 502

    add_integer( "program", 0, NULL,
503
                 INPUT_PROGRAM_TEXT, INPUT_PROGRAM_LONGTEXT, VLC_TRUE );
504
    add_integer( "audio-type", -1, NULL,
505
                 INPUT_AUDIO_TEXT, INPUT_AUDIO_LONGTEXT, VLC_TRUE );
506
    add_integer( "audio-channel", -1, NULL,
507
                 INPUT_CHAN_TEXT, INPUT_CHAN_LONGTEXT, VLC_TRUE );
508
    add_integer( "spu-channel", -1, NULL,
509
                 INPUT_SUBT_TEXT, INPUT_SUBT_LONGTEXT, VLC_TRUE );
510

Gildas Bazin's avatar
 
Gildas Bazin committed
511 512
    add_file( "dvd", DVD_DEVICE, NULL, DVD_DEV_TEXT, DVD_DEV_LONGTEXT, VLC_FALSE );
    add_file( "vcd", VCD_DEVICE, NULL, VCD_DEV_TEXT, VCD_DEV_LONGTEXT, VLC_FALSE );
513

514 515
    add_bool_with_short( "ipv6", '6', 0, NULL, IPV6_TEXT, IPV6_LONGTEXT, VLC_FALSE );
    add_bool_with_short( "ipv4", '4', 0, NULL, IPV4_TEXT, IPV4_LONGTEXT, VLC_FALSE );
516 517

    /* Decoder options */
518 519
    add_category_hint( N_("Decoders"), NULL, VLC_TRUE );
    add_module( "codec", "decoder", NULL, NULL, CODEC_TEXT, CODEC_LONGTEXT, VLC_TRUE );
520

521 522 523
    add_category_hint( N_("Encoders"), NULL, VLC_TRUE );
    add_module( "video-encoder", "video encoder", NULL, NULL, ENCODER_VIDEO_TEXT, ENCODER_VIDEO_LONGTEXT, VLC_TRUE );
    add_module( "audio-encoder", "audio encoder", NULL, NULL, ENCODER_AUDIO_TEXT, ENCODER_AUDIO_LONGTEXT, VLC_TRUE );
524

Gildas Bazin's avatar
 
Gildas Bazin committed
525
    /* Stream output options */
526 527
    add_category_hint( N_("Stream output"), NULL, VLC_TRUE );
    add_string( "sout", NULL, NULL, SOUT_TEXT, SOUT_LONGTEXT, VLC_TRUE );
528 529
    add_bool( "sout-display", VLC_FALSE, NULL, SOUT_DISPLAY_TEXT, SOUT_DISPLAY_LONGTEXT, VLC_TRUE );

530 531
    add_bool( "sout-audio", 1, NULL, SOUT_AUDIO_TEXT, SOUT_AUDIO_LONGTEXT, VLC_TRUE );
    add_string_from_list( "sout-acodec", "", ppsz_sout_acodec, NULL, SOUT_ACODEC_TEXT, SOUT_ACODEC_LONGTEXT, VLC_TRUE );
532 533 534
    add_bool( "sout-abitrate", 0, NULL, SOUT_ABITRATE_TEXT, SOUT_ABITRATE_LONGTEXT, VLC_TRUE );

    add_bool( "sout-video", 1, NULL, SOUT_VIDEO_TEXT, SOUT_VIDEO_LONGTEXT, VLC_TRUE );
535
    add_string_from_list( "sout-vcodec", "", ppsz_sout_vcodec, NULL, SOUT_VCODEC_TEXT, SOUT_VCODEC_LONGTEXT, VLC_TRUE );
536 537
    add_bool( "sout-vbitrate", 0, NULL, SOUT_VBITRATE_TEXT, SOUT_VBITRATE_LONGTEXT, VLC_TRUE );

Gildas Bazin's avatar
 
Gildas Bazin committed
538
    add_module( "packetizer", "packetizer", NULL, NULL,
539 540
                PACKETIZER_TEXT, PACKETIZER_LONGTEXT, VLC_TRUE );
    add_module( "mux", "sout mux", NULL, NULL, MUX_TEXT, MUX_LONGTEXT, VLC_TRUE );
Gildas Bazin's avatar
 
Gildas Bazin committed
541
    add_module( "access_output", "sout access", NULL, NULL,
542
                ACCESS_OUTPUT_TEXT, ACCESS_OUTPUT_LONGTEXT, VLC_TRUE );
543

544
    /* CPU options */
Gildas Bazin's avatar
 
Gildas Bazin committed
545
    add_category_hint( N_("CPU"), NULL, VLC_TRUE );
546
#if defined( __i386__ )
Gildas Bazin's avatar
 
Gildas Bazin committed
547 548 549 550
    add_bool( "mmx", 1, NULL, MMX_TEXT, MMX_LONGTEXT, VLC_TRUE );
    add_bool( "3dn", 1, NULL, THREE_DN_TEXT, THREE_DN_LONGTEXT, VLC_TRUE );
    add_bool( "mmxext", 1, NULL, MMXEXT_TEXT, MMXEXT_LONGTEXT, VLC_TRUE );
    add_bool( "sse", 1, NULL, SSE_TEXT, SSE_LONGTEXT, VLC_TRUE );
551 552
#endif
#if defined( __powerpc__ ) || defined( SYS_DARWIN )
Gildas Bazin's avatar
 
Gildas Bazin committed
553
    add_bool( "altivec", 1, NULL, ALTIVEC_TEXT, ALTIVEC_LONGTEXT, VLC_TRUE );
554 555
#endif

556
    /* Playlist options */
557 558 559 560
    add_category_hint( N_("Playlist"), NULL, VLC_FALSE );
    add_bool_with_short( "random", 'Z', 0, NULL, RANDOM_TEXT, RANDOM_LONGTEXT, VLC_FALSE );
    add_bool( "enqueue", 0, NULL, ENQUEUE_TEXT, ENQUEUE_LONGTEXT, VLC_FALSE );
    add_bool( "loop", 0, NULL, LOOP_TEXT, LOOP_LONGTEXT, VLC_FALSE );
Gildas Bazin's avatar
 
Gildas Bazin committed
561

562
    /* Misc options */
563 564 565 566
    add_category_hint( N_("Miscellaneous"), NULL, VLC_TRUE );
    add_module( "memcpy", "memcpy", NULL, NULL, MEMCPY_TEXT, MEMCPY_LONGTEXT, VLC_TRUE );
    add_module( "access", "access", NULL, NULL, ACCESS_TEXT, ACCESS_LONGTEXT, VLC_TRUE );
    add_module( "demux", "demux", NULL, NULL, DEMUX_TEXT, DEMUX_LONGTEXT, VLC_TRUE );
567

568
#if defined(WIN32)
569 570
    add_bool( "fast-mutex", 0, NULL, FAST_MUTEX_TEXT, FAST_MUTEX_LONGTEXT, VLC_TRUE );
    add_integer( "win9x-cv-method", 0, NULL, WIN9X_CV_TEXT, WIN9X_CV_LONGTEXT, VLC_TRUE );
571
#endif
572

573 574
    /* Usage (mainly useful for cmd line stuff) */
    add_usage_hint( PLAYLIST_USAGE );
575

576 577 578
    set_description( N_("main program") );
    set_capability( "main", 100 );
vlc_module_end();
579 580 581

static module_config_t p_help_config[] =
{
582
    { CONFIG_ITEM_BOOL, NULL, "help", 'h', N_("print help"),
583
      NULL, NULL, 0, 0.0, 0, 0, 0.0, 0.0, NULL, NULL, NULL, VLC_FALSE },
584
    { CONFIG_ITEM_BOOL, NULL, "longhelp", 'H', N_("print detailed help"),
585
      NULL, NULL, 0, 0.0, 0, 0, 0.0, 0.0, NULL, NULL, NULL, VLC_FALSE },
586
    { CONFIG_ITEM_BOOL, NULL, "list", 'l',
587
                              N_("print a list of available modules"),
588
      NULL, NULL, 0, 0.0, 0, 0, 0.0, 0.0, NULL, NULL, NULL, VLC_FALSE },
589
    { CONFIG_ITEM_STRING, NULL, "module", 'p', N_("print help on module"),
590
      NULL, NULL, 0, 0.0, 0, 0, 0.0, 0.0, NULL, NULL, NULL, VLC_FALSE },
591
    { CONFIG_ITEM_BOOL, NULL, "version", '\0',
592
                              N_("print version information"),
593
      NULL, NULL, 0, 0.0, 0, 0, 0.0, 0.0, NULL, NULL, NULL, VLC_FALSE },
594
    { CONFIG_HINT_END, NULL, NULL, '\0', NULL,
595
      NULL, NULL, 0, 0.0, 0, 0, 0.0, 0.0, NULL, NULL, NULL, VLC_FALSE }
596 597 598 599 600
};

/*****************************************************************************
 * End configuration.
 *****************************************************************************/