-
Notifications
You must be signed in to change notification settings - Fork 3
/
lex_token.h
135 lines (115 loc) · 3.3 KB
/
lex_token.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
/*
www.sourceforge.net/projects/tinyxpath
Copyright (c) 2002-2004 Yves Berquin (yvesb@users.sourceforge.net)
This software is provided 'as-is', without any express or implied
warranty. In no event will the authors be held liable for any
damages arising from the use of this software.
Permission is granted to anyone to use this software for any
purpose, including commercial applications, and to alter it and
redistribute it freely, subject to the following restrictions:
1. The origin of this software must not be misrepresented; you must
not claim that you wrote the original software. If you use this
software in a product, an acknowledgment in the product documentation
would be appreciated but is not required.
2. Altered source versions must be plainly marked as such, and
must not be misrepresented as being the original software.
3. This notice may not be removed or altered from any source
distribution.
*/
#ifndef __TINYLEXTOKEN_H
#define __TINYLEXTOKEN_H
#include <stdio.h>
#include <string.h>
#include "lex_util.h"
namespace TinyXPath
{
/**
A lexical token stream, part of a single linked list
*/
class lex_token
{
/// Representation
char * cp_value;
/// lexical value
lexico l_enum;
/// pointer to next element
lex_token * ltp_next, * ltp_prev;
public :
/// constructor
lex_token (lexico l_in_enum, const _byte_ * bp_in_value, unsigned u_in_size)
{
l_enum = l_in_enum;
cp_value = new char [u_in_size + 1];
if (u_in_size)
memcpy (cp_value, bp_in_value, u_in_size);
cp_value [u_in_size] = 0;
ltp_next = NULL;
ltp_prev = NULL;
}
/// set the next element in list
void v_set_next (lex_token * ltp_in_next)
{
ltp_next = ltp_in_next;
}
/// set the previous element in list
void v_set_prev (lex_token * ltp_in_prev)
{
ltp_prev = ltp_in_prev;
}
/// destructor. doesn't destroys next in list
~ lex_token ()
{
if (cp_value)
delete [] cp_value;
}
/// get next in list
lex_token * ltp_get_next () const
{
return ltp_next;
}
/// get next in list
lex_token * ltp_get_prev () const
{
return ltp_prev;
}
/// Return the next i-th element in the list
lex_token * ltp_get_next (int i_nb)
{
lex_token * ltp_ret;
int i;
ltp_ret = this;
for (i = 0; i < i_nb; i++)
{
if (! ltp_ret)
return NULL;
ltp_ret = ltp_ret -> ltp_get_next ();
if (! ltp_ret || ! ltp_ret -> o_is_valid ())
return NULL;
}
return ltp_ret;
}
/// return the value of a lexical element
lexico lex_get_value () const
{
return l_enum;
}
/// Set the string value of a lexical element
void v_set (lexico lex_in, const char * cp_repre)
{
unsigned u_length;
l_enum = lex_in;
delete [] cp_value;
u_length = strlen (cp_repre);
cp_value = new char [u_length + 1];
strcpy (cp_value, cp_repre);
}
/// return the string value of a lexical element
const char * cp_get_literal ()
{
return cp_value;
}
/// check if the lexical element is valid
bool o_is_valid () const {return (l_enum != lex_null);}
} ;
}
#endif