Compare commits
	
		
			24 Commits
		
	
	
		
			main
			...
			b59c59e7e1
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b59c59e7e1 | |||
| 574f771444 | |||
| 1d118c8568 | |||
| 896a9ff085 | |||
| eece52600b | |||
| 7cb4b28da8 | |||
| bf958056bd | |||
| ec6df32839 | |||
| de57d9f14b | |||
| f1f90cf56b | |||
| 41d7cf2717 | |||
| 002a8e7064 | |||
| fc80095d1f | |||
| 642d000ebd | |||
| b4a4865870 | |||
| 1b4d6a6156 | |||
| 26fabd91b9 | |||
| adde1db0f4 | |||
| 7eec0e0730 | |||
| 6c454fbb8e | |||
| fd8231b02d | |||
| 09f2315b66 | |||
| 91162654b3 | |||
| 6e93d3ecd1 | 
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@@ -3,3 +3,4 @@
 | 
			
		||||
src/ignore/**/*
 | 
			
		||||
main
 | 
			
		||||
compile_commands.json
 | 
			
		||||
gentable
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										28
									
								
								compile
									
									
									
									
									
								
							
							
						
						
									
										28
									
								
								compile
									
									
									
									
									
								
							@@ -1,24 +1,28 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
 | 
			
		||||
CC=clang
 | 
			
		||||
CFLAGS="-g -Wall -Werror -pedantic -Iinclude"
 | 
			
		||||
SRC="src/main.c"
 | 
			
		||||
OUT=main
 | 
			
		||||
CFLAGS="-g -Wall -Werror -pedantic -I./include"
 | 
			
		||||
SRC="./src/main.c"
 | 
			
		||||
OUT=./main
 | 
			
		||||
 | 
			
		||||
# STATE_TABLE
 | 
			
		||||
(set -x;$CC $CFLAGS -I./include/lexer ./generate_state_table.c -o ./gentable)
 | 
			
		||||
./gentable
 | 
			
		||||
 | 
			
		||||
# DSTRING
 | 
			
		||||
CFLAGS+=" -Iinclude/dstring"
 | 
			
		||||
SRC+=" src/dstring/*.c"
 | 
			
		||||
CFLAGS+=" -I./include/dstring"
 | 
			
		||||
SRC+=" ./src/dstring/*.c"
 | 
			
		||||
 | 
			
		||||
# JSON_ENTITIES
 | 
			
		||||
CFLAGS+=" -Iinclude/json_entities"
 | 
			
		||||
SRC+=" src/json_entities/*.c"
 | 
			
		||||
CFLAGS+=" -I./include/json_entities"
 | 
			
		||||
SRC+=" ./src/json_entities/*.c"
 | 
			
		||||
 | 
			
		||||
# LEXER
 | 
			
		||||
CFLAGS+=" -Iinclude/lexer"
 | 
			
		||||
SRC+=" src/lexer/*.c"
 | 
			
		||||
CFLAGS+=" -I./include/lexer"
 | 
			
		||||
SRC+=" ./src/lexer/*.c"
 | 
			
		||||
 | 
			
		||||
# PARSER
 | 
			
		||||
CFLAGS+=" -Iinclude/parser"
 | 
			
		||||
SRC+=" src/parser/*.c"
 | 
			
		||||
CFLAGS+=" -I./include/parser"
 | 
			
		||||
SRC+=" ./src/parser/*.c"
 | 
			
		||||
 | 
			
		||||
$CC $CFLAGS $SRC -o $OUT
 | 
			
		||||
(set -x;$CC $CFLAGS $SRC -o $OUT)
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										673
									
								
								generate_state_table.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										673
									
								
								generate_state_table.c
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,673 @@
 | 
			
		||||
#include "aliases.h"
 | 
			
		||||
#include "lexer_data.h"
 | 
			
		||||
#include <ctype.h>
 | 
			
		||||
#include <stdio.h>
 | 
			
		||||
#include <stdlib.h>
 | 
			
		||||
#include <string.h>
 | 
			
		||||
 | 
			
		||||
#define STRING_BUF_LENGTH 100
 | 
			
		||||
 | 
			
		||||
INTERNAL void fill_table(void);
 | 
			
		||||
INTERNAL void write_table(FILE *fp);
 | 
			
		||||
 | 
			
		||||
INTERNAL void set_column_width(lexer_state_t state);
 | 
			
		||||
INTERNAL const char *get_input_string(lexer_input_t input);
 | 
			
		||||
INTERNAL const char *get_state_string(lexer_state_t state);
 | 
			
		||||
 | 
			
		||||
INTERNAL lexer_state_t lexer_state_machine(lexer_state_t state,
 | 
			
		||||
                                           lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_lexer_start(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_last_collection(char input);
 | 
			
		||||
INTERNAL lexer_state_t handle_object(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_object_end(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_array(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_array_end(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_key(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_value(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_string(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_string_end(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_escape_sequence(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_unicode_hex(lexer_input_t input,
 | 
			
		||||
                                          lexer_state_t return_state);
 | 
			
		||||
INTERNAL lexer_state_t handle_decimal(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_number(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_fraction(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_exponent(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_exp_sign(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_power(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_number_end(lexer_input_t input);
 | 
			
		||||
INTERNAL lexer_state_t handle_true(lexer_input_t input,
 | 
			
		||||
                                   lexer_state_t start_state);
 | 
			
		||||
INTERNAL lexer_state_t handle_false(lexer_input_t input,
 | 
			
		||||
                                    lexer_state_t start_state);
 | 
			
		||||
INTERNAL lexer_state_t handle_null(lexer_input_t input,
 | 
			
		||||
                                   lexer_state_t start_state);
 | 
			
		||||
INTERNAL lexer_state_t handle_keyword_end(lexer_input_t input);
 | 
			
		||||
 | 
			
		||||
INTERNAL i32 column_width = 0;
 | 
			
		||||
 | 
			
		||||
INTERNAL lexer_state_t state_table[COUNT_LEXER_STATES][COUNT_LEXER_INPUTS] = {
 | 
			
		||||
    0};
 | 
			
		||||
 | 
			
		||||
INTERNAL const char *input_strings[COUNT_LEXER_STATES] = {
 | 
			
		||||
    [LEXER_INPUT_NEWLINE] = "NEWLINE",
 | 
			
		||||
    [LEXER_INPUT_WHITE_SPACE] = "WHITE_SPACE",
 | 
			
		||||
    [LEXER_INPUT_OPEN_BRACE] = "OPEN_BRACE",
 | 
			
		||||
    [LEXER_INPUT_CLOSE_BRACE] = "CLOSE_BRACE",
 | 
			
		||||
    [LEXER_INPUT_OPEN_BRACKET] = "OPEN_BRACKET",
 | 
			
		||||
    [LEXER_INPUT_CLOSE_BRACKET] = "CLOSE_BRACKET",
 | 
			
		||||
    [LEXER_INPUT_COMMA] = "COMMA",
 | 
			
		||||
    [LEXER_INPUT_COLON] = "COLON",
 | 
			
		||||
    [LEXER_INPUT_DOUBLE_QUOTE] = "DOUBLE_QUOTE",
 | 
			
		||||
    [LEXER_INPUT_BACK_SLASH] = "BACK_SLASH",
 | 
			
		||||
    [LEXER_INPUT_FORWARD_SLASH] = "FORWARD_SLASH",
 | 
			
		||||
    [LEXER_INPUT_LOWER_A] = "LOWER_A",
 | 
			
		||||
    [LEXER_INPUT_LOWER_B] = "LOWER_B",
 | 
			
		||||
    [LEXER_INPUT_LOWER_C] = "LOWER_C",
 | 
			
		||||
    [LEXER_INPUT_LOWER_D] = "LOWER_D",
 | 
			
		||||
    [LEXER_INPUT_LOWER_E] = "LOWER_E",
 | 
			
		||||
    [LEXER_INPUT_LOWER_F] = "LOWER_F",
 | 
			
		||||
    [LEXER_INPUT_LOWER_L] = "LOWER_L",
 | 
			
		||||
    [LEXER_INPUT_LOWER_N] = "LOWER_N",
 | 
			
		||||
    [LEXER_INPUT_LOWER_R] = "LOWER_R",
 | 
			
		||||
    [LEXER_INPUT_LOWER_S] = "LOWER_S",
 | 
			
		||||
    [LEXER_INPUT_LOWER_T] = "LOWER_T",
 | 
			
		||||
    [LEXER_INPUT_LOWER_U] = "LOWER_U",
 | 
			
		||||
    [LEXER_INPUT_UPPER_A] = "UPPER_A",
 | 
			
		||||
    [LEXER_INPUT_UPPER_B] = "UPPER_B",
 | 
			
		||||
    [LEXER_INPUT_UPPER_C] = "UPPER_C",
 | 
			
		||||
    [LEXER_INPUT_UPPER_D] = "UPPER_D",
 | 
			
		||||
    [LEXER_INPUT_UPPER_E] = "UPPER_E",
 | 
			
		||||
    [LEXER_INPUT_UPPER_F] = "UPPER_F",
 | 
			
		||||
    [LEXER_INPUT_MINUS] = "MINUS",
 | 
			
		||||
    [LEXER_INPUT_PLUS] = "PLUS",
 | 
			
		||||
    [LEXER_INPUT_DECIMAL] = "DECIMAL",
 | 
			
		||||
    [LEXER_INPUT_ZERO] = "ZERO",
 | 
			
		||||
    [LEXER_INPUT_NON_ZERO] = "NON_ZERO",
 | 
			
		||||
    [LEXER_INPUT_OTHER] = "OTHER",
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
INTERNAL const char *state_strings[COUNT_LEXER_STATES] = {
 | 
			
		||||
    [LEXER_STATE_ERROR] = "LEXER_STATE_ERROR",
 | 
			
		||||
    [LEXER_STATE_START] = "LEXER_STATE_START",
 | 
			
		||||
    [LEXER_STATE_VALUE] = "LEXER_STATE_VALUE",
 | 
			
		||||
    [LEXER_STATE_VALUE_END] = "LEXER_STATE_VALUE_END",
 | 
			
		||||
    [LEXER_STATE_OBJECT_START] = "LEXER_STATE_OBJECT_START",
 | 
			
		||||
    [LEXER_STATE_OBJECT] = "LEXER_STATE_OBJECT",
 | 
			
		||||
    [LEXER_STATE_OBJECT_END] = "LEXER_STATE_OBJECT_END",
 | 
			
		||||
    [LEXER_STATE_ARRAY_START] = "LEXER_STATE_ARRAY_START",
 | 
			
		||||
    [LEXER_STATE_ARRAY] = "LEXER_STATE_ARRAY",
 | 
			
		||||
    [LEXER_STATE_ARRAY_END] = "LEXER_STATE_ARRAY_END",
 | 
			
		||||
    [LEXER_STATE_LAST_COLLECTION] = "LEXER_STATE_LAST_COLLECTION",
 | 
			
		||||
    [LEXER_STATE_KEY] = "LEXER_STATE_KEY",
 | 
			
		||||
    [LEXER_STATE_KEY_END] = "LEXER_STATE_KEY_END",
 | 
			
		||||
    [LEXER_STATE_DECIMAL] = "LEXER_STATE_DECIMAL",
 | 
			
		||||
    [LEXER_STATE_NUMBER] = "LEXER_STATE_NUMBER",
 | 
			
		||||
    [LEXER_STATE_FRACTION] = "LEXER_STATE_FRACTION",
 | 
			
		||||
    [LEXER_STATE_EXPONENT] = "LEXER_STATE_EXPONENT",
 | 
			
		||||
    [LEXER_STATE_EXP_SIGN] = "LEXER_STATE_EXP_SIGN",
 | 
			
		||||
    [LEXER_STATE_POWER] = "LEXER_STATE_POWER",
 | 
			
		||||
    [LEXER_STATE_NUMBER_END] = "LEXER_STATE_NUMBER_END",
 | 
			
		||||
    [LEXER_STATE_STRING] = "LEXER_STATE_STRING",
 | 
			
		||||
    [LEXER_STATE_STRING_END] = "LEXER_STATE_STRING_END",
 | 
			
		||||
    [LEXER_STATE_ESCAPE_SEQUENCE] = "LEXER_STATE_ESCAPE_SEQUENCE",
 | 
			
		||||
    [LEXER_STATE_UNICODE_HEX1] = "LEXER_STATE_UNICODE_HEX1",
 | 
			
		||||
    [LEXER_STATE_UNICODE_HEX2] = "LEXER_STATE_UNICODE_HEX2",
 | 
			
		||||
    [LEXER_STATE_UNICODE_HEX3] = "LEXER_STATE_UNICODE_HEX3",
 | 
			
		||||
    [LEXER_STATE_UNICODE_HEX4] = "LEXER_STATE_UNICODE_HEX4",
 | 
			
		||||
    [LEXER_STATE_T] = "LEXER_STATE_T",
 | 
			
		||||
    [LEXER_STATE_TR] = "LEXER_STATE_TR",
 | 
			
		||||
    [LEXER_STATE_TRU] = "LEXER_STATE_TRU",
 | 
			
		||||
    [LEXER_STATE_TRUE] = "LEXER_STATE_TRUE",
 | 
			
		||||
    [LEXER_STATE_F] = "LEXER_STATE_F",
 | 
			
		||||
    [LEXER_STATE_FA] = "LEXER_STATE_FA",
 | 
			
		||||
    [LEXER_STATE_FAL] = "LEXER_STATE_FAL",
 | 
			
		||||
    [LEXER_STATE_FALS] = "LEXER_STATE_FALS",
 | 
			
		||||
    [LEXER_STATE_FALSE] = "LEXER_STATE_FALSE",
 | 
			
		||||
    [LEXER_STATE_N] = "LEXER_STATE_N",
 | 
			
		||||
    [LEXER_STATE_NU] = "LEXER_STATE_NU",
 | 
			
		||||
    [LEXER_STATE_NUL] = "LEXER_STATE_NUL",
 | 
			
		||||
    [LEXER_STATE_NULL] = "LEXER_STATE_NULL",
 | 
			
		||||
    [LEXER_STATE_KEYWORD_END] = "LEXER_STATE_KEYWORD_END",
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
INTERNAL const char *filename = "./include/lexer/lexer_state_transitions.table";
 | 
			
		||||
 | 
			
		||||
int main(void) {
 | 
			
		||||
  FILE *fp = fopen(filename, "w");
 | 
			
		||||
  if (!fp) {
 | 
			
		||||
    printf("Failed to open file\n");
 | 
			
		||||
 | 
			
		||||
    return EXIT_FAILURE;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  fill_table();
 | 
			
		||||
 | 
			
		||||
  write_table(fp);
 | 
			
		||||
 | 
			
		||||
  fclose(fp);
 | 
			
		||||
 | 
			
		||||
  return EXIT_SUCCESS;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
INTERNAL void fill_table(void) {
 | 
			
		||||
  lexer_state_t state;
 | 
			
		||||
  lexer_input_t input;
 | 
			
		||||
 | 
			
		||||
  for (u64 i = 0; i < COUNT_LEXER_STATES; ++i) {
 | 
			
		||||
    state = (lexer_state_t)i;
 | 
			
		||||
 | 
			
		||||
    for (u64 j = 0; j < COUNT_LEXER_INPUTS; ++j) {
 | 
			
		||||
      input = (lexer_input_t)j;
 | 
			
		||||
 | 
			
		||||
      state_table[i][j] = (lexer_state_t)lexer_state_machine(state, input);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void write_table(FILE *fp) {
 | 
			
		||||
  const char *array_open = "{ ";
 | 
			
		||||
  const u64 array_open_length = strlen(array_open);
 | 
			
		||||
 | 
			
		||||
  const char *array_close = "},";
 | 
			
		||||
  const u64 array_close_length = strlen(array_close);
 | 
			
		||||
 | 
			
		||||
  const char *comment = "//";
 | 
			
		||||
  const u64 comment_length = strlen(comment);
 | 
			
		||||
 | 
			
		||||
  const char *table_header_end = "   \n";
 | 
			
		||||
  const u64 table_header_end_length = strlen(table_header_end);
 | 
			
		||||
 | 
			
		||||
  char output[STRING_BUF_LENGTH] = {0};
 | 
			
		||||
  u64 length = 0;
 | 
			
		||||
 | 
			
		||||
  for (u64 i = 0; i < COUNT_LEXER_STATES; ++i) {
 | 
			
		||||
    set_column_width((lexer_state_t)i);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  fwrite(comment, sizeof(char), comment_length, fp);
 | 
			
		||||
 | 
			
		||||
  i32 column_white_space = 0;
 | 
			
		||||
 | 
			
		||||
  for (u64 i = 0; i < COUNT_LEXER_INPUTS; ++i) {
 | 
			
		||||
    const char *input_str = get_input_string((lexer_input_t)i);
 | 
			
		||||
    column_white_space = (column_width - strlen(input_str)) / 2;
 | 
			
		||||
 | 
			
		||||
    sprintf(output, "%*s%*s| ", column_width - column_white_space, input_str,
 | 
			
		||||
            column_white_space, " ");
 | 
			
		||||
    length = strlen(output);
 | 
			
		||||
    fwrite(output, sizeof(char), length, fp);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  fwrite(table_header_end, sizeof(char), table_header_end_length, fp);
 | 
			
		||||
 | 
			
		||||
  for (u64 i = 0; i < COUNT_LEXER_STATES; ++i) {
 | 
			
		||||
    fwrite(array_open, sizeof(char), array_open_length, fp);
 | 
			
		||||
 | 
			
		||||
    for (u64 j = 0; j < COUNT_LEXER_INPUTS; ++j) {
 | 
			
		||||
      sprintf(output, "%*s, ", column_width,
 | 
			
		||||
              get_state_string((lexer_state_t)state_table[i][j]));
 | 
			
		||||
      length = strlen(output);
 | 
			
		||||
      fwrite(output, sizeof(char), length, fp);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    fwrite(array_close, sizeof(char), array_close_length, fp);
 | 
			
		||||
 | 
			
		||||
    sprintf(output, "  // %s\n", get_state_string((lexer_state_t)i));
 | 
			
		||||
    length = strlen(output);
 | 
			
		||||
    fwrite(output, sizeof(char), length, fp);
 | 
			
		||||
 | 
			
		||||
    memset(output, 0, STRING_BUF_LENGTH);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
INTERNAL void set_column_width(lexer_state_t state) {
 | 
			
		||||
  if (state >= COUNT_LEXER_STATES) {
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  const char *output = state_strings[state];
 | 
			
		||||
  i32 length = strlen(output);
 | 
			
		||||
 | 
			
		||||
  column_width = length > column_width ? length : column_width;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
INTERNAL const char *get_input_string(lexer_input_t input) {
 | 
			
		||||
  if (input >= COUNT_LEXER_INPUTS) {
 | 
			
		||||
    return "";
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return input_strings[input];
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
INTERNAL const char *get_state_string(lexer_state_t state) {
 | 
			
		||||
  if (state >= COUNT_LEXER_STATES) {
 | 
			
		||||
    return "";
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return state_strings[state];
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t lexer_state_machine(lexer_state_t state, lexer_input_t input) {
 | 
			
		||||
  switch (state) {
 | 
			
		||||
  case LEXER_STATE_START:
 | 
			
		||||
    return handle_lexer_start(input);
 | 
			
		||||
  case LEXER_STATE_VALUE:
 | 
			
		||||
    return handle_value(input);
 | 
			
		||||
  case LEXER_STATE_OBJECT:
 | 
			
		||||
    return handle_object(input);
 | 
			
		||||
  case LEXER_STATE_OBJECT_END:
 | 
			
		||||
    return handle_object_end(input);
 | 
			
		||||
  case LEXER_STATE_ARRAY:
 | 
			
		||||
    return handle_array(input);
 | 
			
		||||
  case LEXER_STATE_ARRAY_END:
 | 
			
		||||
    return handle_array_end(input);
 | 
			
		||||
  case LEXER_STATE_KEY:
 | 
			
		||||
    return handle_key(input);
 | 
			
		||||
  case LEXER_STATE_DECIMAL:
 | 
			
		||||
    return handle_decimal(input);
 | 
			
		||||
  case LEXER_STATE_NUMBER:
 | 
			
		||||
    return handle_number(input);
 | 
			
		||||
  case LEXER_STATE_FRACTION:
 | 
			
		||||
    return handle_fraction(input);
 | 
			
		||||
  case LEXER_STATE_EXPONENT:
 | 
			
		||||
    return handle_exponent(input);
 | 
			
		||||
  case LEXER_STATE_EXP_SIGN:
 | 
			
		||||
    return handle_exp_sign(input);
 | 
			
		||||
  case LEXER_STATE_POWER:
 | 
			
		||||
    return handle_power(input);
 | 
			
		||||
  case LEXER_STATE_NUMBER_END:
 | 
			
		||||
    return handle_number_end(input);
 | 
			
		||||
  case LEXER_STATE_STRING:
 | 
			
		||||
    return handle_string(input);
 | 
			
		||||
  case LEXER_STATE_STRING_END:
 | 
			
		||||
    return handle_string_end(input);
 | 
			
		||||
  case LEXER_STATE_ESCAPE_SEQUENCE:
 | 
			
		||||
    return handle_escape_sequence(input);
 | 
			
		||||
  case LEXER_STATE_UNICODE_HEX1:
 | 
			
		||||
    return handle_unicode_hex(input, LEXER_STATE_UNICODE_HEX2);
 | 
			
		||||
  case LEXER_STATE_UNICODE_HEX2:
 | 
			
		||||
    return handle_unicode_hex(input, LEXER_STATE_UNICODE_HEX3);
 | 
			
		||||
  case LEXER_STATE_UNICODE_HEX3:
 | 
			
		||||
    return handle_unicode_hex(input, LEXER_STATE_UNICODE_HEX4);
 | 
			
		||||
  case LEXER_STATE_UNICODE_HEX4:
 | 
			
		||||
    return handle_unicode_hex(input, LEXER_STATE_STRING);
 | 
			
		||||
  case LEXER_STATE_T:
 | 
			
		||||
    return handle_true(input, LEXER_STATE_T);
 | 
			
		||||
  case LEXER_STATE_TR:
 | 
			
		||||
    return handle_true(input, LEXER_STATE_TR);
 | 
			
		||||
  case LEXER_STATE_TRU:
 | 
			
		||||
    return handle_true(input, LEXER_STATE_TRU);
 | 
			
		||||
  case LEXER_STATE_F:
 | 
			
		||||
    return handle_false(input, LEXER_STATE_F);
 | 
			
		||||
  case LEXER_STATE_FA:
 | 
			
		||||
    return handle_false(input, LEXER_STATE_FA);
 | 
			
		||||
  case LEXER_STATE_FAL:
 | 
			
		||||
    return handle_false(input, LEXER_STATE_FAL);
 | 
			
		||||
  case LEXER_STATE_FALS:
 | 
			
		||||
    return handle_false(input, LEXER_STATE_FALS);
 | 
			
		||||
  case LEXER_STATE_N:
 | 
			
		||||
    return handle_null(input, LEXER_STATE_N);
 | 
			
		||||
  case LEXER_STATE_NU:
 | 
			
		||||
    return handle_null(input, LEXER_STATE_NU);
 | 
			
		||||
  case LEXER_STATE_NUL:
 | 
			
		||||
    return handle_null(input, LEXER_STATE_NUL);
 | 
			
		||||
  case LEXER_STATE_KEYWORD_END:
 | 
			
		||||
    return handle_keyword_end(input);
 | 
			
		||||
  case LEXER_STATE_LAST_COLLECTION:
 | 
			
		||||
    return handle_last_collection(input);
 | 
			
		||||
  case LEXER_STATE_TRUE:
 | 
			
		||||
  case LEXER_STATE_FALSE:
 | 
			
		||||
  case LEXER_STATE_NULL:
 | 
			
		||||
  case LEXER_STATE_OBJECT_START:
 | 
			
		||||
  case LEXER_STATE_ARRAY_START:
 | 
			
		||||
  case LEXER_STATE_KEY_END:
 | 
			
		||||
  case LEXER_STATE_VALUE_END:
 | 
			
		||||
  case LEXER_STATE_ERROR:
 | 
			
		||||
  case COUNT_LEXER_STATES:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_lexer_start(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_START;
 | 
			
		||||
  case LEXER_INPUT_OPEN_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_START;
 | 
			
		||||
  case LEXER_INPUT_OPEN_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_START;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_last_collection(char input) {
 | 
			
		||||
  if (input == LEXER_INPUT_NEWLINE || input == LEXER_INPUT_WHITE_SPACE) {
 | 
			
		||||
    return LEXER_STATE_LAST_COLLECTION;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return LEXER_STATE_ERROR;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_object(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT;
 | 
			
		||||
  case LEXER_INPUT_DOUBLE_QUOTE:
 | 
			
		||||
    return LEXER_STATE_KEY;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_object_end(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_END;
 | 
			
		||||
  case LEXER_INPUT_COMMA:
 | 
			
		||||
    return LEXER_STATE_VALUE_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_array(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_ARRAY;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return handle_value(input);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_array_end(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_END;
 | 
			
		||||
  case LEXER_INPUT_COMMA:
 | 
			
		||||
    return LEXER_STATE_VALUE_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_key(lexer_input_t input) { return LEXER_STATE_STRING; }
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_value(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_VALUE;
 | 
			
		||||
  case LEXER_INPUT_NON_ZERO:
 | 
			
		||||
  case LEXER_INPUT_MINUS:
 | 
			
		||||
    return LEXER_STATE_NUMBER;
 | 
			
		||||
  case LEXER_INPUT_ZERO:
 | 
			
		||||
    return LEXER_STATE_DECIMAL;
 | 
			
		||||
  case LEXER_INPUT_DOUBLE_QUOTE:
 | 
			
		||||
    return LEXER_STATE_STRING;
 | 
			
		||||
  case LEXER_INPUT_OPEN_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_START;
 | 
			
		||||
  case LEXER_INPUT_OPEN_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_START;
 | 
			
		||||
  case LEXER_INPUT_LOWER_T:
 | 
			
		||||
    return LEXER_STATE_T;
 | 
			
		||||
  case LEXER_INPUT_LOWER_F:
 | 
			
		||||
    return LEXER_STATE_F;
 | 
			
		||||
  case LEXER_INPUT_LOWER_N:
 | 
			
		||||
    return LEXER_STATE_N;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_string(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_BACK_SLASH:
 | 
			
		||||
    return LEXER_STATE_ESCAPE_SEQUENCE;
 | 
			
		||||
  case LEXER_INPUT_DOUBLE_QUOTE:
 | 
			
		||||
    return LEXER_STATE_STRING_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_STRING;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_string_end(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_STRING_END;
 | 
			
		||||
  case LEXER_INPUT_COLON:
 | 
			
		||||
    return LEXER_STATE_KEY_END;
 | 
			
		||||
  case LEXER_INPUT_COMMA:
 | 
			
		||||
    return LEXER_STATE_VALUE_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_escape_sequence(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_DOUBLE_QUOTE:
 | 
			
		||||
  case LEXER_INPUT_FORWARD_SLASH:
 | 
			
		||||
  case LEXER_INPUT_BACK_SLASH:
 | 
			
		||||
  case LEXER_INPUT_LOWER_B:
 | 
			
		||||
  case LEXER_INPUT_LOWER_F:
 | 
			
		||||
  case LEXER_INPUT_LOWER_N:
 | 
			
		||||
  case LEXER_INPUT_LOWER_R:
 | 
			
		||||
  case LEXER_INPUT_LOWER_T:
 | 
			
		||||
    return LEXER_STATE_STRING;
 | 
			
		||||
  case LEXER_INPUT_LOWER_U:
 | 
			
		||||
    return LEXER_STATE_UNICODE_HEX1;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
INTERNAL lexer_state_t handle_unicode_hex(lexer_input_t input,
 | 
			
		||||
                                          lexer_state_t return_state) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_LOWER_A:
 | 
			
		||||
  case LEXER_INPUT_LOWER_B:
 | 
			
		||||
  case LEXER_INPUT_LOWER_C:
 | 
			
		||||
  case LEXER_INPUT_LOWER_D:
 | 
			
		||||
  case LEXER_INPUT_LOWER_E:
 | 
			
		||||
  case LEXER_INPUT_LOWER_F:
 | 
			
		||||
  case LEXER_INPUT_UPPER_A:
 | 
			
		||||
  case LEXER_INPUT_UPPER_B:
 | 
			
		||||
  case LEXER_INPUT_UPPER_C:
 | 
			
		||||
  case LEXER_INPUT_UPPER_D:
 | 
			
		||||
  case LEXER_INPUT_UPPER_E:
 | 
			
		||||
  case LEXER_INPUT_UPPER_F:
 | 
			
		||||
  case LEXER_INPUT_ZERO:
 | 
			
		||||
  case LEXER_INPUT_NON_ZERO:
 | 
			
		||||
    return return_state;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_decimal(lexer_input_t input) {
 | 
			
		||||
  if (input == LEXER_INPUT_DECIMAL) {
 | 
			
		||||
    return LEXER_STATE_FRACTION;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return LEXER_STATE_ERROR;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_number(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_ZERO:
 | 
			
		||||
  case LEXER_INPUT_NON_ZERO:
 | 
			
		||||
    return LEXER_STATE_NUMBER;
 | 
			
		||||
  case LEXER_INPUT_DECIMAL:
 | 
			
		||||
    return LEXER_STATE_FRACTION;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_END;
 | 
			
		||||
  case LEXER_INPUT_COMMA:
 | 
			
		||||
    return LEXER_STATE_VALUE_END;
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_NUMBER_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_fraction(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_ZERO:
 | 
			
		||||
  case LEXER_INPUT_NON_ZERO:
 | 
			
		||||
    return LEXER_STATE_FRACTION;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_END;
 | 
			
		||||
  case LEXER_INPUT_LOWER_E:
 | 
			
		||||
  case LEXER_INPUT_UPPER_E:
 | 
			
		||||
    return LEXER_STATE_EXPONENT;
 | 
			
		||||
  case LEXER_INPUT_COMMA:
 | 
			
		||||
    return LEXER_STATE_VALUE_END;
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_NUMBER_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_exponent(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_ZERO:
 | 
			
		||||
  case LEXER_INPUT_NON_ZERO:
 | 
			
		||||
    return LEXER_STATE_POWER;
 | 
			
		||||
  case LEXER_INPUT_PLUS:
 | 
			
		||||
  case LEXER_INPUT_MINUS:
 | 
			
		||||
    return LEXER_STATE_EXP_SIGN;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_exp_sign(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_ZERO:
 | 
			
		||||
  case LEXER_INPUT_NON_ZERO:
 | 
			
		||||
    return LEXER_STATE_POWER;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_power(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_ZERO:
 | 
			
		||||
  case LEXER_INPUT_NON_ZERO:
 | 
			
		||||
    return LEXER_STATE_POWER;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_END;
 | 
			
		||||
  case LEXER_INPUT_COMMA:
 | 
			
		||||
    return LEXER_STATE_VALUE_END;
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_NUMBER_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_number_end(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_NUMBER_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_END;
 | 
			
		||||
  case LEXER_INPUT_COMMA:
 | 
			
		||||
    return LEXER_STATE_VALUE_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_true(lexer_input_t input, lexer_state_t start_state) {
 | 
			
		||||
  switch (start_state) {
 | 
			
		||||
  case LEXER_STATE_T:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_R ? LEXER_STATE_TR : LEXER_STATE_ERROR;
 | 
			
		||||
  case LEXER_STATE_TR:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_U ? LEXER_STATE_TRU : LEXER_STATE_ERROR;
 | 
			
		||||
  case LEXER_STATE_TRU:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_E ? LEXER_STATE_TRUE : LEXER_STATE_ERROR;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_false(lexer_input_t input, lexer_state_t start_state) {
 | 
			
		||||
  switch (start_state) {
 | 
			
		||||
  case LEXER_STATE_F:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_A ? LEXER_STATE_FA : LEXER_STATE_ERROR;
 | 
			
		||||
  case LEXER_STATE_FA:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_L ? LEXER_STATE_FAL : LEXER_STATE_ERROR;
 | 
			
		||||
  case LEXER_STATE_FAL:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_S ? LEXER_STATE_FALS : LEXER_STATE_ERROR;
 | 
			
		||||
  case LEXER_STATE_FALS:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_E ? LEXER_STATE_FALSE : LEXER_STATE_ERROR;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_null(lexer_input_t input, lexer_state_t start_state) {
 | 
			
		||||
  switch (start_state) {
 | 
			
		||||
  case LEXER_STATE_N:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_U ? LEXER_STATE_NU : LEXER_STATE_ERROR;
 | 
			
		||||
  case LEXER_STATE_NU:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_L ? LEXER_STATE_NUL : LEXER_STATE_ERROR;
 | 
			
		||||
  case LEXER_STATE_NUL:
 | 
			
		||||
    return input == LEXER_INPUT_LOWER_L ? LEXER_STATE_NULL : LEXER_STATE_ERROR;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
lexer_state_t handle_keyword_end(lexer_input_t input) {
 | 
			
		||||
  switch (input) {
 | 
			
		||||
  case LEXER_INPUT_NEWLINE:
 | 
			
		||||
  case LEXER_INPUT_WHITE_SPACE:
 | 
			
		||||
    return LEXER_STATE_KEYWORD_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACE:
 | 
			
		||||
    return LEXER_STATE_OBJECT_END;
 | 
			
		||||
  case LEXER_INPUT_CLOSE_BRACKET:
 | 
			
		||||
    return LEXER_STATE_ARRAY_END;
 | 
			
		||||
  case LEXER_INPUT_COMMA:
 | 
			
		||||
    return LEXER_STATE_VALUE_END;
 | 
			
		||||
  default:
 | 
			
		||||
    return LEXER_STATE_ERROR;
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
@@ -4,9 +4,6 @@
 | 
			
		||||
#include "aliases.h"
 | 
			
		||||
#include <stdbool.h>
 | 
			
		||||
 | 
			
		||||
#define VALID_JSON true
 | 
			
		||||
#define INVALID_JSON false
 | 
			
		||||
 | 
			
		||||
typedef const char *str_view_t;
 | 
			
		||||
 | 
			
		||||
typedef enum {
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										96
									
								
								include/lexer/lexer_data.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										96
									
								
								include/lexer/lexer_data.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,96 @@
 | 
			
		||||
#ifndef LEXER_DATA_H
 | 
			
		||||
#define LEXER_DATA_H
 | 
			
		||||
 | 
			
		||||
typedef enum {
 | 
			
		||||
  // GENERAL STATES
 | 
			
		||||
  LEXER_STATE_ERROR,
 | 
			
		||||
  LEXER_STATE_START,
 | 
			
		||||
  LEXER_STATE_VALUE,
 | 
			
		||||
  LEXER_STATE_VALUE_END,
 | 
			
		||||
  // COLLECTION STATES
 | 
			
		||||
  LEXER_STATE_OBJECT_START,
 | 
			
		||||
  LEXER_STATE_OBJECT,
 | 
			
		||||
  LEXER_STATE_OBJECT_END,
 | 
			
		||||
  LEXER_STATE_ARRAY_START,
 | 
			
		||||
  LEXER_STATE_ARRAY,
 | 
			
		||||
  LEXER_STATE_ARRAY_END,
 | 
			
		||||
  LEXER_STATE_LAST_COLLECTION,
 | 
			
		||||
  // OBJECT STATES
 | 
			
		||||
  LEXER_STATE_KEY,
 | 
			
		||||
  LEXER_STATE_KEY_END,
 | 
			
		||||
  // NUMBER STATES
 | 
			
		||||
  LEXER_STATE_DECIMAL,
 | 
			
		||||
  LEXER_STATE_NUMBER,
 | 
			
		||||
  LEXER_STATE_FRACTION,
 | 
			
		||||
  LEXER_STATE_EXPONENT,
 | 
			
		||||
  LEXER_STATE_EXP_SIGN,
 | 
			
		||||
  LEXER_STATE_POWER,
 | 
			
		||||
  LEXER_STATE_NUMBER_END,
 | 
			
		||||
  // STRING STATES
 | 
			
		||||
  LEXER_STATE_STRING,
 | 
			
		||||
  LEXER_STATE_STRING_END,
 | 
			
		||||
  LEXER_STATE_ESCAPE_SEQUENCE,
 | 
			
		||||
  LEXER_STATE_UNICODE_HEX1,
 | 
			
		||||
  LEXER_STATE_UNICODE_HEX2,
 | 
			
		||||
  LEXER_STATE_UNICODE_HEX3,
 | 
			
		||||
  LEXER_STATE_UNICODE_HEX4,
 | 
			
		||||
  // KEYWORD STATES
 | 
			
		||||
  LEXER_STATE_T,
 | 
			
		||||
  LEXER_STATE_TR,
 | 
			
		||||
  LEXER_STATE_TRU,
 | 
			
		||||
  LEXER_STATE_TRUE,
 | 
			
		||||
  LEXER_STATE_F,
 | 
			
		||||
  LEXER_STATE_FA,
 | 
			
		||||
  LEXER_STATE_FAL,
 | 
			
		||||
  LEXER_STATE_FALS,
 | 
			
		||||
  LEXER_STATE_FALSE,
 | 
			
		||||
  LEXER_STATE_N,
 | 
			
		||||
  LEXER_STATE_NU,
 | 
			
		||||
  LEXER_STATE_NUL,
 | 
			
		||||
  LEXER_STATE_NULL,
 | 
			
		||||
  LEXER_STATE_KEYWORD_END,
 | 
			
		||||
 | 
			
		||||
  COUNT_LEXER_STATES,
 | 
			
		||||
} lexer_state_t;
 | 
			
		||||
 | 
			
		||||
typedef enum {
 | 
			
		||||
  LEXER_INPUT_NEWLINE,
 | 
			
		||||
  LEXER_INPUT_WHITE_SPACE,
 | 
			
		||||
  LEXER_INPUT_OPEN_BRACE,
 | 
			
		||||
  LEXER_INPUT_CLOSE_BRACE,
 | 
			
		||||
  LEXER_INPUT_OPEN_BRACKET,
 | 
			
		||||
  LEXER_INPUT_CLOSE_BRACKET,
 | 
			
		||||
  LEXER_INPUT_COMMA,
 | 
			
		||||
  LEXER_INPUT_COLON,
 | 
			
		||||
  LEXER_INPUT_DOUBLE_QUOTE,
 | 
			
		||||
  LEXER_INPUT_BACK_SLASH,
 | 
			
		||||
  LEXER_INPUT_FORWARD_SLASH,
 | 
			
		||||
  LEXER_INPUT_LOWER_A,
 | 
			
		||||
  LEXER_INPUT_LOWER_B,
 | 
			
		||||
  LEXER_INPUT_LOWER_C,
 | 
			
		||||
  LEXER_INPUT_LOWER_D,
 | 
			
		||||
  LEXER_INPUT_LOWER_E,
 | 
			
		||||
  LEXER_INPUT_LOWER_F,
 | 
			
		||||
  LEXER_INPUT_LOWER_L,
 | 
			
		||||
  LEXER_INPUT_LOWER_N,
 | 
			
		||||
  LEXER_INPUT_LOWER_R,
 | 
			
		||||
  LEXER_INPUT_LOWER_S,
 | 
			
		||||
  LEXER_INPUT_LOWER_T,
 | 
			
		||||
  LEXER_INPUT_LOWER_U,
 | 
			
		||||
  LEXER_INPUT_UPPER_A,
 | 
			
		||||
  LEXER_INPUT_UPPER_B,
 | 
			
		||||
  LEXER_INPUT_UPPER_C,
 | 
			
		||||
  LEXER_INPUT_UPPER_D,
 | 
			
		||||
  LEXER_INPUT_UPPER_E,
 | 
			
		||||
  LEXER_INPUT_UPPER_F,
 | 
			
		||||
  LEXER_INPUT_MINUS,
 | 
			
		||||
  LEXER_INPUT_PLUS,
 | 
			
		||||
  LEXER_INPUT_DECIMAL,
 | 
			
		||||
  LEXER_INPUT_ZERO,
 | 
			
		||||
  LEXER_INPUT_NON_ZERO,
 | 
			
		||||
  LEXER_INPUT_OTHER,
 | 
			
		||||
 | 
			
		||||
  COUNT_LEXER_INPUTS,
 | 
			
		||||
} lexer_input_t;
 | 
			
		||||
 | 
			
		||||
#endif // !LEXER_DATA_H
 | 
			
		||||
							
								
								
									
										42
									
								
								include/lexer/lexer_state_transitions.table
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								include/lexer/lexer_state_transitions.table
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,42 @@
 | 
			
		||||
//          NEWLINE          |         WHITE_SPACE        |          OPEN_BRACE        |         CLOSE_BRACE        |         OPEN_BRACKET       |        CLOSE_BRACKET       |            COMMA           |            COLON           |         DOUBLE_QUOTE       |          BACK_SLASH        |        FORWARD_SLASH       |           LOWER_A          |           LOWER_B          |           LOWER_C          |           LOWER_D          |           LOWER_E          |           LOWER_F          |           LOWER_L          |           LOWER_N          |           LOWER_R          |           LOWER_S          |           LOWER_T          |           LOWER_U          |           UPPER_A          |           UPPER_B          |           UPPER_C          |           UPPER_D          |           UPPER_E          |           UPPER_F          |            MINUS           |             PLUS           |           DECIMAL          |             ZERO           |           NON_ZERO         |            OTHER           |    
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_ERROR
 | 
			
		||||
{           LEXER_STATE_START,           LEXER_STATE_START,    LEXER_STATE_OBJECT_START,           LEXER_STATE_ERROR,     LEXER_STATE_ARRAY_START,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_START
 | 
			
		||||
{           LEXER_STATE_VALUE,           LEXER_STATE_VALUE,    LEXER_STATE_OBJECT_START,           LEXER_STATE_ERROR,     LEXER_STATE_ARRAY_START,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,               LEXER_STATE_F,           LEXER_STATE_ERROR,               LEXER_STATE_N,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,               LEXER_STATE_T,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,          LEXER_STATE_NUMBER,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,         LEXER_STATE_DECIMAL,          LEXER_STATE_NUMBER,           LEXER_STATE_ERROR, },  // LEXER_STATE_VALUE
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_VALUE_END
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_OBJECT_START
 | 
			
		||||
{          LEXER_STATE_OBJECT,          LEXER_STATE_OBJECT,           LEXER_STATE_ERROR,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,             LEXER_STATE_KEY,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_OBJECT
 | 
			
		||||
{      LEXER_STATE_OBJECT_END,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,       LEXER_STATE_ARRAY_END,       LEXER_STATE_VALUE_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_OBJECT_END
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_ARRAY_START
 | 
			
		||||
{           LEXER_STATE_ARRAY,           LEXER_STATE_ARRAY,    LEXER_STATE_OBJECT_START,           LEXER_STATE_ERROR,     LEXER_STATE_ARRAY_START,       LEXER_STATE_ARRAY_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,               LEXER_STATE_F,           LEXER_STATE_ERROR,               LEXER_STATE_N,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,               LEXER_STATE_T,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,          LEXER_STATE_NUMBER,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,         LEXER_STATE_DECIMAL,          LEXER_STATE_NUMBER,           LEXER_STATE_ERROR, },  // LEXER_STATE_ARRAY
 | 
			
		||||
{       LEXER_STATE_ARRAY_END,       LEXER_STATE_ARRAY_END,           LEXER_STATE_ERROR,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,       LEXER_STATE_ARRAY_END,       LEXER_STATE_VALUE_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_ARRAY_END
 | 
			
		||||
{ LEXER_STATE_LAST_COLLECTION, LEXER_STATE_LAST_COLLECTION,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_LAST_COLLECTION
 | 
			
		||||
{          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING, },  // LEXER_STATE_KEY
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_KEY_END
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,        LEXER_STATE_FRACTION,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_DECIMAL
 | 
			
		||||
{      LEXER_STATE_NUMBER_END,      LEXER_STATE_NUMBER_END,           LEXER_STATE_ERROR,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,       LEXER_STATE_ARRAY_END,       LEXER_STATE_VALUE_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,        LEXER_STATE_FRACTION,          LEXER_STATE_NUMBER,          LEXER_STATE_NUMBER,           LEXER_STATE_ERROR, },  // LEXER_STATE_NUMBER
 | 
			
		||||
{      LEXER_STATE_NUMBER_END,      LEXER_STATE_NUMBER_END,           LEXER_STATE_ERROR,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,       LEXER_STATE_ARRAY_END,       LEXER_STATE_VALUE_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,        LEXER_STATE_EXPONENT,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,        LEXER_STATE_EXPONENT,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,        LEXER_STATE_FRACTION,        LEXER_STATE_FRACTION,           LEXER_STATE_ERROR, },  // LEXER_STATE_FRACTION
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,        LEXER_STATE_EXP_SIGN,        LEXER_STATE_EXP_SIGN,           LEXER_STATE_ERROR,           LEXER_STATE_POWER,           LEXER_STATE_POWER,           LEXER_STATE_ERROR, },  // LEXER_STATE_EXPONENT
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_POWER,           LEXER_STATE_POWER,           LEXER_STATE_ERROR, },  // LEXER_STATE_EXP_SIGN
 | 
			
		||||
{      LEXER_STATE_NUMBER_END,      LEXER_STATE_NUMBER_END,           LEXER_STATE_ERROR,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,       LEXER_STATE_ARRAY_END,       LEXER_STATE_VALUE_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_POWER,           LEXER_STATE_POWER,           LEXER_STATE_ERROR, },  // LEXER_STATE_POWER
 | 
			
		||||
{      LEXER_STATE_NUMBER_END,      LEXER_STATE_NUMBER_END,           LEXER_STATE_ERROR,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,       LEXER_STATE_ARRAY_END,       LEXER_STATE_VALUE_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_NUMBER_END
 | 
			
		||||
{          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,      LEXER_STATE_STRING_END, LEXER_STATE_ESCAPE_SEQUENCE,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING, },  // LEXER_STATE_STRING
 | 
			
		||||
{      LEXER_STATE_STRING_END,      LEXER_STATE_STRING_END,           LEXER_STATE_ERROR,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,       LEXER_STATE_ARRAY_END,       LEXER_STATE_VALUE_END,         LEXER_STATE_KEY_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_STRING_END
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,          LEXER_STATE_STRING,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,    LEXER_STATE_UNICODE_HEX1,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_ESCAPE_SEQUENCE
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,    LEXER_STATE_UNICODE_HEX2,    LEXER_STATE_UNICODE_HEX2,           LEXER_STATE_ERROR, },  // LEXER_STATE_UNICODE_HEX1
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,    LEXER_STATE_UNICODE_HEX3,    LEXER_STATE_UNICODE_HEX3,           LEXER_STATE_ERROR, },  // LEXER_STATE_UNICODE_HEX2
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,    LEXER_STATE_UNICODE_HEX4,    LEXER_STATE_UNICODE_HEX4,           LEXER_STATE_ERROR, },  // LEXER_STATE_UNICODE_HEX3
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,          LEXER_STATE_STRING,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,          LEXER_STATE_STRING,          LEXER_STATE_STRING,           LEXER_STATE_ERROR, },  // LEXER_STATE_UNICODE_HEX4
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,              LEXER_STATE_TR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_T
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,             LEXER_STATE_TRU,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_TR
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,            LEXER_STATE_TRUE,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_TRU
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_TRUE
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,              LEXER_STATE_FA,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_F
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,             LEXER_STATE_FAL,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_FA
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,            LEXER_STATE_FALS,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_FAL
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_FALSE,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_FALS
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_FALSE
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,              LEXER_STATE_NU,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_N
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,             LEXER_STATE_NUL,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_NU
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,            LEXER_STATE_NULL,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_NUL
 | 
			
		||||
{           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_NULL
 | 
			
		||||
{     LEXER_STATE_KEYWORD_END,     LEXER_STATE_KEYWORD_END,           LEXER_STATE_ERROR,      LEXER_STATE_OBJECT_END,           LEXER_STATE_ERROR,       LEXER_STATE_ARRAY_END,       LEXER_STATE_VALUE_END,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR,           LEXER_STATE_ERROR, },  // LEXER_STATE_KEYWORD_END
 | 
			
		||||
							
								
								
									
										41
									
								
								notes
									
									
									
									
									
								
							
							
						
						
									
										41
									
								
								notes
									
									
									
									
									
								
							@@ -1,41 +0,0 @@
 | 
			
		||||
TOKENS
 | 
			
		||||
	Symbols
 | 
			
		||||
		Array notation
 | 
			
		||||
			[
 | 
			
		||||
			]
 | 
			
		||||
		Object notation
 | 
			
		||||
			{
 | 
			
		||||
			}
 | 
			
		||||
			:
 | 
			
		||||
		Separator
 | 
			
		||||
			,
 | 
			
		||||
		String
 | 
			
		||||
			"
 | 
			
		||||
			\ (for escape sequences)
 | 
			
		||||
		Numerical
 | 
			
		||||
			-
 | 
			
		||||
			.
 | 
			
		||||
			eE (exponents only)
 | 
			
		||||
			+ (exponents only)
 | 
			
		||||
	Keywords
 | 
			
		||||
		true
 | 
			
		||||
		false
 | 
			
		||||
		null
 | 
			
		||||
	Key
 | 
			
		||||
		strings only
 | 
			
		||||
 | 
			
		||||
Implement stack data structure for pushing and pulling states when necessary
 | 
			
		||||
 | 
			
		||||
LEXER STATES
 | 
			
		||||
	START
 | 
			
		||||
	ERROR
 | 
			
		||||
	END
 | 
			
		||||
	VALUE
 | 
			
		||||
	OBJECT_KEY
 | 
			
		||||
	     ---------
 | 
			
		||||
	OBJECT        |
 | 
			
		||||
	ARRAY         |
 | 
			
		||||
	PRIMITIVES    |------> Can be values
 | 
			
		||||
	STRING--------|------> Only one that can be an object key
 | 
			
		||||
	NUMBER        |
 | 
			
		||||
	     ---------
 | 
			
		||||
@@ -1,5 +0,0 @@
 | 
			
		||||
#!/bin/bash
 | 
			
		||||
 | 
			
		||||
for JSON in $(find test_files -iregex .*json); do
 | 
			
		||||
	./main $JSON
 | 
			
		||||
done
 | 
			
		||||
							
								
								
									
										71
									
								
								run_tests.py
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										71
									
								
								run_tests.py
									
									
									
									
									
										Executable file
									
								
							@@ -0,0 +1,71 @@
 | 
			
		||||
#!/bin/env python3
 | 
			
		||||
 | 
			
		||||
import json
 | 
			
		||||
import subprocess
 | 
			
		||||
from pathlib import Path
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
class TermFormat:
 | 
			
		||||
    OKGREEN = "\033[92m"
 | 
			
		||||
    FAIL = "\033[91m"
 | 
			
		||||
    ENDC = "\033[0m"
 | 
			
		||||
    BOLD = "\033[1m"
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
def print_header(header, width, padding):
 | 
			
		||||
    print(
 | 
			
		||||
        f"{TermFormat.BOLD}{'=' * (int(width / 3) + padding)}{header}{'=' * (int(width / 3) + padding)}{TermFormat.ENDC}"
 | 
			
		||||
    )
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
test_dir = Path(__file__).parent / "test_files"
 | 
			
		||||
hj_exec = Path(__file__).parent / "main"
 | 
			
		||||
 | 
			
		||||
valid_files = [
 | 
			
		||||
    json_file
 | 
			
		||||
    for json_file in test_dir.iterdir()
 | 
			
		||||
    if json_file.is_file()
 | 
			
		||||
    and "json" in json_file.suffix
 | 
			
		||||
    and "invalid" not in json_file.stem
 | 
			
		||||
]
 | 
			
		||||
 | 
			
		||||
name_width = 0
 | 
			
		||||
 | 
			
		||||
for vf in valid_files:
 | 
			
		||||
    if len(str(vf)) > name_width:
 | 
			
		||||
        name_width = len(str(vf))
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
print_header("helloJSON TEST SUITE", name_width, 9)
 | 
			
		||||
print()
 | 
			
		||||
print_header("VALID FILES", name_width, 13)
 | 
			
		||||
 | 
			
		||||
for vf in valid_files:
 | 
			
		||||
    with open(vf, "r") as infile:
 | 
			
		||||
        try:
 | 
			
		||||
            original = json.load(infile)
 | 
			
		||||
        except json.JSONDecodeError as e:
 | 
			
		||||
            print(
 | 
			
		||||
                f"\n{TermFormat.BOLD}{TermFormat.FAIL}ERROR:{TermFormat.ENDC} Failed to decode {str(vf)}\n{e.msg}"
 | 
			
		||||
            )
 | 
			
		||||
            continue
 | 
			
		||||
 | 
			
		||||
    cmd = [hj_exec, vf]
 | 
			
		||||
 | 
			
		||||
    proc = subprocess.Popen(cmd, stdout=subprocess.PIPE, stderr=subprocess.STDOUT)
 | 
			
		||||
 | 
			
		||||
    proc.wait()
 | 
			
		||||
 | 
			
		||||
    stdout, _ = proc.communicate()
 | 
			
		||||
 | 
			
		||||
    try:
 | 
			
		||||
        parsed = json.loads(stdout)
 | 
			
		||||
    except:
 | 
			
		||||
        parsed = None
 | 
			
		||||
        pass
 | 
			
		||||
 | 
			
		||||
    match = original == parsed
 | 
			
		||||
 | 
			
		||||
    print(
 | 
			
		||||
        f"\n{str(vf):{name_width + 3}} {TermFormat.BOLD}{TermFormat.OKGREEN if match else TermFormat.FAIL}{'PASSED' if match else 'FAILED'}{TermFormat.ENDC}"
 | 
			
		||||
    )
 | 
			
		||||
							
								
								
									
										1060
									
								
								src/lexer/lexer.c
									
									
									
									
									
								
							
							
						
						
									
										1060
									
								
								src/lexer/lexer.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -5,7 +5,7 @@
 | 
			
		||||
			"position": [
 | 
			
		||||
				25.1212,
 | 
			
		||||
				55.1535
 | 
			
		||||
			],
 | 
			
		||||
			]
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"name": "Shangri-La Hotel",
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user