aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--epan/Makefile.am6
-rw-r--r--epan/Makefile.nmake1
-rw-r--r--epan/packet.c54
-rw-r--r--epan/packet.h14
-rw-r--r--epan/value_string.c90
-rw-r--r--epan/value_string.h44
6 files changed, 142 insertions, 67 deletions
diff --git a/epan/Makefile.am b/epan/Makefile.am
index e6eebdb6a6..6c824fdc3f 100644
--- a/epan/Makefile.am
+++ b/epan/Makefile.am
@@ -2,7 +2,7 @@
# Automake file for the EPAN library
# (Ethereal Protocol ANalyzer Library)
#
-# $Id: Makefile.am,v 1.18 2001/04/01 02:47:55 hagbard Exp $
+# $Id: Makefile.am,v 1.19 2001/04/01 03:18:41 hagbard Exp $
#
# Ethereal - Network traffic analyzer
# By Gerald Combs <gerald@zing.org>
@@ -67,7 +67,9 @@ libethereal_a_SOURCES = \
to_str.c \
to_str.h \
tvbuff.c \
- tvbuff.h
+ tvbuff.h \
+ value_string.c \
+ value_string.h
EXTRA_libethereal_a_SOURCES = \
inet_aton.c \
diff --git a/epan/Makefile.nmake b/epan/Makefile.nmake
index 5c87123281..31bd83da88 100644
--- a/epan/Makefile.nmake
+++ b/epan/Makefile.nmake
@@ -36,6 +36,7 @@ OBJECTS=atalk-utils.obj \
strutil.obj \
to_str.obj \
tvbuff.obj \
+ value_string.obj \
all: ftypes dfilter ethereal.lib
diff --git a/epan/packet.c b/epan/packet.c
index 7cf1872d0f..cb5c89132c 100644
--- a/epan/packet.c
+++ b/epan/packet.c
@@ -1,7 +1,7 @@
/* packet.c
* Routines for packet disassembly
*
- * $Id: packet.c,v 1.25 2001/04/01 02:47:55 hagbard Exp $
+ * $Id: packet.c,v 1.26 2001/04/01 03:18:41 hagbard Exp $
*
* Ethereal - Network traffic analyzer
* By Gerald Combs <gerald@zing.org>
@@ -127,58 +127,6 @@ packet_cleanup(void)
/* nothing */
}
-/* 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. */
-gchar*
-val_to_str(guint32 val, const value_string *vs, const char *fmt) {
- gchar *ret;
- static gchar str[3][64];
- static gchar *cur;
-
- ret = match_strval(val, vs);
- if (ret != NULL)
- return ret;
- if (cur == &str[0][0]) {
- cur = &str[1][0];
- } else if (cur == &str[1][0]) {
- cur = &str[2][0];
- } else {
- cur = &str[0][0];
- }
- snprintf(cur, 64, fmt, val);
- return cur;
-}
-
-/* Tries to match val against each element in the value_string array vs.
- Returns the associated string ptr on a match, or NULL on failure. */
-gchar*
-match_strval(guint32 val, const value_string *vs) {
- gint i = 0;
-
- while (vs[i].strptr) {
- if (vs[i].value == val)
- return(vs[i].strptr);
- i++;
- }
-
- return(NULL);
-}
-
-/* Generate a string describing an enumerated bitfield (an N-bit field
- with various specific values having particular names). */
-const char *
-decode_enumerated_bitfield(guint32 val, guint32 mask, int width,
- const value_string *tab, const char *fmt)
-{
- static char buf[1025];
- char *p;
-
- p = decode_bitfield_value(buf, val, mask, width);
- sprintf(p, fmt, val_to_str(val & mask, tab, "Unknown"));
- return buf;
-}
-
/* Allocate all the data structures for constructing column data, given
the number of columns. */
void
diff --git a/epan/packet.h b/epan/packet.h
index 7b7fb84fee..54335f7b52 100644
--- a/epan/packet.h
+++ b/epan/packet.h
@@ -1,7 +1,7 @@
/* packet.h
* Definitions for packet disassembly structures and routines
*
- * $Id: packet.h,v 1.25 2001/04/01 02:47:55 hagbard Exp $
+ * $Id: packet.h,v 1.26 2001/04/01 03:18:41 hagbard Exp $
*
* Ethereal - Network traffic analyzer
* By Gerald Combs <gerald@zing.org>
@@ -32,6 +32,7 @@
#include "tvbuff.h"
#include "pint.h"
#include "to_str.h"
+#include "value_string.h"
#define hi_nibble(b) (((b) & 0xf0) >> 4)
#define lo_nibble(b) ((b) & 0x0f)
@@ -189,13 +190,6 @@ typedef struct _packet_info {
extern packet_info pi;
-/* Struct for the match_strval function */
-
-typedef struct _value_string {
- guint32 value;
- gchar *strptr;
-} value_string;
-
/* Struct for boolean enumerations */
typedef struct true_false_string {
char *true_string;
@@ -328,10 +322,6 @@ void call_dissector(dissector_handle_t handle, tvbuff_t *tvb,
packet_info *pinfo, proto_tree *tree);
/* Utility routines used by packet*.c */
-gchar* val_to_str(guint32, const value_string *, const char *);
-gchar* match_strval(guint32, const value_string*);
-const char *decode_enumerated_bitfield(guint32 val, guint32 mask, int width,
- const value_string *tab, const char *fmt);
void col_set_writable(frame_data *fd, gboolean writable);
gint check_col(frame_data *, gint);
diff --git a/epan/value_string.c b/epan/value_string.c
new file mode 100644
index 0000000000..66e0150e66
--- /dev/null
+++ b/epan/value_string.c
@@ -0,0 +1,90 @@
+/* value_string.c
+ * Routines for value_strings
+ *
+ * $Id: value_string.c,v 1.1 2001/04/01 03:18:41 hagbard Exp $
+ *
+ * Ethereal - Network traffic analyzer
+ * By Gerald Combs <gerald@zing.org>
+ * Copyright 1998 Gerald Combs
+ *
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#ifdef HAVE_CONFIG_H
+# include "config.h"
+#endif
+
+#include <stdio.h>
+
+#ifdef NEED_SNPRINTF_H
+# include "snprintf.h"
+#endif
+#include "to_str.h"
+#include "value_string.h"
+
+/* 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. */
+gchar*
+val_to_str(guint32 val, const value_string *vs, const char *fmt) {
+ gchar *ret;
+ static gchar str[3][64];
+ static gchar *cur;
+
+ ret = match_strval(val, vs);
+ if (ret != NULL)
+ return ret;
+ if (cur == &str[0][0]) {
+ cur = &str[1][0];
+ } else if (cur == &str[1][0]) {
+ cur = &str[2][0];
+ } else {
+ cur = &str[0][0];
+ }
+ snprintf(cur, 64, fmt, val);
+ return cur;
+}
+
+/* Tries to match val against each element in the value_string array vs.
+ Returns the associated string ptr on a match, or NULL on failure. */
+gchar*
+match_strval(guint32 val, const value_string *vs) {
+ gint i = 0;
+
+ while (vs[i].strptr) {
+ if (vs[i].value == val)
+ return(vs[i].strptr);
+ i++;
+ }
+
+ return(NULL);
+}
+
+/* Generate a string describing an enumerated bitfield (an N-bit field
+ with various specific values having particular names). */
+const char *
+decode_enumerated_bitfield(guint32 val, guint32 mask, int width,
+ const value_string *tab, const char *fmt)
+{
+ static char buf[1025];
+ char *p;
+
+ p = decode_bitfield_value(buf, val, mask, width);
+ sprintf(p, fmt, val_to_str(val & mask, tab, "Unknown"));
+ return buf;
+}
+
+
diff --git a/epan/value_string.h b/epan/value_string.h
new file mode 100644
index 0000000000..b90d072a14
--- /dev/null
+++ b/epan/value_string.h
@@ -0,0 +1,44 @@
+/* value_string.h
+ * Definitions for value_string structures and routines
+ *
+ * $Id: value_string.h,v 1.1 2001/04/01 03:18:41 hagbard Exp $
+ *
+ * Ethereal - Network traffic analyzer
+ * By Gerald Combs <gerald@zing.org>
+ * Copyright 1998 Gerald Combs
+ *
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
+ */
+
+#ifndef __VALUE_STRING_H__
+#define __VALUE_STRING_H__
+
+#include <glib.h>
+
+/* Struct for the match_strval function */
+
+typedef struct _value_string {
+ guint32 value;
+ gchar *strptr;
+} value_string;
+
+gchar* match_strval(guint32, const value_string*);
+
+gchar* val_to_str(guint32, const value_string *, const char *);
+const char *decode_enumerated_bitfield(guint32 val, guint32 mask, int width,
+ const value_string *tab, const char *fmt);
+
+#endif /* __VALUE_STRING_H__ */