lib: add libvlc_media_tracklist API
[vlc.git] / include / vlc_config_cat.h
blob608d80eb4d397c92cdae340fada5a7f018cb5b11
1 /*****************************************************************************
2 * vlc_config_cat.h : Definition of configuration categories
3 *****************************************************************************
4 * Copyright (C) 2003 VLC authors and VideoLAN
6 * Authors: Clément Stenac <zorglub@videolan.org>
7 * Anil Daoud <anil@videolan.org>
9 * This program is free software; you can redistribute it and/or modify it
10 * under the terms of the GNU Lesser General Public License as published by
11 * the Free Software Foundation; either version 2.1 of the License, or
12 * (at your option) any later version.
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Lesser General Public License for more details.
19 * You should have received a copy of the GNU Lesser General Public License
20 * along with this program; if not, write to the Free Software Foundation,
21 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
22 *****************************************************************************/
24 #ifndef VLC_HELP_H
25 #define VLC_HELP_H 1
26 # include <vlc_plugin.h>
29 * First, we need help strings for the General Settings and for the
30 * Plugins screen
32 #define MAIN_TITLE N_( "VLC preferences" )
33 #define MAIN_HELP N_( \
34 "Select \"Advanced Options\" to see all options." )
36 /* Interface */
37 #define INTF_TITLE N_("Interface")
38 #define INTF_HELP N_( "Settings for VLC's interfaces" )
40 #define INTF_GENERAL_HELP N_( "Main interfaces settings" )
42 #define INTF_MAIN_TITLE N_( "Main interfaces" )
43 #define INTF_MAIN_HELP N_( "Settings for the main interface" )
45 #define INTF_CONTROL_TITLE N_( "Control interfaces" )
46 #define INTF_CONTROL_HELP N_( "Settings for VLC's control interfaces" )
48 #define INTF_HOTKEYS_TITLE N_( "Hotkeys settings" )
49 #define INTF_HOTKEYS_HELP N_( "Hotkeys settings" )
51 /* Audio */
52 #define AUDIO_TITLE N_( "Audio" )
53 #define AUDIO_HELP N_( "Audio settings" )
55 #define AUDIO_GENERAL_HELP N_("General audio settings")
57 #define AFILTER_TITLE N_("Filters")
58 #define AFILTER_HELP N_( "Audio filters are used to process the audio stream." )
60 #define ARESAMPLER_TITLE N_("Audio resampler")
62 #define AVISUAL_TITLE N_("Visualizations")
63 #define AVISUAL_HELP N_( "Audio visualizations" )
65 #define AOUT_TITLE N_( "Output modules" )
66 #define AOUT_HELP N_("General settings for audio output modules.")
68 #define AMISC_TITLE N_("Miscellaneous")
69 #define AMISC_HELP N_( "Miscellaneous audio settings and modules." )
71 /* Video */
72 #define VIDEO_TITLE N_("Video")
73 #define VIDEO_HELP N_("Video settings")
75 #define VIDEO_GENERAL_HELP N_( "General video settings" )
77 #define _VOUT_TITLE N_("Output modules" )
78 #define VOUT_HELP N_("General settings for video output modules.")
80 #define VFILTER_TITLE N_("Filters" )
81 #define VFILTER_HELP N_("Video filters are used to process the video stream." )
83 #define SUBPIC_TITLE N_( "Subtitles / OSD")
84 #define SUBPIC_HELP N_( "Settings related to On-Screen-Display,"\
85 " subtitles and \"overlay subpictures\"")
87 #define SPLITTER_TITLE N_("Splitters")
88 #define SPLITTER_HELP N_("Video splitters separate the stream into multiple videos.")
91 #define TEXT_HELP N_( \
92 "Use the settings of the \"freetype\" module to choose the font you " \
93 "want VLC to use for text rendering (to display subtitles for example).")
95 /* Input */
96 #define INPUT_TITLE N_( "Input / Codecs" )
97 #define INPUT_HELP N_( "Settings for input, demultiplexing, " \
98 "decoding and encoding")
100 #define ACCESS_TITLE N_( "Access modules" )
101 #define ACCESS_HELP N_( \
102 "Settings related to the various access methods. " \
103 "Common settings you may want to alter are HTTP proxy or " \
104 "caching settings." )
106 #define STREAM_FILTER_TITLE N_( "Stream filters" )
107 #define STREAM_FILTER_HELP N_( \
108 "Stream filters are special modules that allow advanced operations on " \
109 "the input side of VLC. Use with care..." )
111 #define DEMUX_TITLE N_("Demuxers")
112 #define DEMUX_HELP N_( "Demuxers are used to separate audio and video streams." )
114 #define VDEC_TITLE N_( "Video codecs" )
115 #define VDEC_HELP N_( "Settings for the video, images or video+audio decoders and encoders." )
117 #define ADEC_TITLE N_( "Audio codecs" )
118 #define ADEC_HELP N_( "Settings for the audio-only decoders and encoders." )
120 #define SDEC_TITLE N_( "Subtitle codecs")
121 #define SDEC_HELP N_( "Settings for subtitle, teletext and CC decoders and encoders." )
123 #define ADVANCED_HELP N_( "General input settings. Use with care..." )
125 /* Sout */
126 #define SOUT_TITLE N_( "Stream output" )
127 #define SOUT_HELP N_( \
128 "Stream output settings are used when acting as a streaming server " \
129 "or when saving incoming streams.\n" \
130 "Streams are first muxed and then sent through an \"access output\" "\
131 "module that can either save the stream to a file, or stream " \
132 "it (UDP, HTTP, RTP/RTSP).\n" \
133 "Sout streams modules allow advanced stream processing (transcoding, "\
134 "duplicating...).")
136 #define SOUT_GENERAL_HELP N_( "General stream output settings")
138 #define SOUT_MUX_TITLE N_( "Muxers" )
139 #define SOUT_MUX_HELP N_( \
140 "Muxers create the encapsulation formats that are used to " \
141 "put all the elementary streams (video, audio, ...) " \
142 "together. This setting allows you to always force a specific muxer. " \
143 "You should probably not do that.\n" \
144 "You can also set default parameters for each muxer." )
146 #define SOUT_ACO_TITLE N_( "Access output" )
147 #define SOUT_ACO_HELP N_( \
148 "Access output modules control the ways the muxed streams are sent. " \
149 "This setting allows you to always force a specific access output method. " \
150 "You should probably not do that.\n" \
151 "You can also set default parameters for each access output.")
153 #define SOUT_PACKET_TITLE N_( "Packetizers" )
154 #define SOUT_PACKET_HELP N_( \
155 "Packetizers are used to \"preprocess\" the elementary "\
156 "streams before muxing. " \
157 "This setting allows you to always force a packetizer. " \
158 "You should probably not do that.\n" \
159 "You can also set default parameters for each packetizer." )
161 #define SOUT_STREAM_TITLE N_("Sout stream")
162 #define SOUT_STREAM_HELP N_( "Sout stream modules allow to build a sout " \
163 "processing chain. Please refer to the Streaming Howto for " \
164 "more information. You can configure default options for " \
165 "each sout stream module here.")
167 #define SOUT_VOD_TITLE N_( "VOD" )
168 #define SOUT_VOD_HELP N_( "VLC's implementation of Video On Demand" )
171 /* Playlist */
172 #define PLAYLIST_TITLE N_( "Playlist" )
173 #define PLAYLIST_HELP N_( "Settings related to playlist behaviour " \
174 "(e.g. playback mode) and to modules that automatically add "\
175 "items to the playlist (\"service discovery\" modules).")
177 #define PGENERAL_HELP N_( "General playlist behaviour")
178 #define SD_TITLE N_("Services discovery")
179 #define SD_HELP N_("Services discovery modules are facilities "\
180 "that automatically add items to playlist.")
182 /* Advanced */
183 #define AADVANCED_TITLE N_( "Advanced" )
184 #define AADVANCED_HELP N_( "Advanced settings. Use with care...")
186 #define MISC_TITLE N_( "Advanced settings" )
188 /* This function is deprecated and is kept only for compatibility */
189 static const struct config_category_t categories_array[] =
191 /* Interface */
192 { CAT_INTERFACE, INTF_TITLE, INTF_HELP },
193 { SUBCAT_INTERFACE_GENERAL, INTF_TITLE, INTF_GENERAL_HELP },
194 { SUBCAT_INTERFACE_MAIN, INTF_MAIN_TITLE, INTF_MAIN_HELP },
195 { SUBCAT_INTERFACE_CONTROL, INTF_CONTROL_TITLE, INTF_CONTROL_HELP },
196 { SUBCAT_INTERFACE_HOTKEYS, INTF_HOTKEYS_TITLE, INTF_HOTKEYS_HELP },
198 { CAT_AUDIO, AUDIO_TITLE, AUDIO_HELP },
199 { SUBCAT_AUDIO_GENERAL, AUDIO_TITLE, AUDIO_GENERAL_HELP },
200 { SUBCAT_AUDIO_AOUT, AOUT_TITLE, AOUT_HELP },
201 { SUBCAT_AUDIO_AFILTER, AFILTER_TITLE, AFILTER_HELP },
202 { SUBCAT_AUDIO_RESAMPLER, ARESAMPLER_TITLE, AFILTER_HELP },
203 { SUBCAT_AUDIO_VISUAL, AVISUAL_TITLE, AVISUAL_HELP },
204 { SUBCAT_AUDIO_MISC, AMISC_TITLE, AMISC_HELP },
206 { CAT_VIDEO, VIDEO_TITLE, VIDEO_HELP },
207 { SUBCAT_VIDEO_GENERAL, VIDEO_TITLE, VIDEO_GENERAL_HELP },
208 { SUBCAT_VIDEO_VOUT, _VOUT_TITLE, VOUT_HELP },
209 { SUBCAT_VIDEO_VFILTER, VFILTER_TITLE, VFILTER_HELP },
210 { SUBCAT_VIDEO_SUBPIC, SUBPIC_TITLE, SUBPIC_HELP },
211 { SUBCAT_VIDEO_SPLITTER, SPLITTER_TITLE, SPLITTER_HELP },
213 { CAT_INPUT, INPUT_TITLE, INPUT_HELP },
214 { SUBCAT_INPUT_GENERAL, INPUT_TITLE, INPUT_HELP },
215 { SUBCAT_INPUT_ACCESS, ACCESS_TITLE, ACCESS_HELP },
216 { SUBCAT_INPUT_DEMUX, DEMUX_TITLE, DEMUX_HELP },
217 { SUBCAT_INPUT_VCODEC, VDEC_TITLE, VDEC_HELP },
218 { SUBCAT_INPUT_ACODEC, ADEC_TITLE, ADEC_HELP },
219 { SUBCAT_INPUT_SCODEC, SDEC_TITLE, SDEC_HELP },
220 { SUBCAT_INPUT_STREAM_FILTER, STREAM_FILTER_TITLE, STREAM_FILTER_HELP },
222 { CAT_SOUT, SOUT_TITLE, SOUT_HELP },
223 { SUBCAT_SOUT_GENERAL, SOUT_TITLE, SOUT_GENERAL_HELP },
224 { SUBCAT_SOUT_STREAM, SOUT_STREAM_TITLE, SOUT_STREAM_HELP },
225 { SUBCAT_SOUT_MUX, SOUT_MUX_TITLE, SOUT_MUX_HELP },
226 { SUBCAT_SOUT_ACO, SOUT_ACO_TITLE, SOUT_ACO_HELP },
227 { SUBCAT_SOUT_PACKETIZER, SOUT_PACKET_TITLE, SOUT_PACKET_HELP },
228 { SUBCAT_SOUT_VOD, SOUT_VOD_TITLE, SOUT_VOD_HELP },
230 { CAT_PLAYLIST, PLAYLIST_TITLE , PLAYLIST_HELP },
231 { SUBCAT_PLAYLIST_GENERAL, PLAYLIST_TITLE, PGENERAL_HELP },
232 { SUBCAT_PLAYLIST_SD, SD_TITLE, SD_HELP },
234 { CAT_ADVANCED, AADVANCED_TITLE, AADVANCED_HELP },
235 { SUBCAT_ADVANCED_MISC, MISC_TITLE, AADVANCED_HELP },
237 { -1, NULL, NULL }
240 VLC_USED
241 static inline const char *config_CategoryNameGet( int i_value )
243 int i = 0;
244 while( categories_array[i].psz_name != NULL )
246 if( categories_array[i].i_id == i_value )
248 return vlc_gettext(categories_array[i].psz_name);
250 i++;
252 return NULL;
255 VLC_USED
256 static inline const char *config_CategoryHelpGet( int i_value )
258 int i = 0;
259 while( categories_array[i].psz_help != NULL )
261 if( categories_array[i].i_id == i_value )
263 return vlc_gettext(categories_array[i].psz_help);
265 i++;
267 return NULL;
270 #endif /* VLC_HELP_H */