11#ifndef __VALUE_STRING_H__
12#define __VALUE_STRING_H__
16#include "ws_symbol_export.h"
48 #define foo_VALUE_STRING_LIST(XXX) \
49 XXX( FOO_A, 1, "aaa" ) \
50 XXX( FOO_B, 3, "bbb" )
53 VALUE_STRING_ENUM(foo);
57 VALUE_STRING_ARRAY(foo);
60 VALUE_STRING_ARRAY_GLOBAL_DEF(foo);
61 VALUE_STRING_ARRAY_GLOBAL_DCL(foo);
64 #define bar_VALUE_STRING_LIST(XXX) \
68 VALUE_STRING_ENUM2(bar);
69 VALUE_STRING_ARRAY2(bar);
74#define VALUE_STRING_ENUM( array_name) _VS_ENUM_XXX( array_name, _VS_ENUM_ENTRY)
75#define VALUE_STRING_ARRAY( array_name) _VS_ARRAY_SC_XXX(array_name, _VS_ARRAY_ENTRY, static)
76#define VALUE_STRING_ARRAY_GLOBAL_DEF( array_name) _VS_ARRAY_XXX(array_name, _VS_ARRAY_ENTRY)
77#define VALUE_STRING_ARRAY_GLOBAL_DCL( array_name) _VS_ARRAY_SC_TYPE_NAME(array_name, extern)
79#define VALUE_STRING_ENUM2( array_name) _VS_ENUM_XXX( array_name, _VS_ENUM_ENTRY2)
80#define VALUE_STRING_ARRAY2( array_name) _VS_ARRAY_SC_XXX(array_name, _VS_ARRAY_ENTRY2, static)
81#define VALUE_STRING_ARRAY2_GLOBAL_DEF( array_name) _VS_ARRAY_XXX(array_name, _VS_ARRAY_ENTRY2)
82#define VALUE_STRING_ARRAY2_GLOBAL_DCL( array_name) _VS_ARRAY_SC_TYPE_NAME(array_name, extern)
85#define _VS_ENUM_XXX(array_name, macro) \
87 array_name##_VALUE_STRING_LIST(macro) \
88 _##array_name##_ENUM_DUMMY = 0 \
91#define _VS_ARRAY_SC_XXX(array_name, macro, sc) \
92 _VS_ARRAY_SC_TYPE_NAME(array_name, sc) = { \
93 array_name##_VALUE_STRING_LIST(macro) \
97#define _VS_ARRAY_XXX(array_name, macro) \
98 _VS_ARRAY_TYPE_NAME(array_name) = { \
99 array_name##_VALUE_STRING_LIST(macro) \
103#define _VS_ARRAY_SC_TYPE_NAME(array_name, sc) sc const value_string array_name[]
104#define _VS_ARRAY_TYPE_NAME(array_name) const value_string array_name[]
106#define _VS_ENUM_ENTRY( name, value, string) name = value,
107#define _VS_ARRAY_ENTRY(name, value, string) { value, string },
109#define _VS_ENUM_ENTRY2( name, value) name = value,
110#define _VS_ARRAY_ENTRY2(name, value) { value, #name },
335#define VALUE_STRING_EXT_VS_P(x) (x)->_vs_p
336#define VALUE_STRING_EXT_VS_NUM_ENTRIES(x) (x)->_vs_num_entries
337#define VALUE_STRING_EXT_VS_NAME(x) (x)->_vs_name
354#define VALUE_STRING_EXT_INIT(x) { _try_val_to_str_ext_init, 0, G_N_ELEMENTS(x)-1, x, #x, NULL }
483#define VAL64_STRING_EXT_VS_P(x) (x)->_vs_p
484#define VAL64_STRING_EXT_VS_NUM_ENTRIES(x) (x)->_vs_num_entries
485#define VAL64_STRING_EXT_VS_NAME(x) (x)->_vs_name
521#define VAL64_STRING_EXT_INIT(x) { _try_val64_to_str_ext_init, 0, G_N_ELEMENTS(x)-1, x, #x, NULL }
547val64_to_str_ext_const(
const uint64_t val,
val64_string_ext *vs,
const char *unknown_str);
624rval_to_str_const(
const uint32_t val,
const range_string *rs,
const char *unknown_str);
697 const uint8_t *value;
698 const size_t value_length;
722try_bytesval_to_str(
const uint8_t *val,
const size_t val_len,
const bytes_string *bs);
Definition value_string.h:696
Definition value_string.h:611
Definition value_string.h:567
Definition value_string.h:678
Extended metadata for a 64-bit value-string mapping array.
Definition value_string.h:474
const char * _vs_name
Definition value_string.h:479
uint64_t _vs_first_value
Definition value_string.h:476
unsigned _vs_num_entries
Definition value_string.h:477
_val64_string_match2_t _vs_match2
Definition value_string.h:475
wmem_allocator_t * _scope
Definition value_string.h:480
const val64_string * _vs_p
Definition value_string.h:478
Mapping between a 64-bit integer value and its string representation.
Definition value_string.h:196
uint64_t value
Definition value_string.h:197
const char * strptr
Definition value_string.h:198
Extended metadata for a value_string array.
Definition value_string.h:325
const value_string * _vs_p
Definition value_string.h:329
const char * _vs_name
Definition value_string.h:330
unsigned _vs_num_entries
Definition value_string.h:328
uint32_t _vs_first_value
Definition value_string.h:327
_value_string_match2_t _vs_match2
Definition value_string.h:326
wmem_allocator_t * _scope
Definition value_string.h:331
Mapping between a 32-bit integer value and its string representation.
Definition value_string.h:33
const char * strptr
Definition value_string.h:35
uint32_t value
Definition value_string.h:34
Internal memory allocator interface used by the wmem subsystem.
Definition wmem_allocator.h:34
WS_DLL_PUBLIC const char * value_string_ext_match_type_str(const value_string_ext *vse)
Returns a string representation of the match type for a value_string_ext.
Definition value_string.c:1067
WS_DLL_PUBLIC value_string_ext * value_string_ext_new(wmem_allocator_t *scope, const value_string *vs, unsigned vs_tot_num_entries, const char *vs_name)
Create a new extended value-string mapping structure.
Definition value_string.c:258
WS_DLL_PUBLIC const char * try_val_to_str_idx(const uint32_t val, const value_string *vs, int *idx)
Attempt to convert a numeric value to a string and retrieve its index.
Definition value_string.c:90
WS_DLL_PUBLIC const char * try_bytesprefix_to_str(const uint8_t *haystack, const size_t haystack_len, const bytes_string *bs)
Tries to find a string representation for a byte prefix in a bytes_string array.
Definition value_string.c:991
WS_DLL_PUBLIC const char * try_val_to_str_ext(const uint32_t val, value_string_ext *vse)
Attempt to convert a numeric value to a string using an extended value-string mapping.
Definition value_string.c:289
struct _val64_string val64_string
Mapping between a 64-bit integer value and its string representation.
WS_DLL_PUBLIC const char * try_rval_to_str(const uint32_t val, const range_string *rs)
Convert a 32-bit unsigned integer to its corresponding string representation based on a range string.
Definition value_string.c:872
WS_DLL_PUBLIC const char * try_time_val_to_str(const nstime_t *val, const time_value_string *vs)
Tries to match a time value against an array of time_value_string entries.
Definition value_string.c:913
WS_DLL_PUBLIC char * val_to_str(wmem_allocator_t *scope, const uint32_t val, const value_string *vs, const char *fmt)
Convert a numeric value to a string using a value-string mapping.
Definition value_string.c:51
WS_DLL_PUBLIC int value_str_value_compare(const void *a, const void *b)
Compare two value_string entries by their numeric value.
Definition value_string.c:32
WS_DLL_PUBLIC const char * try_val_to_str(const uint32_t val, const value_string *vs)
Attempt to convert a numeric value to a string using a value-string mapping.
Definition value_string.c:112
WS_DLL_PUBLIC void value_string_ext_free(value_string_ext *vse)
Free an extended value-string mapping structure.
Definition value_string.c:282
WS_DLL_PUBLIC value_string * get_external_value_string(const char *name)
Retrieves an external value string by name.
Definition value_string.c:1028
WS_DLL_PUBLIC char * val_to_str_ext(wmem_allocator_t *scope, const uint32_t val, value_string_ext *vse, const char *fmt)
Convert a numeric value to a string using an extended value-string mapping.
Definition value_string.c:319
WS_DLL_PUBLIC const char * try_val_to_str_idx_ext(const uint32_t val, value_string_ext *vse, int *idx)
Attempt to convert a numeric value to a string and retrieve its index from an extended mapping.
Definition value_string.c:304
WS_DLL_PUBLIC const char * val64_to_str_wmem(wmem_allocator_t *scope, const uint64_t val, const val64_string *vs, const char *fmt)
Convert a 64-bit value to a string using a value-string mapping.
Definition value_string.c:120
WS_DLL_PUBLIC const char * try_val64_to_str(const uint64_t val, const val64_string *vs)
Attempt to convert a 64-bit value to a string using a value-string mapping.
Definition value_string.c:173
WS_DLL_PUBLIC void value_string_externals_cleanup(void)
Cleans up external value string resources.
Definition value_string.c:1015
WS_DLL_PUBLIC const char * val_to_str_ext_const(const uint32_t val, value_string_ext *vs, const char *unknown_str)
Convert a numeric value to a constant string using an extended value-string mapping.
Definition value_string.c:335
WS_DLL_PUBLIC bool val64_string_ext_validate(const val64_string_ext *vse)
Validates a value_string_ext structure.
Definition value_string.c:1081
WS_DLL_PUBLIC int str_to_val_idx(const char *val, const value_string *vs)
Retrieve the index of a string in a value-string mapping array.
Definition value_string.c:200
WS_DLL_PUBLIC const char * try_rval_to_str_idx(const uint32_t val, const range_string *rs, int *idx)
Converts a 32-bit unsigned integer value to its corresponding string representation based on a range_...
Definition value_string.c:852
WS_DLL_PUBLIC val64_string_ext * val64_string_ext_new(wmem_allocator_t *scope, const val64_string *vs, unsigned vs_tot_num_entries, const char *vs_name)
Create a new extended value string structure.
Definition value_string.c:530
WS_DLL_PUBLIC const char * try_val64_to_str_idx_ext(const uint64_t val, val64_string_ext *vse, int *idx)
Convert a 64-bit value to its corresponding string index and pointer.
Definition value_string.c:576
WS_DLL_PUBLIC bool value_string_ext_validate(const value_string_ext *vse)
Validates a value_string_ext structure.
Definition value_string.c:1052
struct _value_string value_string
Mapping between a 32-bit integer value and its string representation.
WS_DLL_PUBLIC const char * bytesprefix_to_str(wmem_allocator_t *scope, const uint8_t *haystack, const size_t haystack_len, const bytes_string *bs, const char *fmt)
Convert a byte prefix to a string using a value_string array.
Definition value_string.c:973
WS_DLL_PUBLIC void register_external_value_string(const char *name, const value_string *vs)
Registers an external value string with a given name.
Definition value_string.c:1022
WS_DLL_PUBLIC const value_string * _try_val_to_str_ext_init(const uint32_t val, value_string_ext *vse)
Attempt to initialize and retrieve a value-string entry from an extended mapping.
Definition value_string.c:402
WS_DLL_PUBLIC const char * try_str_to_str(const char *val, const string_string *vs)
Converts a string to another string based on a value-string mapping.
Definition value_string.c:806
WS_DLL_PUBLIC const char * val_to_str_const(const uint32_t val, const value_string *vs, const char *unknown_str)
Convert a numeric value to a constant string using a value-string mapping.
Definition value_string.c:70
WS_DLL_PUBLIC const char * val64_to_str_const(const uint64_t val, const val64_string *vs, const char *unknown_str)
Convert a 64-bit value to a constant string using a value-string mapping.
Definition value_string.c:136
WS_DLL_PUBLIC const char * str_to_str_wmem(wmem_allocator_t *scope, const char *val, const string_string *vs, const char *fmt)
Converts a string value to a formatted string using a value string table.
Definition value_string.c:770
WS_DLL_PUBLIC void register_external_value_string_ext(const char *name, const value_string_ext *vse)
Registers an external value string extension.
Definition value_string.c:1034
WS_DLL_PUBLIC const val64_string * _try_val64_to_str_ext_init(const uint64_t val, val64_string_ext *vse)
Attempt to initialize and retrieve a 64-bit value-string entry from an extended mapping.
Definition value_string.c:673
WS_DLL_PUBLIC const char * try_val64_to_str_idx(const uint64_t val, const val64_string *vs, int *idx)
Attempt to convert a 64-bit value to a string and retrieve its index.
Definition value_string.c:152
WS_DLL_PUBLIC const char * try_rval64_to_str(const uint64_t val, const range_string *rs)
Convert a 64-bit unsigned integer value to a string based on a range of strings.
Definition value_string.c:900
WS_DLL_PUBLIC const char * bytesval_to_str_wmem(wmem_allocator_t *scope, const uint8_t *val, const size_t val_len, const bytes_string *bs, const char *fmt)
Converts a byte value to a string using a format string.
Definition value_string.c:933
WS_DLL_PUBLIC void value_string_externals_init(void)
Initializes external value string and extension registries.
Definition value_string.c:1009
WS_DLL_PUBLIC const char * try_rval64_to_str_idx(const uint64_t val, const range_string *rs, int *idx)
Converts a 64-bit unsigned integer value to its corresponding string representation based on a range ...
Definition value_string.c:880
WS_DLL_PUBLIC const char * try_str_to_str_idx(const char *val, const string_string *vs, int *idx)
Converts a string to an index in a string-string mapping table.
Definition value_string.c:786
WS_DLL_PUBLIC uint32_t str_to_val(const char *val, const value_string *vs, const uint32_t err_val)
Convert a string to its corresponding numeric value using a value-string mapping.
Definition value_string.c:185
WS_DLL_PUBLIC const char * val64_string_ext_match_type_str(const val64_string_ext *vse)
Returns a string representation of the match type for a 64-bit value string extension.
Definition value_string.c:1096
WS_DLL_PUBLIC value_string_ext * get_external_value_string_ext(const char *name)
Retrieves an external value string extension by name.
Definition value_string.c:1040