1 /*****************************************************************************
2 * variables.h: object variables typedefs
3 *****************************************************************************
4 * Copyright (C) 1999-2012 VLC authors and VideoLAN
6 * Authors: Samuel Hocevar <sam@zoy.org>
8 * This program is free software; you can redistribute it and/or modify it
9 * under the terms of the GNU Lesser General Public License as published by
10 * the Free Software Foundation; either version 2.1 of the License, or
11 * (at your option) any later version.
13 * This program is distributed in the hope that it will be useful,
14 * but WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 * GNU Lesser General Public License for more details.
18 * You should have received a copy of the GNU Lesser General Public License
19 * along with this program; if not, write to the Free Software Foundation,
20 * Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
21 *****************************************************************************/
23 #ifndef LIBVLC_VARIABLES_H
24 # define LIBVLC_VARIABLES_H 1
26 # include <vlc_atomic.h>
29 * Private LibVLC data for each object.
31 typedef struct vlc_object_internals vlc_object_internals_t;
33 struct vlc_object_internals
35 char *psz_name; /* given name */
37 /* Object variables */
42 /* Objects thread synchronization */
45 /* Objects management */
47 vlc_destructor_t pf_destructor;
49 /* Objects tree structure */
50 vlc_object_internals_t *next; /* next sibling */
51 vlc_object_internals_t *prev; /* previous sibling */
52 vlc_object_internals_t *first; /* first child */
55 # define vlc_internals( obj ) (((vlc_object_internals_t*)(VLC_OBJECT(obj)))-1)
56 # define vlc_externals( priv ) ((vlc_object_t *)((priv) + 1))
59 typedef struct callback_entry_t callback_entry_t;
61 typedef struct variable_ops_t
63 int (*pf_cmp) ( vlc_value_t, vlc_value_t );
64 void (*pf_dup) ( vlc_value_t * );
65 void (*pf_free) ( vlc_value_t * );
69 * The structure describing a variable.
70 * \note vlc_value_t is the common union for variable values
74 char * psz_name; /**< The variable unique name (must be first) */
76 /** The variable's exported value */
79 /** The variable display name, mainly for use by the interfaces */
82 const variable_ops_t *ops;
84 int i_type; /**< The type of the variable */
85 unsigned i_usage; /**< Reference count */
87 /** If the variable has min/max/step values */
88 vlc_value_t min, max, step;
90 /** Index of the default choice, if the variable is to be chosen in
93 /** List of choices */
95 /** List of friendly names for the choices */
96 vlc_list_t choices_text;
98 /** Set to TRUE if the variable is in a callback */
101 /** Number of registered callbacks */
103 /** Array of registered callbacks */
104 callback_entry_t * p_entries;
107 extern void var_DestroyAll( vlc_object_t * );