wireshark/wiretap/ascend-scanner.l

263 lines
5.1 KiB
Plaintext
Raw Normal View History

%{
/* ascend-scanner.l
*
* $Id: ascend-scanner.l,v 1.15 2000/05/19 08:18:14 guy Exp $
*
* Wiretap Library
* Copyright (c) 1998 by Gilbert Ramirez <gram@xiexie.org>
*
* 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.
*
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#ifdef HAVE_IO_H
#include <io.h> /* for isatty() on win32 */
#endif
#include "wtap.h"
#include "ascend.h"
#include "ascend-grammar.h"
#include "ascend-int.h"
#include "file_wrappers.h"
FILE_T yy_fh;
extern char *ascend_ra_ptr;
extern char *ascend_ra_last;
#define YY_INPUT(buf,result,max_size) { int c = file_getc(yy_fh); \
result = (c==EOF) ? YY_NULL : (buf[0] = c, 1); }
int at_eof;
int mul, scratch;
/* We don't need yyunput, so use this macro to get it out of the
* generated C file, avoiding a compiler warning about its lack of use */
#define YY_NO_UNPUT 1
%}
/* %option debug */
%option nostdinit
%option noyywrap
D [0-9]
H [A-Fa-f0-9]
XPFX XMIT-
RPFX RECV-
WDD_DATE "Date:"
WDD_TIME "Time:"
WDD_CAUSE "Cause an attempt to place call to "
WDD_CALLNUM [^\n\r\t ]+
WDD_CHUNK "WD_DIALOUT_DISP: chunk"
WDD_TYPE "type "[^\n\r\t ]+
%s sc_gen_task
%s sc_gen_time_s
%s sc_gen_time_u
%s sc_gen_octets
%s sc_gen_counter
%s sc_gen_byte
%s sc_wds_user
%s sc_wds_sess
%s sc_wdd_date_d
%s sc_wdd_date_m
%s sc_wdd_date_y
%s sc_wdd_time
%s sc_wdd_time_h
%s sc_wdd_time_m
%s sc_wdd_time_s
%s sc_wdd_cause
%s sc_wdd_callnum
%s sc_wdd_chunk
%s sc_wdd_chunknum
%s sc_wdd_type
%%
<INITIAL,sc_gen_byte>{XPFX} {
BEGIN(sc_wds_user);
ascendlval.d = ASCEND_PFX_WDS_X;
return WDS_PREFIX;
}
<INITIAL,sc_gen_byte>{RPFX} {
BEGIN(sc_wds_user);
ascendlval.d = ASCEND_PFX_WDS_R;
return WDS_PREFIX;
}
<sc_wds_user>[^:]+ {
BEGIN(sc_wds_sess);
if (pseudo_header != NULL) {
strncpy(pseudo_header->user, ascendtext, ASCEND_MAX_STR_LEN);
pseudo_header->user[ASCEND_MAX_STR_LEN - 1] = '\0';
}
return STRING;
}
<sc_wds_sess>{D}+ {
BEGIN(sc_gen_task);
ascendlval.d = strtol(ascendtext, NULL, 10);
return DECNUM;
}
<sc_gen_task>{H}+ {
BEGIN(sc_gen_time_s);
ascendlval.d = strtoul(ascendtext, NULL, 16);
return HEXNUM;
}
<sc_gen_time_s>{D}+ {
BEGIN(sc_gen_time_u);
ascendlval.d = strtol(ascendtext, NULL, 10);
return DECNUM;
}
<sc_gen_time_u>{D}+ {
BEGIN(sc_gen_octets);
/* We have the fractional portion of the time. We want it converted
to microseconds. */
mul = 1000000;
ascendlval.d = strtol(ascendtext, NULL, 10);
for (scratch = ascendlval.d; scratch > 0; scratch /= 10)
mul /= 10;
ascendlval.d *= mul;
return DECNUM;
}
<sc_gen_octets>{D}+ {
BEGIN(sc_gen_counter);
ascendlval.d = strtol(ascendtext, NULL, 10);
return DECNUM;
}
<sc_gen_counter,sc_gen_byte>"["{H}{4}"]:" {
BEGIN(sc_gen_byte);
return COUNTER;
}
<sc_gen_byte>{H}{2} {
ascendlval.b = strtol(ascendtext, NULL, 16);
return HEXBYTE;
}
<INITIAL,sc_gen_byte>{WDD_DATE} {
BEGIN(sc_wdd_date_d);
return KEYWORD;
}
<sc_wdd_date_d>{D}{2} {
BEGIN(sc_wdd_date_m);
ascendlval.d = strtol(ascendtext, NULL, 10);
return DECNUM;
}
<sc_wdd_date_m>{D}{2} {
BEGIN(sc_wdd_date_y);
ascendlval.d = strtol(ascendtext, NULL, 10);
return DECNUM;
}
<sc_wdd_date_y>{D}{4} {
BEGIN(sc_wdd_time);
ascendlval.d = strtol(ascendtext, NULL, 10);
return DECNUM;
}
<sc_wdd_time>{WDD_TIME} {
BEGIN(sc_wdd_time_h);
return KEYWORD;
}
<sc_wdd_time_h>{D}{2} {
BEGIN(sc_wdd_time_m);
ascendlval.d = strtol(ascendtext, NULL, 10);
return DECNUM;
}
<sc_wdd_time_m>{D}{2} {
BEGIN(sc_wdd_time_s);
ascendlval.d = strtol(ascendtext, NULL, 10);
return DECNUM;
}
<sc_wdd_time_s>{D}{2} {
BEGIN(sc_wdd_cause);
ascendlval.d = strtol(ascendtext, NULL, 10);
return DECNUM;
}
<sc_wdd_cause>{WDD_CAUSE} {
BEGIN(sc_wdd_callnum);
return KEYWORD;
}
<sc_wdd_callnum>{WDD_CALLNUM} {
BEGIN(sc_wdd_chunk);
if (pseudo_header != NULL) {
strncpy(pseudo_header->call_num, ascendtext, ASCEND_MAX_STR_LEN);
pseudo_header->call_num[ASCEND_MAX_STR_LEN - 1] = '\0';
}
return STRING;
}
<sc_wdd_chunk>{WDD_CHUNK} {
BEGIN(sc_wdd_chunknum);
return KEYWORD;
}
<sc_wdd_chunknum>{H}+ {
BEGIN(sc_wdd_type);
ascendlval.d = strtoul(ascendtext, NULL, 16);
return HEXNUM;
}
<sc_wdd_type>{WDD_TYPE} {
BEGIN(sc_gen_task);
return KEYWORD;
}
{H}+ { return HEXNUM; }
task:|time:|octets { return KEYWORD; }
<<EOF>> { at_eof++; yyterminate(); }
. ;
%%
int ascendwrap() { return 1; }
void ascend_init_lexer(FILE_T fh, FILE *nfh)
{
yyrestart(0);
yyout = nfh;
yy_fh = fh;
BEGIN(INITIAL);
}