xref: /aosp_15_r20/external/bc/src/dc_lex.c (revision 5a6e848804d15c18a0125914844ee4eb0bda4fcf)
1*5a6e8488SAndroid Build Coastguard Worker /*
2*5a6e8488SAndroid Build Coastguard Worker  * *****************************************************************************
3*5a6e8488SAndroid Build Coastguard Worker  *
4*5a6e8488SAndroid Build Coastguard Worker  * SPDX-License-Identifier: BSD-2-Clause
5*5a6e8488SAndroid Build Coastguard Worker  *
6*5a6e8488SAndroid Build Coastguard Worker  * Copyright (c) 2018-2024 Gavin D. Howard and contributors.
7*5a6e8488SAndroid Build Coastguard Worker  *
8*5a6e8488SAndroid Build Coastguard Worker  * Redistribution and use in source and binary forms, with or without
9*5a6e8488SAndroid Build Coastguard Worker  * modification, are permitted provided that the following conditions are met:
10*5a6e8488SAndroid Build Coastguard Worker  *
11*5a6e8488SAndroid Build Coastguard Worker  * * Redistributions of source code must retain the above copyright notice, this
12*5a6e8488SAndroid Build Coastguard Worker  *   list of conditions and the following disclaimer.
13*5a6e8488SAndroid Build Coastguard Worker  *
14*5a6e8488SAndroid Build Coastguard Worker  * * Redistributions in binary form must reproduce the above copyright notice,
15*5a6e8488SAndroid Build Coastguard Worker  *   this list of conditions and the following disclaimer in the documentation
16*5a6e8488SAndroid Build Coastguard Worker  *   and/or other materials provided with the distribution.
17*5a6e8488SAndroid Build Coastguard Worker  *
18*5a6e8488SAndroid Build Coastguard Worker  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
19*5a6e8488SAndroid Build Coastguard Worker  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
20*5a6e8488SAndroid Build Coastguard Worker  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
21*5a6e8488SAndroid Build Coastguard Worker  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
22*5a6e8488SAndroid Build Coastguard Worker  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23*5a6e8488SAndroid Build Coastguard Worker  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24*5a6e8488SAndroid Build Coastguard Worker  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25*5a6e8488SAndroid Build Coastguard Worker  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26*5a6e8488SAndroid Build Coastguard Worker  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27*5a6e8488SAndroid Build Coastguard Worker  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28*5a6e8488SAndroid Build Coastguard Worker  * POSSIBILITY OF SUCH DAMAGE.
29*5a6e8488SAndroid Build Coastguard Worker  *
30*5a6e8488SAndroid Build Coastguard Worker  * *****************************************************************************
31*5a6e8488SAndroid Build Coastguard Worker  *
32*5a6e8488SAndroid Build Coastguard Worker  * The lexer for dc.
33*5a6e8488SAndroid Build Coastguard Worker  *
34*5a6e8488SAndroid Build Coastguard Worker  */
35*5a6e8488SAndroid Build Coastguard Worker 
36*5a6e8488SAndroid Build Coastguard Worker #if DC_ENABLED
37*5a6e8488SAndroid Build Coastguard Worker 
38*5a6e8488SAndroid Build Coastguard Worker #include <ctype.h>
39*5a6e8488SAndroid Build Coastguard Worker 
40*5a6e8488SAndroid Build Coastguard Worker #include <dc.h>
41*5a6e8488SAndroid Build Coastguard Worker #include <vm.h>
42*5a6e8488SAndroid Build Coastguard Worker 
43*5a6e8488SAndroid Build Coastguard Worker bool
dc_lex_negCommand(BcLex * l)44*5a6e8488SAndroid Build Coastguard Worker dc_lex_negCommand(BcLex* l)
45*5a6e8488SAndroid Build Coastguard Worker {
46*5a6e8488SAndroid Build Coastguard Worker 	char c = l->buf[l->i];
47*5a6e8488SAndroid Build Coastguard Worker 	return !BC_LEX_NUM_CHAR(c, false, false);
48*5a6e8488SAndroid Build Coastguard Worker }
49*5a6e8488SAndroid Build Coastguard Worker 
50*5a6e8488SAndroid Build Coastguard Worker /**
51*5a6e8488SAndroid Build Coastguard Worker  * Processes a dc command that needs a register. This is where the
52*5a6e8488SAndroid Build Coastguard Worker  * extended-register extension is implemented.
53*5a6e8488SAndroid Build Coastguard Worker  * @param l  The lexer.
54*5a6e8488SAndroid Build Coastguard Worker  */
55*5a6e8488SAndroid Build Coastguard Worker static void
dc_lex_register(BcLex * l)56*5a6e8488SAndroid Build Coastguard Worker dc_lex_register(BcLex* l)
57*5a6e8488SAndroid Build Coastguard Worker {
58*5a6e8488SAndroid Build Coastguard Worker 	// If extended register is enabled and the character is whitespace...
59*5a6e8488SAndroid Build Coastguard Worker 	if (DC_X && isspace(l->buf[l->i - 1]))
60*5a6e8488SAndroid Build Coastguard Worker 	{
61*5a6e8488SAndroid Build Coastguard Worker 		char c;
62*5a6e8488SAndroid Build Coastguard Worker 
63*5a6e8488SAndroid Build Coastguard Worker 		// Eat the whitespace.
64*5a6e8488SAndroid Build Coastguard Worker 		bc_lex_whitespace(l);
65*5a6e8488SAndroid Build Coastguard Worker 		c = l->buf[l->i];
66*5a6e8488SAndroid Build Coastguard Worker 
67*5a6e8488SAndroid Build Coastguard Worker 		// Check for a letter or underscore.
68*5a6e8488SAndroid Build Coastguard Worker 		if (BC_ERR(!isalpha(c) && c != '_'))
69*5a6e8488SAndroid Build Coastguard Worker 		{
70*5a6e8488SAndroid Build Coastguard Worker 			bc_lex_verr(l, BC_ERR_PARSE_CHAR, c);
71*5a6e8488SAndroid Build Coastguard Worker 		}
72*5a6e8488SAndroid Build Coastguard Worker 
73*5a6e8488SAndroid Build Coastguard Worker 		// Parse a normal identifier.
74*5a6e8488SAndroid Build Coastguard Worker 		l->i += 1;
75*5a6e8488SAndroid Build Coastguard Worker 		bc_lex_name(l);
76*5a6e8488SAndroid Build Coastguard Worker 	}
77*5a6e8488SAndroid Build Coastguard Worker 	else
78*5a6e8488SAndroid Build Coastguard Worker 	{
79*5a6e8488SAndroid Build Coastguard Worker 		// I don't allow newlines because newlines are used for controlling when
80*5a6e8488SAndroid Build Coastguard Worker 		// execution happens, and allowing newlines would just be complex.
81*5a6e8488SAndroid Build Coastguard Worker 		if (BC_ERR(l->buf[l->i - 1] == '\n'))
82*5a6e8488SAndroid Build Coastguard Worker 		{
83*5a6e8488SAndroid Build Coastguard Worker 			bc_lex_verr(l, BC_ERR_PARSE_CHAR, l->buf[l->i - 1]);
84*5a6e8488SAndroid Build Coastguard Worker 		}
85*5a6e8488SAndroid Build Coastguard Worker 
86*5a6e8488SAndroid Build Coastguard Worker 		// Set the lexer string and token.
87*5a6e8488SAndroid Build Coastguard Worker 		bc_vec_popAll(&l->str);
88*5a6e8488SAndroid Build Coastguard Worker 		bc_vec_pushByte(&l->str, (uchar) l->buf[l->i - 1]);
89*5a6e8488SAndroid Build Coastguard Worker 		bc_vec_pushByte(&l->str, '\0');
90*5a6e8488SAndroid Build Coastguard Worker 		l->t = BC_LEX_NAME;
91*5a6e8488SAndroid Build Coastguard Worker 	}
92*5a6e8488SAndroid Build Coastguard Worker }
93*5a6e8488SAndroid Build Coastguard Worker 
94*5a6e8488SAndroid Build Coastguard Worker /**
95*5a6e8488SAndroid Build Coastguard Worker  * Parses a dc string. Since dc's strings need to check for balanced brackets,
96*5a6e8488SAndroid Build Coastguard Worker  * we can't just parse bc and dc strings with different start and end
97*5a6e8488SAndroid Build Coastguard Worker  * characters. Oh, and dc strings need to check for escaped brackets.
98*5a6e8488SAndroid Build Coastguard Worker  * @param l  The lexer.
99*5a6e8488SAndroid Build Coastguard Worker  */
100*5a6e8488SAndroid Build Coastguard Worker static void
dc_lex_string(BcLex * l)101*5a6e8488SAndroid Build Coastguard Worker dc_lex_string(BcLex* l)
102*5a6e8488SAndroid Build Coastguard Worker {
103*5a6e8488SAndroid Build Coastguard Worker 	size_t depth, nls, i;
104*5a6e8488SAndroid Build Coastguard Worker 	char c;
105*5a6e8488SAndroid Build Coastguard Worker 	bool got_more;
106*5a6e8488SAndroid Build Coastguard Worker 
107*5a6e8488SAndroid Build Coastguard Worker 	// Set the token and clear the string.
108*5a6e8488SAndroid Build Coastguard Worker 	l->t = BC_LEX_STR;
109*5a6e8488SAndroid Build Coastguard Worker 	bc_vec_popAll(&l->str);
110*5a6e8488SAndroid Build Coastguard Worker 
111*5a6e8488SAndroid Build Coastguard Worker 	do
112*5a6e8488SAndroid Build Coastguard Worker 	{
113*5a6e8488SAndroid Build Coastguard Worker 		depth = 1;
114*5a6e8488SAndroid Build Coastguard Worker 		nls = 0;
115*5a6e8488SAndroid Build Coastguard Worker 		got_more = false;
116*5a6e8488SAndroid Build Coastguard Worker 
117*5a6e8488SAndroid Build Coastguard Worker #if !BC_ENABLE_OSSFUZZ
118*5a6e8488SAndroid Build Coastguard Worker 		assert(l->mode != BC_MODE_STDIN || l->buf == vm->buffer.v);
119*5a6e8488SAndroid Build Coastguard Worker #endif // !BC_ENABLE_OSSFUZZ
120*5a6e8488SAndroid Build Coastguard Worker 
121*5a6e8488SAndroid Build Coastguard Worker 		// This is the meat. As long as we don't run into the NUL byte, and we
122*5a6e8488SAndroid Build Coastguard Worker 		// have "depth", which means we haven't completely balanced brackets
123*5a6e8488SAndroid Build Coastguard Worker 		// yet, we continue eating the string.
124*5a6e8488SAndroid Build Coastguard Worker 		for (i = l->i; (c = l->buf[i]) && depth; ++i)
125*5a6e8488SAndroid Build Coastguard Worker 		{
126*5a6e8488SAndroid Build Coastguard Worker 			// Check for escaped brackets and set the depths as appropriate.
127*5a6e8488SAndroid Build Coastguard Worker 			if (c == '\\')
128*5a6e8488SAndroid Build Coastguard Worker 			{
129*5a6e8488SAndroid Build Coastguard Worker 				c = l->buf[++i];
130*5a6e8488SAndroid Build Coastguard Worker 				if (!c) break;
131*5a6e8488SAndroid Build Coastguard Worker 			}
132*5a6e8488SAndroid Build Coastguard Worker 			else
133*5a6e8488SAndroid Build Coastguard Worker 			{
134*5a6e8488SAndroid Build Coastguard Worker 				depth += (c == '[');
135*5a6e8488SAndroid Build Coastguard Worker 				depth -= (c == ']');
136*5a6e8488SAndroid Build Coastguard Worker 			}
137*5a6e8488SAndroid Build Coastguard Worker 
138*5a6e8488SAndroid Build Coastguard Worker 			// We want to adjust the line in the lexer as necessary.
139*5a6e8488SAndroid Build Coastguard Worker 			nls += (c == '\n');
140*5a6e8488SAndroid Build Coastguard Worker 
141*5a6e8488SAndroid Build Coastguard Worker 			if (depth) bc_vec_push(&l->str, &c);
142*5a6e8488SAndroid Build Coastguard Worker 		}
143*5a6e8488SAndroid Build Coastguard Worker 
144*5a6e8488SAndroid Build Coastguard Worker 		if (BC_ERR(c == '\0' && depth))
145*5a6e8488SAndroid Build Coastguard Worker 		{
146*5a6e8488SAndroid Build Coastguard Worker 			if (!vm->eof && l->mode != BC_MODE_FILE)
147*5a6e8488SAndroid Build Coastguard Worker 			{
148*5a6e8488SAndroid Build Coastguard Worker 				got_more = bc_lex_readLine(l);
149*5a6e8488SAndroid Build Coastguard Worker 			}
150*5a6e8488SAndroid Build Coastguard Worker 
151*5a6e8488SAndroid Build Coastguard Worker 			if (got_more)
152*5a6e8488SAndroid Build Coastguard Worker 			{
153*5a6e8488SAndroid Build Coastguard Worker 				bc_vec_popAll(&l->str);
154*5a6e8488SAndroid Build Coastguard Worker 			}
155*5a6e8488SAndroid Build Coastguard Worker 		}
156*5a6e8488SAndroid Build Coastguard Worker 	}
157*5a6e8488SAndroid Build Coastguard Worker 	while (got_more && depth);
158*5a6e8488SAndroid Build Coastguard Worker 
159*5a6e8488SAndroid Build Coastguard Worker 	// Obviously, if we didn't balance, that's an error.
160*5a6e8488SAndroid Build Coastguard Worker 	if (BC_ERR(c == '\0' && depth))
161*5a6e8488SAndroid Build Coastguard Worker 	{
162*5a6e8488SAndroid Build Coastguard Worker 		l->i = i;
163*5a6e8488SAndroid Build Coastguard Worker 		bc_lex_err(l, BC_ERR_PARSE_STRING);
164*5a6e8488SAndroid Build Coastguard Worker 	}
165*5a6e8488SAndroid Build Coastguard Worker 
166*5a6e8488SAndroid Build Coastguard Worker 	bc_vec_pushByte(&l->str, '\0');
167*5a6e8488SAndroid Build Coastguard Worker 
168*5a6e8488SAndroid Build Coastguard Worker 	l->i = i;
169*5a6e8488SAndroid Build Coastguard Worker 	l->line += nls;
170*5a6e8488SAndroid Build Coastguard Worker }
171*5a6e8488SAndroid Build Coastguard Worker 
172*5a6e8488SAndroid Build Coastguard Worker /**
173*5a6e8488SAndroid Build Coastguard Worker  * Lexes a dc token. This is the dc implementation of BcLexNext.
174*5a6e8488SAndroid Build Coastguard Worker  * @param l  The lexer.
175*5a6e8488SAndroid Build Coastguard Worker  */
176*5a6e8488SAndroid Build Coastguard Worker void
dc_lex_token(BcLex * l)177*5a6e8488SAndroid Build Coastguard Worker dc_lex_token(BcLex* l)
178*5a6e8488SAndroid Build Coastguard Worker {
179*5a6e8488SAndroid Build Coastguard Worker 	char c = l->buf[l->i++], c2;
180*5a6e8488SAndroid Build Coastguard Worker 	size_t i;
181*5a6e8488SAndroid Build Coastguard Worker 
182*5a6e8488SAndroid Build Coastguard Worker 	BC_SIG_ASSERT_LOCKED;
183*5a6e8488SAndroid Build Coastguard Worker 
184*5a6e8488SAndroid Build Coastguard Worker 	// If the last token was a command that needs a register, we need to parse a
185*5a6e8488SAndroid Build Coastguard Worker 	// register, so do so.
186*5a6e8488SAndroid Build Coastguard Worker 	for (i = 0; i < dc_lex_regs_len; ++i)
187*5a6e8488SAndroid Build Coastguard Worker 	{
188*5a6e8488SAndroid Build Coastguard Worker 		// If the token is a register token, take care of it and return.
189*5a6e8488SAndroid Build Coastguard Worker 		if (l->last == dc_lex_regs[i])
190*5a6e8488SAndroid Build Coastguard Worker 		{
191*5a6e8488SAndroid Build Coastguard Worker 			dc_lex_register(l);
192*5a6e8488SAndroid Build Coastguard Worker 			return;
193*5a6e8488SAndroid Build Coastguard Worker 		}
194*5a6e8488SAndroid Build Coastguard Worker 	}
195*5a6e8488SAndroid Build Coastguard Worker 
196*5a6e8488SAndroid Build Coastguard Worker 	// These lines are for tokens that easily correspond to one character. We
197*5a6e8488SAndroid Build Coastguard Worker 	// just set the token.
198*5a6e8488SAndroid Build Coastguard Worker 	if (c >= '"' && c <= '~' &&
199*5a6e8488SAndroid Build Coastguard Worker 	    (l->t = dc_lex_tokens[(c - '"')]) != BC_LEX_INVALID)
200*5a6e8488SAndroid Build Coastguard Worker 	{
201*5a6e8488SAndroid Build Coastguard Worker 		return;
202*5a6e8488SAndroid Build Coastguard Worker 	}
203*5a6e8488SAndroid Build Coastguard Worker 
204*5a6e8488SAndroid Build Coastguard Worker 	// This is the workhorse of the lexer when more complicated things are
205*5a6e8488SAndroid Build Coastguard Worker 	// needed.
206*5a6e8488SAndroid Build Coastguard Worker 	switch (c)
207*5a6e8488SAndroid Build Coastguard Worker 	{
208*5a6e8488SAndroid Build Coastguard Worker 		case '\0':
209*5a6e8488SAndroid Build Coastguard Worker 		case '\n':
210*5a6e8488SAndroid Build Coastguard Worker 		case '\t':
211*5a6e8488SAndroid Build Coastguard Worker 		case '\v':
212*5a6e8488SAndroid Build Coastguard Worker 		case '\f':
213*5a6e8488SAndroid Build Coastguard Worker 		case '\r':
214*5a6e8488SAndroid Build Coastguard Worker 		case ' ':
215*5a6e8488SAndroid Build Coastguard Worker 		{
216*5a6e8488SAndroid Build Coastguard Worker 			bc_lex_commonTokens(l, c);
217*5a6e8488SAndroid Build Coastguard Worker 			break;
218*5a6e8488SAndroid Build Coastguard Worker 		}
219*5a6e8488SAndroid Build Coastguard Worker 
220*5a6e8488SAndroid Build Coastguard Worker 		// We don't have the ! command, so we always expect certain things
221*5a6e8488SAndroid Build Coastguard Worker 		// after the exclamation point.
222*5a6e8488SAndroid Build Coastguard Worker 		case '!':
223*5a6e8488SAndroid Build Coastguard Worker 		{
224*5a6e8488SAndroid Build Coastguard Worker 			c2 = l->buf[l->i];
225*5a6e8488SAndroid Build Coastguard Worker 
226*5a6e8488SAndroid Build Coastguard Worker 			if (c2 == '=') l->t = BC_LEX_OP_REL_NE;
227*5a6e8488SAndroid Build Coastguard Worker 			else if (c2 == '<') l->t = BC_LEX_OP_REL_LE;
228*5a6e8488SAndroid Build Coastguard Worker 			else if (c2 == '>') l->t = BC_LEX_OP_REL_GE;
229*5a6e8488SAndroid Build Coastguard Worker 			else bc_lex_invalidChar(l, c);
230*5a6e8488SAndroid Build Coastguard Worker 
231*5a6e8488SAndroid Build Coastguard Worker 			l->i += 1;
232*5a6e8488SAndroid Build Coastguard Worker 
233*5a6e8488SAndroid Build Coastguard Worker 			break;
234*5a6e8488SAndroid Build Coastguard Worker 		}
235*5a6e8488SAndroid Build Coastguard Worker 
236*5a6e8488SAndroid Build Coastguard Worker 		case '#':
237*5a6e8488SAndroid Build Coastguard Worker 		{
238*5a6e8488SAndroid Build Coastguard Worker 			bc_lex_lineComment(l);
239*5a6e8488SAndroid Build Coastguard Worker 			break;
240*5a6e8488SAndroid Build Coastguard Worker 		}
241*5a6e8488SAndroid Build Coastguard Worker 
242*5a6e8488SAndroid Build Coastguard Worker 		case '.':
243*5a6e8488SAndroid Build Coastguard Worker 		{
244*5a6e8488SAndroid Build Coastguard Worker 			c2 = l->buf[l->i];
245*5a6e8488SAndroid Build Coastguard Worker 
246*5a6e8488SAndroid Build Coastguard Worker 			// If the character after is a number, this dot is part of a number.
247*5a6e8488SAndroid Build Coastguard Worker 			// Otherwise, it's the BSD dot (equivalent to last).
248*5a6e8488SAndroid Build Coastguard Worker 			if (BC_NO_ERR(BC_LEX_NUM_CHAR(c2, true, false)))
249*5a6e8488SAndroid Build Coastguard Worker 			{
250*5a6e8488SAndroid Build Coastguard Worker 				bc_lex_number(l, c);
251*5a6e8488SAndroid Build Coastguard Worker 			}
252*5a6e8488SAndroid Build Coastguard Worker 			else bc_lex_invalidChar(l, c);
253*5a6e8488SAndroid Build Coastguard Worker 
254*5a6e8488SAndroid Build Coastguard Worker 			break;
255*5a6e8488SAndroid Build Coastguard Worker 		}
256*5a6e8488SAndroid Build Coastguard Worker 
257*5a6e8488SAndroid Build Coastguard Worker 		case '0':
258*5a6e8488SAndroid Build Coastguard Worker 		case '1':
259*5a6e8488SAndroid Build Coastguard Worker 		case '2':
260*5a6e8488SAndroid Build Coastguard Worker 		case '3':
261*5a6e8488SAndroid Build Coastguard Worker 		case '4':
262*5a6e8488SAndroid Build Coastguard Worker 		case '5':
263*5a6e8488SAndroid Build Coastguard Worker 		case '6':
264*5a6e8488SAndroid Build Coastguard Worker 		case '7':
265*5a6e8488SAndroid Build Coastguard Worker 		case '8':
266*5a6e8488SAndroid Build Coastguard Worker 		case '9':
267*5a6e8488SAndroid Build Coastguard Worker 		case 'A':
268*5a6e8488SAndroid Build Coastguard Worker 		case 'B':
269*5a6e8488SAndroid Build Coastguard Worker 		case 'C':
270*5a6e8488SAndroid Build Coastguard Worker 		case 'D':
271*5a6e8488SAndroid Build Coastguard Worker 		case 'E':
272*5a6e8488SAndroid Build Coastguard Worker 		case 'F':
273*5a6e8488SAndroid Build Coastguard Worker 		{
274*5a6e8488SAndroid Build Coastguard Worker 			bc_lex_number(l, c);
275*5a6e8488SAndroid Build Coastguard Worker 			break;
276*5a6e8488SAndroid Build Coastguard Worker 		}
277*5a6e8488SAndroid Build Coastguard Worker 
278*5a6e8488SAndroid Build Coastguard Worker 		case 'g':
279*5a6e8488SAndroid Build Coastguard Worker 		{
280*5a6e8488SAndroid Build Coastguard Worker 			c2 = l->buf[l->i];
281*5a6e8488SAndroid Build Coastguard Worker 
282*5a6e8488SAndroid Build Coastguard Worker 			if (c2 == 'l') l->t = BC_LEX_KW_LINE_LENGTH;
283*5a6e8488SAndroid Build Coastguard Worker 			else if (c2 == 'x') l->t = BC_LEX_EXTENDED_REGISTERS;
284*5a6e8488SAndroid Build Coastguard Worker 			else if (c2 == 'z') l->t = BC_LEX_KW_LEADING_ZERO;
285*5a6e8488SAndroid Build Coastguard Worker 			else bc_lex_invalidChar(l, c2);
286*5a6e8488SAndroid Build Coastguard Worker 
287*5a6e8488SAndroid Build Coastguard Worker 			l->i += 1;
288*5a6e8488SAndroid Build Coastguard Worker 
289*5a6e8488SAndroid Build Coastguard Worker 			break;
290*5a6e8488SAndroid Build Coastguard Worker 		}
291*5a6e8488SAndroid Build Coastguard Worker 
292*5a6e8488SAndroid Build Coastguard Worker 		case '[':
293*5a6e8488SAndroid Build Coastguard Worker 		{
294*5a6e8488SAndroid Build Coastguard Worker 			dc_lex_string(l);
295*5a6e8488SAndroid Build Coastguard Worker 			break;
296*5a6e8488SAndroid Build Coastguard Worker 		}
297*5a6e8488SAndroid Build Coastguard Worker 
298*5a6e8488SAndroid Build Coastguard Worker 		default:
299*5a6e8488SAndroid Build Coastguard Worker 		{
300*5a6e8488SAndroid Build Coastguard Worker 			bc_lex_invalidChar(l, c);
301*5a6e8488SAndroid Build Coastguard Worker 		}
302*5a6e8488SAndroid Build Coastguard Worker 	}
303*5a6e8488SAndroid Build Coastguard Worker }
304*5a6e8488SAndroid Build Coastguard Worker #endif // DC_ENABLED
305