diff options
author | Guy Harris <guy@alum.mit.edu> | 2016-03-30 18:44:01 -0700 |
---|---|---|
committer | Guy Harris <guy@alum.mit.edu> | 2016-04-03 22:21:29 +0000 |
commit | 59816ef00c6dd09532d80b393ba03f8194aba236 (patch) | |
tree | f5e84c67ebe0e69542db94d56db70fa476c0db6c /epan/dfilter/dfilter-int.h | |
parent | e42a43bc58a36848316adae19981878a5f430c46 (diff) |
Make the Flex scanners and YACC parser in libraries reentrant.
master-branch libpcap now generates a reentrant Flex scanner and
Bison/Berkeley YACC parser for capture filter expressions, so it
requires versions of Flex and Bison/Berkeley YACC that support that.
We might as well do the same. For libwiretap, it means we could
actually have multiple K12 text or Ascend/Lucent text files open at the
same time. For libwireshark, it might not be as useful, as we only read
configuration files at startup (which should only happen once, in one
thread) or on demand (in which case, if we ever support multiple threads
running libwireshark, we'd need a mutex to ensure that only one file
reads it), but it's still the right thing to do.
We also require a version of Flex that can write out a header file, so
we change the runlex script to generate the header file ourselves. This
means we require a version of Flex new enough to support --header-file.
Clean up some other stuff encountered in the process.
Change-Id: Id23078c6acea549a52fc687779bb55d715b55c16
Reviewed-on: https://code.wireshark.org/review/14719
Reviewed-by: Guy Harris <guy@alum.mit.edu>
Diffstat (limited to 'epan/dfilter/dfilter-int.h')
-rw-r--r-- | epan/dfilter/dfilter-int.h | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/epan/dfilter/dfilter-int.h b/epan/dfilter/dfilter-int.h index 40e55488b5..f94c78f139 100644 --- a/epan/dfilter/dfilter-int.h +++ b/epan/dfilter/dfilter-int.h @@ -56,10 +56,12 @@ typedef struct { } dfwork_t; /* - * XXX - if we're using a version of Flex that supports reentrant lexical - * analyzers, we should put this into the lexical analyzer's state. + * State kept by the scanner. */ -extern dfwork_t *global_dfw; +typedef struct { + dfwork_t *dfw; + GString* quoted_string; +} df_scanner_state_t; /* Constructor/Destructor prototypes for Lemon Parser */ void *DfilterAlloc(void* (*)(gsize)); |