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
  
/* 
|| This file is part of Pike. For copyright information see COPYRIGHT. 
|| Pike is distributed under GPL, LGPL and MPL. See the file COPYING 
|| for more information. 
*/ 
 
#include "global.h" 
#include "las.h" 
#include "lex.h" 
#include "bignum.h" 
#include "pike_compiler.h" 
#include "interpret.h" 
 
#include <ctype.h> 
 
 
static double my_strtod(const char *nptr, char **endptr) 
{ 
  double tmp=strtod(nptr,endptr); 
  if(*endptr>nptr) 
  { 
    if(endptr[0][-1]=='.') 
      endptr[0]--; 
  } 
  return tmp; 
} 
 
#define LEXDEBUG 0 
 
/* Make lexers for shifts 0, 1 and 2. */ 
 
#define SHIFT 0 
#include "lexer.h" 
#undef SHIFT 
#define SHIFT 1 
#include "lexer.h" 
#undef SHIFT 
#define SHIFT 2 
#include "lexer.h" 
#undef SHIFT 
 
int parse_esc_seq_pcharp (PCHARP buf, p_wchar2 *chr, ptrdiff_t *len) 
{ 
  if(LIKELY(buf.shift == 0)) 
    return parse_esc_seq0((void*)buf.ptr,chr,len); 
  if( buf.shift == 1 ) 
    return parse_esc_seq1((void*)buf.ptr,chr,len); 
  return parse_esc_seq2((void*)buf.ptr,chr,len); 
  /* UNREACHABLE */ 
} 
 
int yylex(YYSTYPE *yylval) 
{ 
  struct lex *lex; 
  CHECK_COMPILER(); 
  lex = &THIS_COMPILATION->lex; 
#if LEXDEBUG>8 
  fprintf(stderr, "YYLEX: Calling lexer at 0x%08lx\n", 
          (long)lex->current_lexer); 
#endif /* LEXDEBUG > 8 */ 
  return(lex->current_lexer(lex, yylval)); 
}