VLC  2.1.0-git
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
Data Structures | Macros | Typedefs | Functions | Variables
vlc_arrays.h File Reference

This file defines functions, structures and macros for handling arrays in vlc. More...

Include dependency graph for vlc_arrays.h:

Go to the source code of this file.

Data Structures

struct  vlc_array_t
struct  vlc_dictionary_entry_t
struct  vlc_dictionary_t

Macros

#define INSERT_ELEM(p_ar, i_oldsize, i_pos, elem)
 Simple dynamic array handling.
#define REMOVE_ELEM(p_ar, i_size, i_pos)
#define TAB_INIT(count, tab)
#define TAB_CLEAN(count, tab)
#define TAB_APPEND_CAST(cast, count, tab, p)
#define TAB_APPEND(count, tab, p)   TAB_APPEND_CAST( , count, tab, p )
#define TAB_FIND(count, tab, p, idx)
#define TAB_REMOVE(count, tab, p)
#define TAB_INSERT_CAST(cast, count, tab, p, index)
#define TAB_INSERT(count, tab, p, index)   TAB_INSERT_CAST( , count, tab, p, index )
#define BSEARCH(entries, count, elem, zetype, key, answer)
 Binary search in a sorted array.
#define _ARRAY_ALLOC(array, newsize)
#define _ARRAY_GROW1(array)
#define ARRAY_SIZE(x)   (sizeof(x) / sizeof((x)[0]))
#define DECL_ARRAY(type)
#define TYPEDEF_ARRAY(type, name)   typedef DECL_ARRAY(type) name;
#define ARRAY_INIT(array)
#define ARRAY_RESET(array)
#define ARRAY_APPEND(array, elem)
#define ARRAY_INSERT(array, elem, pos)
#define _ARRAY_SHRINK(array)
#define ARRAY_REMOVE(array, pos)
#define ARRAY_VAL(array, pos)   array.p_elems[pos]
#define ARRAY_BSEARCH(array, elem, zetype, key, answer)   BSEARCH( (array).p_elems, (array).i_size, elem, zetype, key, answer)
#define FOREACH_ARRAY(item, array)
#define FOREACH_END()   } }

Typedefs

typedef struct vlc_array_t vlc_array_t
typedef struct
vlc_dictionary_entry_t 
vlc_dictionary_entry_t
typedef struct vlc_dictionary_t vlc_dictionary_t

Functions

static void * realloc_down (void *ptr, size_t size)
static void vlc_array_init (vlc_array_t *p_array)
static void vlc_array_clear (vlc_array_t *p_array)
static vlc_array_tvlc_array_new (void)
static void vlc_array_destroy (vlc_array_t *p_array)
static int vlc_array_count (vlc_array_t *p_array)
static void * vlc_array_item_at_index (vlc_array_t *p_array, int i_index)
static int vlc_array_index_of_item (vlc_array_t *p_array, void *item)
static void vlc_array_insert (vlc_array_t *p_array, void *p_elem, int i_index)
static void vlc_array_append (vlc_array_t *p_array, void *p_elem)
static void vlc_array_remove (vlc_array_t *p_array, int i_index)
static uint64_t DictHash (const char *psz_string, int hashsize)
static void vlc_dictionary_init (vlc_dictionary_t *p_dict, int i_size)
static void vlc_dictionary_clear (vlc_dictionary_t *p_dict, void(*pf_free)(void *p_data, void *p_obj), void *p_obj)
static int vlc_dictionary_has_key (const vlc_dictionary_t *p_dict, const char *psz_key)
static void * vlc_dictionary_value_for_key (const vlc_dictionary_t *p_dict, const char *psz_key)
static int vlc_dictionary_keys_count (const vlc_dictionary_t *p_dict)
static char ** vlc_dictionary_all_keys (const vlc_dictionary_t *p_dict)
static void __vlc_dictionary_insert (vlc_dictionary_t *p_dict, const char *psz_key, void *p_value, bool rebuild)
static void vlc_dictionary_insert (vlc_dictionary_t *p_dict, const char *psz_key, void *p_value)
static void vlc_dictionary_remove_value_for_key (const vlc_dictionary_t *p_dict, const char *psz_key, void(*pf_free)(void *p_data, void *p_obj), void *p_obj)

Variables

static void *const kVLCDictionaryNotFound = NULL

Detailed Description

This file defines functions, structures and macros for handling arrays in vlc.

Macro Definition Documentation

#define _ARRAY_ALLOC (   array,
  newsize 
)
Value:
{ \
(array).i_alloc = newsize; \
(array).p_elems = realloc( (array).p_elems, (array).i_alloc * \
sizeof(*(array).p_elems) ); \
if( !(array).p_elems ) abort(); \
}
#define _ARRAY_GROW1 (   array)
Value:
{ \
if( (array).i_alloc < 10 ) \
_ARRAY_ALLOC(array, 10 ) \
else if( (array).i_alloc == (array).i_size ) \
_ARRAY_ALLOC(array, (int)(array.i_alloc * 1.5) ) \
}
#define _ARRAY_SHRINK (   array)
Value:
{ \
if( (array).i_size > 10 && (array).i_size < (int)((array).i_alloc / 1.5) ) { \
_ARRAY_ALLOC(array, (array).i_size + 5); \
} \
}
#define ARRAY_APPEND (   array,
  elem 
)
Value:
do { \
_ARRAY_GROW1(array); \
(array).p_elems[(array).i_size] = elem; \
(array).i_size++; \
} while(0)

Referenced by AddItem(), FindArt(), playlist_ItemRelease(), playlist_NodeCreate(), ResetCurrentlyPlaying(), vlc_event_attach(), vlc_event_manager_register_event_type(), and vout_control_Push().

#define ARRAY_BSEARCH (   array,
  elem,
  zetype,
  key,
  answer 
)    BSEARCH( (array).p_elems, (array).i_size, elem, zetype, key, answer)
#define ARRAY_INIT (   array)
Value:
do { \
(array).i_alloc = 0; \
(array).i_size = 0; \
(array).p_elems = NULL; \
} while(0)

Referenced by playlist_Create(), playlist_fetcher_New(), vlc_event_manager_init(), vlc_event_manager_register_event_type(), and vout_control_Init().

#define ARRAY_INSERT (   array,
  elem,
  pos 
)
Value:
do { \
_ARRAY_GROW1(array); \
if( (array).i_size - pos ) { \
memmove( (array).p_elems + pos + 1, (array).p_elems + pos, \
((array).i_size-pos) * sizeof(*(array).p_elems) ); \
} \
(array).p_elems[pos] = elem; \
(array).i_size++; \
} while(0)
#define ARRAY_REMOVE (   array,
  pos 
)
Value:
do { \
if( (array).i_size - (pos) - 1 ) \
{ \
memmove( (array).p_elems + pos, (array).p_elems + pos + 1, \
( (array).i_size - pos - 1 ) *sizeof(*(array).p_elems) ); \
} \
(array).i_size--; \
_ARRAY_SHRINK(array); \
} while(0)

Referenced by ChangeToNode(), playlist_NodeDelete(), vlc_event_detach(), and vout_control_Pop().

#define ARRAY_RESET (   array)
Value:
do { \
(array).i_alloc = 0; \
(array).i_size = 0; \
free( (array).p_elems ); (array).p_elems = NULL; \
} while(0)

Referenced by playlist_Destroy(), ResetCurrentlyPlaying(), vlc_event_manager_fini(), and vout_control_Clean().

#define ARRAY_SIZE (   x)    (sizeof(x) / sizeof((x)[0]))
#define ARRAY_VAL (   array,
  pos 
)    array.p_elems[pos]
#define BSEARCH (   entries,
  count,
  elem,
  zetype,
  key,
  answer 
)
Value:
do { \
int low = 0, high = count - 1; \
answer = -1; \
while( low <= high ) {\
int mid = (low + high ) / 2; /* Just don't care about 2^30 tables */ \
zetype mid_val = entries[mid] elem;\
if( mid_val < key ) \
low = mid + 1; \
else if ( mid_val > key ) \
high = mid -1; \
else \
{ \
answer = mid; break; \
}\
} \
} while(0)

Binary search in a sorted array.

The key must be comparable by < and >

Parameters
entriesarray of entries
countnumber of entries
elemkey to check within an entry (like .id, or ->i_id)
zetypetype of the key
keyvalue of the key
answerindex of answer within the array. -1 if not found
#define DECL_ARRAY (   type)
Value:
struct { \
int i_alloc; \
int i_size; \
type *p_elems; \
}
#define FOREACH_ARRAY (   item,
  array 
)
Value:
{ \
int fe_idx; \
for( fe_idx = 0 ; fe_idx < (array).i_size ; fe_idx++ ) \
{ \
item = (array).p_elems[fe_idx];

Referenced by FindArt(), group_contains_listener(), playlist_Destroy(), vlc_event_attach(), vlc_event_detach(), vlc_event_manager_fini(), and vlc_event_send().

#define FOREACH_END ( )    } }
#define INSERT_ELEM (   p_ar,
  i_oldsize,
  i_pos,
  elem 
)
Value:
do \
{ \
if( !(i_oldsize) ) (p_ar) = NULL; \
(p_ar) = realloc( p_ar, ((i_oldsize) + 1) * sizeof(*(p_ar)) ); \
if( !(p_ar) ) abort(); \
if( (i_oldsize) - (i_pos) ) \
{ \
memmove( (p_ar) + (i_pos) + 1, (p_ar) + (i_pos), \
((i_oldsize) - (i_pos)) * sizeof( *(p_ar) ) ); \
} \
(p_ar)[(i_pos)] = elem; \
(i_oldsize)++; \
} \
while( 0 )

Simple dynamic array handling.

Array is realloced at each insert/removal

Referenced by info_category_ReplaceInfo(), info_category_VaAddInfo(), InitPrograms(), input_item_AddOption(), input_item_MergeInfos(), input_item_node_AppendNode(), input_item_ReplaceInfos(), InputItemVaAddInfo(), playlist_fetcher_Push(), playlist_NodeInsert(), playlist_preparser_Push(), playlist_TreeMove(), playlist_TreeMoveMany(), stats_Update(), var_AddCallback(), var_Change(), and var_Create().

#define REMOVE_ELEM (   p_ar,
  i_size,
  i_pos 
)
Value:
do \
{ \
if( (i_size) - (i_pos) - 1 ) \
{ \
memmove( (p_ar) + (i_pos), \
(p_ar) + (i_pos) + 1, \
((i_size) - (i_pos) - 1) * sizeof( *(p_ar) ) ); \
} \
if( i_size > 1 ) \
(p_ar) = realloc_down( p_ar, ((i_size) - 1) * sizeof( *(p_ar) ) );\
else \
{ \
free( p_ar ); \
(p_ar) = NULL; \
} \
(i_size)--; \
} \
while( 0 )

Referenced by info_category_DeleteInfo(), input_item_DelInfo(), input_item_node_Delete(), playlist_fetcher_Delete(), playlist_NodeRemoveItem(), playlist_preparser_Delete(), playlist_ServicesDiscoveryRemove(), playlist_TreeMove(), playlist_TreeMoveMany(), stats_CounterClean(), stats_Update(), Thread(), var_Change(), and var_DelCallback().

#define TAB_APPEND (   count,
  tab,
 
)    TAB_APPEND_CAST( , count, tab, p )
#define TAB_APPEND_CAST (   cast,
  count,
  tab,
 
)
Value:
do { \
if( (count) > 0 ) \
(tab) = cast realloc( tab, sizeof( void ** ) * ( (count) + 1 ) ); \
else \
(tab) = cast malloc( sizeof( void ** ) ); \
if( !(tab) ) abort(); \
(tab)[count] = (p); \
(count)++; \
} while(0)

Referenced by vlm_media_Copy().

#define TAB_CLEAN (   count,
  tab 
)
#define TAB_FIND (   count,
  tab,
  p,
  idx 
)
Value:
do { \
for( (idx) = 0; (idx) < (count); (idx)++ ) \
if( (tab)[(idx)] == (p) ) \
break; \
if( (idx) >= (count) ) \
(idx) = -1; \
} while(0)

Referenced by sout_MuxDeleteStream().

#define TAB_INIT (   count,
  tab 
)
#define TAB_INSERT (   count,
  tab,
  p,
  index 
)    TAB_INSERT_CAST( , count, tab, p, index )

Referenced by vlc_epg_Merge().

#define TAB_INSERT_CAST (   cast,
  count,
  tab,
  p,
  index 
)
Value:
do { \
if( (count) > 0 ) \
(tab) = cast realloc( tab, sizeof( void ** ) * ( (count) + 1 ) ); \
else \
(tab) = cast malloc( sizeof( void ** ) ); \
if( !(tab) ) abort(); \
if( (count) - (index) > 0 ) \
memmove( (void**)(tab) + (index) + 1, \
(void**)(tab) + (index), \
((count) - (index)) * sizeof(*(tab)) );\
(tab)[(index)] = (p); \
(count)++; \
} while(0)

Referenced by vlc_array_insert().

#define TAB_REMOVE (   count,
  tab,
 
)
Value:
do { \
int i_index; \
TAB_FIND( count, tab, p, i_index ); \
if( i_index >= 0 ) \
{ \
if( (count) > 1 ) \
{ \
memmove( ((void**)(tab) + i_index), \
((void**)(tab) + i_index+1), \
( (count) - i_index - 1 ) * sizeof( void* ) );\
} \
(count)--; \
if( (count) == 0 ) \
{ \
free( tab ); \
(tab) = NULL; \
} \
} \
} while(0)

Referenced by Del(), EsOutDel(), EsOutProgramDel(), httpd_HostDelete(), httpd_HostThread(), httpd_UrlDelete(), input_vaControl(), Manage(), RequestVout(), sout_MuxAddStream(), sout_MuxDeleteStream(), vlc_epg_Merge(), vlm_ControlMediaDel(), and vlm_MediaInstanceDelete().

#define TYPEDEF_ARRAY (   type,
  name 
)    typedef DECL_ARRAY(type) name;

Typedef Documentation

typedef struct vlc_array_t vlc_array_t

Function Documentation

static void __vlc_dictionary_insert ( vlc_dictionary_t p_dict,
const char *  psz_key,
void *  p_value,
bool  rebuild 
)
inlinestatic
static uint64_t DictHash ( const char *  psz_string,
int  hashsize 
)
inlinestatic
static void* realloc_down ( void *  ptr,
size_t  size 
)
inlinestatic
static void vlc_array_append ( vlc_array_t p_array,
void *  p_elem 
)
inlinestatic
static void vlc_array_clear ( vlc_array_t p_array)
inlinestatic
static int vlc_array_count ( vlc_array_t p_array)
inlinestatic
static void vlc_array_destroy ( vlc_array_t p_array)
inlinestatic

References vlc_array_clear().

Referenced by __ml_GetValue(), and ml_DeleteSimple().

static int vlc_array_index_of_item ( vlc_array_t p_array,
void *  item 
)
inlinestatic
static void vlc_array_init ( vlc_array_t p_array)
inlinestatic
static void vlc_array_insert ( vlc_array_t p_array,
void *  p_elem,
int  i_index 
)
inlinestatic
static void* vlc_array_item_at_index ( vlc_array_t p_array,
int  i_index 
)
inlinestatic
static vlc_array_t* vlc_array_new ( void  )
inlinestatic

References vlc_array_init().

Referenced by __ml_GetValue(), and ml_DeleteSimple().

static void vlc_array_remove ( vlc_array_t p_array,
int  i_index 
)
inlinestatic
static char** vlc_dictionary_all_keys ( const vlc_dictionary_t p_dict)
inlinestatic
static void vlc_dictionary_clear ( vlc_dictionary_t p_dict,
void(*)(void *p_data, void *p_obj)  pf_free,
void *  p_obj 
)
inlinestatic
static int vlc_dictionary_has_key ( const vlc_dictionary_t p_dict,
const char *  psz_key 
)
inlinestatic
static void vlc_dictionary_init ( vlc_dictionary_t p_dict,
int  i_size 
)
inlinestatic
static void vlc_dictionary_insert ( vlc_dictionary_t p_dict,
const char *  psz_key,
void *  p_value 
)
inlinestatic
static int vlc_dictionary_keys_count ( const vlc_dictionary_t p_dict)
inlinestatic
static void vlc_dictionary_remove_value_for_key ( const vlc_dictionary_t p_dict,
const char *  psz_key,
void(*)(void *p_data, void *p_obj)  pf_free,
void *  p_obj 
)
inlinestatic
static void* vlc_dictionary_value_for_key ( const vlc_dictionary_t p_dict,
const char *  psz_key 
)
inlinestatic

Variable Documentation

void* const kVLCDictionaryNotFound = NULL
static