A map that holds pointers to objects indexed by id.  
More...
|  | 
| PW_API_MAP void | pw_map_init (struct pw_map *map, size_t size, size_t extend) | 
|  | Initialize a map. 
 | 
|  | 
| PW_API_MAP void | pw_map_clear (struct pw_map *map) | 
|  | Clear a map and free the data storage. 
 | 
|  | 
| PW_API_MAP void | pw_map_reset (struct pw_map *map) | 
|  | Reset a map but keep previously allocated storage. 
 | 
|  | 
| PW_API_MAP uint32_t | pw_map_insert_new (struct pw_map *map, void *data) | 
|  | Insert data in the map. 
 | 
|  | 
| PW_API_MAP int | pw_map_insert_at (struct pw_map *map, uint32_t id, void *data) | 
|  | Replace the data in the map at an index. 
 | 
|  | 
| PW_API_MAP void | pw_map_remove (struct pw_map *map, uint32_t id) | 
|  | Remove an item at index. 
 | 
|  | 
| PW_API_MAP void * | pw_map_lookup (const struct pw_map *map, uint32_t id) | 
|  | Find an item in the map. 
 | 
|  | 
| PW_API_MAP int | pw_map_for_each (const struct pw_map *map, int(*func)(void *item_data, void *data), void *data) | 
|  | Iterate all map items. 
 | 
|  | 
A map that holds pointers to objects indexed by id. 
The map is a sparse version of the pw_array that manages the indices of elements for the caller. Adding items with pw_map_insert_new() returns the assigned index for that item; if items are removed the map re-uses indices to keep the array at the minimum required size.
 
PW_API_MAP void pw_map_remove(struct pw_map *map, uint32_t id)
Remove an item at index.
Definition map.h:190
PW_API_MAP uint32_t pw_map_insert_new(struct pw_map *map, void *data)
Insert data in the map.
Definition map.h:138
#define PW_MAP_INIT(extend)
Definition map.h:78
A map.
Definition map.h:71
  
◆ PW_MAP_INIT
      
        
          | #define PW_MAP_INIT | ( |  | extend | ) |  | 
      
 
Value:
#define PW_ARRAY_INIT(extend)
Initialize an array.
Definition array.h:48
#define SPA_ID_INVALID
Definition defs.h:250
 - Parameters
- 
  
    | extend | the amount of bytes to grow the map with when needed |  
 
 
 
◆ pw_map_get_size
      
        
          | #define pw_map_get_size | ( |  | m | ) |  | 
      
 
Value:
#define pw_array_get_len(a, t)
Get the number of items of type t in array.
Definition array.h:56
 
Get the number of currently allocated elements in the map. 
- Note
- pw_map_get_size() returns the currently allocated number of elements in the map, not the number of actually set elements. 
- Returns
- the number of available elements before the map needs to grow 
 
 
◆ pw_map_get_item
      
        
          | #define pw_map_get_item | ( |  | m, | 
        
          |  |  |  | id ) | 
      
 
Value:
#define pw_array_get_unchecked(a, idx, t)
Get the item with index idx and type t from array.
Definition array.h:58
 
 
 
◆ pw_map_item_is_free
      
        
          | #define pw_map_item_is_free | ( |  | item | ) |  | 
      
 
 
◆ pw_map_id_is_free
      
        
          | #define pw_map_id_is_free | ( |  | m, | 
        
          |  |  |  | id ) | 
      
 
Value:
#define pw_map_item_is_free(item)
Definition map.h:88
#define pw_map_get_item(m, id)
Definition map.h:87
 
 
 
◆ pw_map_check_id
      
        
          | #define pw_map_check_id | ( |  | m, | 
        
          |  |  |  | id ) | 
      
 
Value:
uint32_t id
Definition core.h:432
#define pw_map_get_size(m)
Get the number of currently allocated elements in the map.
Definition map.h:86
 - Returns
- true if the id fits within the current map size 
 
 
◆ pw_map_has_item
      
        
          | #define pw_map_has_item | ( |  | m, | 
        
          |  |  |  | id ) | 
      
 
Value:
#define pw_map_check_id(m, id)
Definition map.h:91
#define pw_map_id_is_free(m, id)
Definition map.h:89
 - Returns
- true if there is a valid item at id 
 
 
◆ pw_map_lookup_unchecked
      
        
          | #define pw_map_lookup_unchecked | ( |  | m, | 
        
          |  |  |  | id ) | 
      
 
 
◆ PW_MAP_ID_TO_PTR
      
        
          | #define PW_MAP_ID_TO_PTR | ( |  | id | ) |  | 
      
 
Value:
#define SPA_UINT32_TO_PTR(u)
Definition defs.h:243
 
Convert an id to a pointer that can be inserted into the map. 
 
 
◆ PW_MAP_PTR_TO_ID
      
        
          | #define PW_MAP_PTR_TO_ID | ( |  | p | ) |  | 
      
 
Value:
#define SPA_PTR_TO_UINT32(p)
Definition defs.h:241
 
Convert a pointer to an id that can be retrieved from the map. 
 
 
◆ pw_map_init()
Initialize a map. 
- Parameters
- 
  
    | map | the map to initialize |  | size | the initial size of the map |  | extend | the amount to bytes to grow the map with when needed |  
 
 
 
◆ pw_map_clear()
Clear a map and free the data storage. 
All previously returned ids must be treated as invalid. 
 
 
◆ pw_map_reset()
Reset a map but keep previously allocated storage. 
All previously returned ids must be treated as invalid. 
 
 
◆ pw_map_insert_new()
Insert data in the map. 
This function causes the map to grow if required. 
- Parameters
- 
  
    | map | the map to insert into |  | data | the item to add |  
 
- Returns
- the id where the item was inserted or SPA_ID_INVALID when the item can not be inserted. 
 
 
◆ pw_map_insert_at()
      
        
          | PW_API_MAP int pw_map_insert_at | ( | struct pw_map * | map, | 
        
          |  |  | uint32_t | id, | 
        
          |  |  | void * | data ) | 
      
 
Replace the data in the map at an index. 
- Parameters
- 
  
    | map | the map to insert into |  | id | the index to insert at, must be less or equal to pw_map_get_size() |  | data | the data to insert |  
 
- Returns
- 0 on success, -ENOSPC value when the index is invalid or a negative errno 
 
 
◆ pw_map_remove()
Remove an item at index. 
The id may get re-used in the future.
- Parameters
- 
  
    | map | the map to remove from |  | id | the index to remove |  
 
 
 
◆ pw_map_lookup()
Find an item in the map. 
- Parameters
- 
  
    | map | the map to use |  | id | the index to look at |  
 
- Returns
- the item at id or NULL when no such item exists 
 
 
◆ pw_map_for_each()
      
        
          | PW_API_MAP int pw_map_for_each | ( | const struct pw_map * | map, | 
        
          |  |  | int(* | func )(void *item_data, void *data), | 
        
          |  |  | void * | data ) | 
      
 
Iterate all map items. 
- Parameters
- 
  
    | map | the map to iterate |  | func | the function to call for each item, the item data and data is passed to the function. When func returns a non-zero result, iteration ends and the result is returned. |  | data | data to pass to func |  
 
- Returns
- the result of the last call to func or 0 when all callbacks returned 0.