aboutsummaryrefslogtreecommitdiffstats
path: root/epan/value_string.h
diff options
context:
space:
mode:
Diffstat (limited to 'epan/value_string.h')
-rw-r--r--epan/value_string.h201
1 files changed, 75 insertions, 126 deletions
diff --git a/epan/value_string.h b/epan/value_string.h
index bfdb33bb05..cdb8a8272a 100644
--- a/epan/value_string.h
+++ b/epan/value_string.h
@@ -28,93 +28,31 @@
#include <glib.h>
#include "ws_symbol_export.h"
-/* Struct for the val_to_str, match_strval_idx, and match_strval functions */
+/* VALUE TO STRING MATCHING */
typedef struct _value_string {
guint32 value;
const gchar *strptr;
} value_string;
-/* Struct for the str_to_str, match_strstr_idx, and match_strstr functions */
+WS_DLL_PUBLIC
+const gchar*
+val_to_str(const guint32 val, const value_string *vs, const char *fmt);
-typedef struct _string_string {
- const gchar *value;
- const gchar *strptr;
-} string_string;
-
-/* Struct for the rval_to_str, match_strrval_idx, and match_strrval functions */
-typedef struct _range_string {
- guint32 value_min;
- guint32 value_max;
- const gchar *strptr;
-} range_string;
-
-/* #define VS_DEF(x) { x, #x } */
-/* #define VS_END { 0, NULL } */
-
-/* Tries to match val against each element in the value_string array vs.
- Returns the associated string ptr, and sets "*idx" to the index in
- that table, on a match, and returns NULL, and sets "*idx" to -1,
- on failure. */
-WS_DLL_PUBLIC const gchar* match_strval_idx(const guint32 val, const value_string *vs, gint *idx);
-
-/* Like match_strval_idx(), but doesn't return the index. */
-WS_DLL_PUBLIC const gchar* match_strval(const guint32 val, const value_string *vs);
-
-/* Tries to match val against each element in the value_string array vs.
- Returns the associated string ptr on a match.
- Formats val with fmt, and returns the resulting string, on failure. */
-WS_DLL_PUBLIC const gchar* val_to_str(const guint32 val, const value_string *vs, const char *fmt);
+WS_DLL_PUBLIC
+const gchar*
+val_to_str_const(const guint32 val, const value_string *vs, const char *unknown_str);
+WS_DLL_PUBLIC
+const gchar*
+try_val_to_str(const guint32 val, const value_string *vs);
-/* Tries to match val against each element in the value_string array vs.
- Returns the associated string ptr on a match.
- Returns 'unknown_str', on failure. */
-WS_DLL_PUBLIC const gchar* val_to_str_const(const guint32 val, const value_string *vs, const char *unknown_str);
+WS_DLL_PUBLIC
+const gchar*
+try_val_to_str_idx(const guint32 val, const value_string *vs, gint *idx);
-/* Tries to match val against each element in the string_string array vs.
- Returns the associated string ptr, and sets "*idx" to the index in
- that table, on a match, and returns NULL, and sets "*idx" to -1,
- on failure. */
-extern const gchar* match_strstr_idx(const gchar *val, const string_string *vs, gint *idx);
+/* EXTENDED VALUE TO STRING MATCHING */
-/* Like match_strstr_idx(), but doesn't return the index. */
-extern const gchar* match_strstr(const gchar *val, const string_string *vs);
-
-/* Tries to match val against each element in the string_string array vs.
- Returns the associated string ptr on a match.
- Formats val with fmt, and returns the resulting string, on failure. */
-WS_DLL_PUBLIC const gchar* str_to_str(const gchar *val, const string_string *vs, const char *fmt);
-
-/* --------------------------------------------------------------------*/
-/* value_string_ext functions
- *
- * Extended value strings allow fast(er) value_string array lookups by
- * using (if possible) direct access or a binary search of the array.
- *
- * If the values in the value_string array are a contiguous range of values
- * from min to max, the value will be used as as a direct index into the array.
- *
- * If the values in the array are not contiguous (ie: there are "gaps"),
- * but are in assending order a binary search will be used.
- *
- * If direct access or binary search cannot be used, then a linear search
- * is used.
- *
- * Note that the value_string array used with VALUE_STRING_EXT_INIT
- * *must* be terminated with {0, NULL}).
- *
- * Extended value strings are defined at compile time as follows:
- * static const value_string vs[] = { {value1, "string1"}, {value2, "string2"}, ..., {0, NULL}};
- * static value_string_ext vse = VALUE_STRING_EXT_INIT(vs);
- *
- * Extended value strings can be created at runtime by calling
- * value_string_ext_new(<ptr to value_string array>,
- * <total number of entries in the value_string_array>,
- * <value_string_name>);
- * Note: <total number of entries in the value_string_array> should include the {0, NULL} entry
- */
-/* --------------------------------------------------------------------*/
struct _value_string_ext;
typedef const value_string *(*_value_string_match2_t)(const guint32, const struct _value_string_ext *);
@@ -127,50 +65,78 @@ typedef struct _value_string_ext {
const gchar *_vs_name; /* vse "Name" (for error messages) */
} value_string_ext;
-/* "Accessors" */
#define VALUE_STRING_EXT_VS_P(x) (x)->_vs_p
#define VALUE_STRING_EXT_VS_NUM_ENTRIES(x) (x)->_vs_num_entries
#define VALUE_STRING_EXT_VS_NAME(x) (x)->_vs_name
-/* (Fcns for use by proto_registrar_dump_values() [See proto.c]) */
-gboolean value_string_ext_validate(const value_string_ext *vse);
-const gchar *value_string_ext_match_type_str(const value_string_ext *vse);
-/* --- --- */
+WS_DLL_PUBLIC
+const value_string*
+_try_val_to_str_ext_init(const guint32 val, const value_string_ext *vse);
+#define VALUE_STRING_EXT_INIT(x) { _try_val_to_str_ext_init, 0, array_length(x)-1, x, #x }
-WS_DLL_PUBLIC const value_string *_match_strval_ext_init(const guint32 val, const value_string_ext *vse);
-#define VALUE_STRING_EXT_INIT(x) { _match_strval_ext_init, 0, array_length(x)-1, x, #x }
+WS_DLL_PUBLIC
+value_string_ext*
+value_string_ext_new(value_string *vs, guint vs_tot_num_entries, const gchar *vs_name);
-/* Create a value_string_ext given a ptr to a value_string array and the total number of entries. */
-/* Note: vs_tot_num_entries should include the required {0, NULL} terminating entry of the array. */
-/* Return: a pointer to a gmalloc'd and initialized value_string_ext struct. */
-extern value_string_ext *value_string_ext_new(value_string *vs, guint vs_tot_num_entries, const gchar *vs_name);
+WS_DLL_PUBLIC
+const gchar*
+val_to_str_ext(const guint32 val, const value_string_ext *vs, const char *fmt);
-/* Looks up val in a value_string array using access method (direct, binary search
- * or linear) determined at rutime during the initial access); (see _match_strval_ext_init)
- * Returns the associated string ptr on a match or NULL on failure.
- */
-WS_DLL_PUBLIC const gchar* match_strval_ext(const guint32 val, const value_string_ext *vse);
+WS_DLL_PUBLIC
+const gchar*
+val_to_str_ext_const(const guint32 val, const value_string_ext *vs, const char *unknown_str);
-/* Tries to match val against each element in the value_string array vs.
- * Returns the associated string ptr, and sets "*idx" to the index in
- * that table, on a match, and returns NULL, and sets "*idx" to -1,
- * on failure.
- */
-const gchar* match_strval_idx_ext(const guint32 val, value_string_ext *vse, gint *idx);
+WS_DLL_PUBLIC
+const gchar*
+try_val_to_str_ext(const guint32 val, const value_string_ext *vse);
-/*
- Similar to match_strval_ext except that on failure
- * Formats val with fmt, and returns the resulting string
- */
-WS_DLL_PUBLIC const gchar* val_to_str_ext(const guint32 val, const value_string_ext *vs, const char *fmt);
+WS_DLL_PUBLIC
+const gchar*
+try_val_to_str_idx_ext(const guint32 val, value_string_ext *vse, gint *idx);
-/*
- Similar to match_strval_ext except that on failure
- * Returns 'unknown_str'
- */
-WS_DLL_PUBLIC const gchar* val_to_str_ext_const(const guint32 val, const value_string_ext *vs, const char *unknown_str);
+/* STRING TO STRING MATCHING */
+
+typedef struct _string_string {
+ const gchar *value;
+ const gchar *strptr;
+} string_string;
+
+WS_DLL_PUBLIC
+const gchar*
+str_to_str(const gchar *val, const string_string *vs, const char *fmt);
+
+WS_DLL_PUBLIC
+const gchar*
+try_str_to_str(const gchar *val, const string_string *vs);
+
+WS_DLL_PUBLIC
+const gchar*
+try_str_to_str_idx(const gchar *val, const string_string *vs, gint *idx);
+
+/* RANGE TO STRING MATCHING */
+
+typedef struct _range_string {
+ guint32 value_min;
+ guint32 value_max;
+ const gchar *strptr;
+} range_string;
+
+WS_DLL_PUBLIC
+const gchar*
+rval_to_str(const guint32 val, const range_string *rs, const char *fmt);
+
+WS_DLL_PUBLIC
+const gchar*
+try_rval_to_str(const guint32 val, const range_string *rs);
+
+WS_DLL_PUBLIC
+const gchar*
+try_rval_to_str_idx(const guint32 val, const range_string *rs, gint *idx);
+
+/* MISC (generally do not use) */
-/* ---- ---- */
+gboolean value_string_ext_validate(const value_string_ext *vse);
+const gchar *value_string_ext_match_type_str(const value_string_ext *vse);
/* Generate a string describing an enumerated bitfield (an N-bit field
with various specific values having particular names). */
@@ -182,21 +148,4 @@ WS_DLL_PUBLIC const char *decode_enumerated_bitfield(const guint32 val, const gu
WS_DLL_PUBLIC const char *decode_enumerated_bitfield_shifted(const guint32 val, const guint32 mask,
const int width, const value_string *tab, const char *fmt);
-
-/* ranges aware versions */
-
-/* Tries to match val against each range in the range_string array rs.
- Returns the associated string ptr on a match.
- Formats val with fmt, and returns the resulting string, on failure. */
-WS_DLL_PUBLIC const gchar* rval_to_str(const guint32 val, const range_string *rs, const char *fmt);
-
-/* Tries to match val against each range in the range_string array rs.
- Returns the associated string ptr, and sets "*idx" to the index in
- that table, on a match, and returns NULL, and sets "*idx" to -1,
- on failure. */
-WS_DLL_PUBLIC const gchar *match_strrval_idx(const guint32 val, const range_string *rs, gint *idx);
-
-/* Like match_strrval_idx(), but doesn't return the index. */
-WS_DLL_PUBLIC const gchar *match_strrval(const guint32 val, const range_string *rs);
-
#endif /* __VALUE_STRING_H__ */