forked from parsley72/tinyxpath2
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlex_token.h
127 lines (106 loc) · 3.4 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
/*
www.sourceforge.net/projects/tinyxpath
Copyright (c) 2002-2004 Yves Berquin ([email protected])
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 = nullptr;
/// lexical value
lex _l_enum;
/// pointer to next element
lex_token* _ltp_next = nullptr;
lex_token* _ltp_prev = nullptr;
public:
lex_token(lex_token& other) = delete;
lex_token& operator=(lex_token& other) = delete;
/// constructor
lex_token(lex l_in_enum, const _byte_* bp_in_value, unsigned u_in_size)
: _cp_value(new char[u_in_size + 1]), _l_enum(l_in_enum) {
if (u_in_size) {
memcpy(_cp_value, bp_in_value, u_in_size);
}
_cp_value[u_in_size] = 0;
}
/// 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;
ltp_ret = this;
for (int i = 0; i < i_nb; i++) {
if (!ltp_ret) {
return nullptr;
}
ltp_ret = ltp_ret->ltp_get_next();
if (!ltp_ret || !ltp_ret->o_is_valid()) {
return nullptr;
}
}
return ltp_ret;
}
/// return the value of a lexical element
lex lex_get_value() const {
return _l_enum;
}
/// Set the string value of a lexical element
void v_set(lex lex_in, const char* cp_repre) {
_l_enum = lex_in;
delete[] _cp_value;
const size_t u_length = strlen(cp_repre);
_cp_value = new char[u_length + 1];
strncpy(_cp_value, cp_repre, u_length);
}
/// return the string value of a lexical element
const char* cp_get_literal() const {
return _cp_value;
}
/// check if the lexical element is valid
bool o_is_valid() const {
return (_l_enum != lex::null);
}
};
} // namespace TinyXPath
#endif // __TINYLEXTOKEN_H