Add dstr_resize and rename the dstring functions
This commit is contained in:
parent
31e19a50fc
commit
76620b593a
@ -14,9 +14,9 @@
|
|||||||
"main",
|
"main",
|
||||||
"src/main.c"
|
"src/main.c"
|
||||||
],
|
],
|
||||||
"directory": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json",
|
"directory": "/Users/abdelrahman/dev/personal/say-it-in-json",
|
||||||
"file": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json/src/main.c",
|
"file": "/Users/abdelrahman/dev/personal/say-it-in-json/src/main.c",
|
||||||
"output": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json/main"
|
"output": "/Users/abdelrahman/dev/personal/say-it-in-json/main"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"arguments": [
|
"arguments": [
|
||||||
@ -33,9 +33,9 @@
|
|||||||
"main",
|
"main",
|
||||||
"src/dstring/dstring.c"
|
"src/dstring/dstring.c"
|
||||||
],
|
],
|
||||||
"directory": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json",
|
"directory": "/Users/abdelrahman/dev/personal/say-it-in-json",
|
||||||
"file": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json/src/dstring/dstring.c",
|
"file": "/Users/abdelrahman/dev/personal/say-it-in-json/src/dstring/dstring.c",
|
||||||
"output": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json/main"
|
"output": "/Users/abdelrahman/dev/personal/say-it-in-json/main"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"arguments": [
|
"arguments": [
|
||||||
@ -52,215 +52,8 @@
|
|||||||
"main",
|
"main",
|
||||||
"src/lexer/lexer.c"
|
"src/lexer/lexer.c"
|
||||||
],
|
],
|
||||||
"directory": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json",
|
"directory": "/Users/abdelrahman/dev/personal/say-it-in-json",
|
||||||
"file": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json/src/lexer/lexer.c",
|
"file": "/Users/abdelrahman/dev/personal/say-it-in-json/src/lexer/lexer.c",
|
||||||
"output": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json/main"
|
"output": "/Users/abdelrahman/dev/personal/say-it-in-json/main"
|
||||||
},
|
|
||||||
{
|
|
||||||
"arguments": [
|
|
||||||
"/usr/bin/clang-16",
|
|
||||||
"-cc1",
|
|
||||||
"-triple",
|
|
||||||
"x86_64-redhat-linux-gnu",
|
|
||||||
"-emit-obj",
|
|
||||||
"-mrelax-all",
|
|
||||||
"-disable-free",
|
|
||||||
"-clear-ast-before-backend",
|
|
||||||
"-disable-llvm-verifier",
|
|
||||||
"-discard-value-names",
|
|
||||||
"-main-file-name",
|
|
||||||
"-mrelocation-model",
|
|
||||||
"static",
|
|
||||||
"-mframe-pointer=all",
|
|
||||||
"-fmath-errno",
|
|
||||||
"-ffp-contract=on",
|
|
||||||
"-fno-rounding-math",
|
|
||||||
"-mconstructor-aliases",
|
|
||||||
"-funwind-tables=2",
|
|
||||||
"-target-cpu",
|
|
||||||
"x86-64",
|
|
||||||
"-tune-cpu",
|
|
||||||
"generic",
|
|
||||||
"-mllvm",
|
|
||||||
"-treat-scalable-fixed-error-as-warning",
|
|
||||||
"-debug-info-kind=constructor",
|
|
||||||
"-dwarf-version=4",
|
|
||||||
"-debugger-tuning=gdb",
|
|
||||||
"-fcoverage-compilation-dir=/home/abdelrahman/dev_work/say_it_in_json",
|
|
||||||
"-resource-dir",
|
|
||||||
"/usr/lib64/clang/16",
|
|
||||||
"-I",
|
|
||||||
"include",
|
|
||||||
"-I",
|
|
||||||
"include/dstring",
|
|
||||||
"-I",
|
|
||||||
"include/lexer",
|
|
||||||
"-internal-isystem",
|
|
||||||
"/usr/lib64/clang/16/include",
|
|
||||||
"-internal-isystem",
|
|
||||||
"/usr/local/include",
|
|
||||||
"-internal-isystem",
|
|
||||||
"/usr/bin/../lib/gcc/x86_64-redhat-linux/13/../../../../x86_64-redhat-linux/include",
|
|
||||||
"-internal-externc-isystem",
|
|
||||||
"/include",
|
|
||||||
"-internal-externc-isystem",
|
|
||||||
"/usr/include",
|
|
||||||
"-Wall",
|
|
||||||
"-Werror",
|
|
||||||
"-pedantic",
|
|
||||||
"-fdebug-compilation-dir=/home/abdelrahman/dev_work/say_it_in_json",
|
|
||||||
"-ferror-limit",
|
|
||||||
"19",
|
|
||||||
"-fgnuc-version=4.2.1",
|
|
||||||
"-fcolor-diagnostics",
|
|
||||||
"-faddrsig",
|
|
||||||
"-D__GCC_HAVE_DWARF2_CFI_ASM=1",
|
|
||||||
"-x",
|
|
||||||
"c",
|
|
||||||
"-o",
|
|
||||||
"/tmp/main-e1ef59.o",
|
|
||||||
"src/main.c"
|
|
||||||
],
|
|
||||||
"directory": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json",
|
|
||||||
"file": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json/src/main.c",
|
|
||||||
"output": "/tmp/main-e1ef59.o"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"arguments": [
|
|
||||||
"/usr/bin/clang-16",
|
|
||||||
"-cc1",
|
|
||||||
"-triple",
|
|
||||||
"x86_64-redhat-linux-gnu",
|
|
||||||
"-emit-obj",
|
|
||||||
"-mrelax-all",
|
|
||||||
"-disable-free",
|
|
||||||
"-clear-ast-before-backend",
|
|
||||||
"-disable-llvm-verifier",
|
|
||||||
"-discard-value-names",
|
|
||||||
"-main-file-name",
|
|
||||||
"-mrelocation-model",
|
|
||||||
"static",
|
|
||||||
"-mframe-pointer=all",
|
|
||||||
"-fmath-errno",
|
|
||||||
"-ffp-contract=on",
|
|
||||||
"-fno-rounding-math",
|
|
||||||
"-mconstructor-aliases",
|
|
||||||
"-funwind-tables=2",
|
|
||||||
"-target-cpu",
|
|
||||||
"x86-64",
|
|
||||||
"-tune-cpu",
|
|
||||||
"generic",
|
|
||||||
"-mllvm",
|
|
||||||
"-treat-scalable-fixed-error-as-warning",
|
|
||||||
"-debug-info-kind=constructor",
|
|
||||||
"-dwarf-version=4",
|
|
||||||
"-debugger-tuning=gdb",
|
|
||||||
"-fcoverage-compilation-dir=/home/abdelrahman/dev_work/say_it_in_json",
|
|
||||||
"-resource-dir",
|
|
||||||
"/usr/lib64/clang/16",
|
|
||||||
"-I",
|
|
||||||
"include",
|
|
||||||
"-I",
|
|
||||||
"include/dstring",
|
|
||||||
"-I",
|
|
||||||
"include/lexer",
|
|
||||||
"-internal-isystem",
|
|
||||||
"/usr/lib64/clang/16/include",
|
|
||||||
"-internal-isystem",
|
|
||||||
"/usr/local/include",
|
|
||||||
"-internal-isystem",
|
|
||||||
"/usr/bin/../lib/gcc/x86_64-redhat-linux/13/../../../../x86_64-redhat-linux/include",
|
|
||||||
"-internal-externc-isystem",
|
|
||||||
"/include",
|
|
||||||
"-internal-externc-isystem",
|
|
||||||
"/usr/include",
|
|
||||||
"-Wall",
|
|
||||||
"-Werror",
|
|
||||||
"-pedantic",
|
|
||||||
"-fdebug-compilation-dir=/home/abdelrahman/dev_work/say_it_in_json",
|
|
||||||
"-ferror-limit",
|
|
||||||
"19",
|
|
||||||
"-fgnuc-version=4.2.1",
|
|
||||||
"-fcolor-diagnostics",
|
|
||||||
"-faddrsig",
|
|
||||||
"-D__GCC_HAVE_DWARF2_CFI_ASM=1",
|
|
||||||
"-x",
|
|
||||||
"c",
|
|
||||||
"-o",
|
|
||||||
"/tmp/dstring-b2eb78.o",
|
|
||||||
"src/dstring/dstring.c"
|
|
||||||
],
|
|
||||||
"directory": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json",
|
|
||||||
"file": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json/src/dstring/dstring.c",
|
|
||||||
"output": "/tmp/dstring-b2eb78.o"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"arguments": [
|
|
||||||
"/usr/bin/clang-16",
|
|
||||||
"-cc1",
|
|
||||||
"-triple",
|
|
||||||
"x86_64-redhat-linux-gnu",
|
|
||||||
"-emit-obj",
|
|
||||||
"-mrelax-all",
|
|
||||||
"-disable-free",
|
|
||||||
"-clear-ast-before-backend",
|
|
||||||
"-disable-llvm-verifier",
|
|
||||||
"-discard-value-names",
|
|
||||||
"-main-file-name",
|
|
||||||
"-mrelocation-model",
|
|
||||||
"static",
|
|
||||||
"-mframe-pointer=all",
|
|
||||||
"-fmath-errno",
|
|
||||||
"-ffp-contract=on",
|
|
||||||
"-fno-rounding-math",
|
|
||||||
"-mconstructor-aliases",
|
|
||||||
"-funwind-tables=2",
|
|
||||||
"-target-cpu",
|
|
||||||
"x86-64",
|
|
||||||
"-tune-cpu",
|
|
||||||
"generic",
|
|
||||||
"-mllvm",
|
|
||||||
"-treat-scalable-fixed-error-as-warning",
|
|
||||||
"-debug-info-kind=constructor",
|
|
||||||
"-dwarf-version=4",
|
|
||||||
"-debugger-tuning=gdb",
|
|
||||||
"-fcoverage-compilation-dir=/home/abdelrahman/dev_work/say_it_in_json",
|
|
||||||
"-resource-dir",
|
|
||||||
"/usr/lib64/clang/16",
|
|
||||||
"-I",
|
|
||||||
"include",
|
|
||||||
"-I",
|
|
||||||
"include/dstring",
|
|
||||||
"-I",
|
|
||||||
"include/lexer",
|
|
||||||
"-internal-isystem",
|
|
||||||
"/usr/lib64/clang/16/include",
|
|
||||||
"-internal-isystem",
|
|
||||||
"/usr/local/include",
|
|
||||||
"-internal-isystem",
|
|
||||||
"/usr/bin/../lib/gcc/x86_64-redhat-linux/13/../../../../x86_64-redhat-linux/include",
|
|
||||||
"-internal-externc-isystem",
|
|
||||||
"/include",
|
|
||||||
"-internal-externc-isystem",
|
|
||||||
"/usr/include",
|
|
||||||
"-Wall",
|
|
||||||
"-Werror",
|
|
||||||
"-pedantic",
|
|
||||||
"-fdebug-compilation-dir=/home/abdelrahman/dev_work/say_it_in_json",
|
|
||||||
"-ferror-limit",
|
|
||||||
"19",
|
|
||||||
"-fgnuc-version=4.2.1",
|
|
||||||
"-fcolor-diagnostics",
|
|
||||||
"-faddrsig",
|
|
||||||
"-D__GCC_HAVE_DWARF2_CFI_ASM=1",
|
|
||||||
"-x",
|
|
||||||
"c",
|
|
||||||
"-o",
|
|
||||||
"/tmp/lexer-b0ee1f.o",
|
|
||||||
"src/lexer/lexer.c"
|
|
||||||
],
|
|
||||||
"directory": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json",
|
|
||||||
"file": "/mnt/3A5CDF785CDF2CFF/Users/abdoo/dev/say_it_in_json/src/lexer/lexer.c",
|
|
||||||
"output": "/tmp/lexer-b0ee1f.o"
|
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -3,17 +3,19 @@
|
|||||||
|
|
||||||
#include "aliases.h"
|
#include "aliases.h"
|
||||||
|
|
||||||
typedef struct dstr dstr_t;
|
typedef struct dstring dstr_t;
|
||||||
|
|
||||||
dstr_t *dstr_with_capacity(u64 capacity);
|
dstr_t *dstr_with_capacity(u64 capacity);
|
||||||
dstr_t *dstr_from_string(const char *str);
|
dstr_t *dstr_from_string(const char *str);
|
||||||
void update_dstr(dstr_t **dst, const char *src);
|
void dstr_update(dstr_t **dst, const char *src);
|
||||||
void delete_dstr(dstr_t **str);
|
void dstr_free(dstr_t **str);
|
||||||
void concat_dstr(dstr_t **dst, const char *src);
|
void dstr_concat(dstr_t **dst, const char *src);
|
||||||
void append_to_dstr(dstr_t **dst, char c);
|
void dstr_append(dstr_t **dst, char c);
|
||||||
void empty_dstr(dstr_t *str);
|
void dstr_resize(dstr_t **str);
|
||||||
void print_dstr(const dstr_t *str);
|
void dstr_clear(dstr_t *str);
|
||||||
|
void dstr_print(const dstr_t *str);
|
||||||
u64 dstr_length(const dstr_t *str);
|
u64 dstr_length(const dstr_t *str);
|
||||||
u64 dstr_capacity(const dstr_t *str);
|
u64 dstr_capacity(const dstr_t *str);
|
||||||
|
const char *dstr_to_cstr(const dstr_t *str);
|
||||||
|
|
||||||
#endif // !DSTRING_H
|
#endif // !DSTRING_H
|
||||||
|
@ -8,7 +8,7 @@
|
|||||||
// constantly reallocate
|
// constantly reallocate
|
||||||
#define CAPACITY_SCALAR 8
|
#define CAPACITY_SCALAR 8
|
||||||
|
|
||||||
struct dstr {
|
struct dstring {
|
||||||
u64 capacity;
|
u64 capacity;
|
||||||
u64 size;
|
u64 size;
|
||||||
char buf[];
|
char buf[];
|
||||||
@ -45,7 +45,7 @@ dstr_t *dstr_from_string(const char *str) {
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
void update_dstr(dstr_t **dst, const char *src) {
|
void dstr_update(dstr_t **dst, const char *src) {
|
||||||
if (!(*dst)) {
|
if (!(*dst)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -77,7 +77,7 @@ void update_dstr(dstr_t **dst, const char *src) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void delete_dstr(dstr_t **str) {
|
void dstr_free(dstr_t **str) {
|
||||||
if (!(*str)) {
|
if (!(*str)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -86,7 +86,7 @@ void delete_dstr(dstr_t **str) {
|
|||||||
*str = NULL;
|
*str = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
void concat_dstr(dstr_t **dst, const char *src) {
|
void dstr_concat(dstr_t **dst, const char *src) {
|
||||||
if (!(*dst)) {
|
if (!(*dst)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -105,10 +105,10 @@ void concat_dstr(dstr_t **dst, const char *src) {
|
|||||||
strncpy(str, (*dst)->buf, (*dst)->size);
|
strncpy(str, (*dst)->buf, (*dst)->size);
|
||||||
strncat(str, src, src_length);
|
strncat(str, src, src_length);
|
||||||
|
|
||||||
update_dstr(dst, str);
|
dstr_update(dst, str);
|
||||||
}
|
}
|
||||||
|
|
||||||
void append_to_dstr(dstr_t **dst, char c) {
|
void dstr_append(dstr_t **dst, char c) {
|
||||||
if (!(*dst)) {
|
if (!(*dst)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -121,10 +121,24 @@ void append_to_dstr(dstr_t **dst, char c) {
|
|||||||
strncpy(str, (*dst)->buf, (*dst)->size);
|
strncpy(str, (*dst)->buf, (*dst)->size);
|
||||||
str[(*dst)->size] = c;
|
str[(*dst)->size] = c;
|
||||||
|
|
||||||
update_dstr(dst, str);
|
dstr_update(dst, str);
|
||||||
}
|
}
|
||||||
|
|
||||||
void empty_dstr(dstr_t *str) {
|
void dstr_resize(dstr_t **str) {
|
||||||
|
u64 capacity = (*str)->size;
|
||||||
|
|
||||||
|
dstr_t *tmp = (dstr_t *)realloc(*str, sizeof(dstr_t) + capacity + 1);
|
||||||
|
|
||||||
|
if (!tmp) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
tmp->capacity = capacity;
|
||||||
|
|
||||||
|
*str = tmp;
|
||||||
|
}
|
||||||
|
|
||||||
|
void dstr_clear(dstr_t *str) {
|
||||||
if (!str || str->size == 0) {
|
if (!str || str->size == 0) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -133,7 +147,7 @@ void empty_dstr(dstr_t *str) {
|
|||||||
str->size = 0;
|
str->size = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void print_dstr(const dstr_t *str) {
|
void dstr_print(const dstr_t *str) {
|
||||||
if (!str) {
|
if (!str) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -156,3 +170,5 @@ u64 dstr_capacity(const dstr_t *str) {
|
|||||||
|
|
||||||
return str->capacity;
|
return str->capacity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const char *dstr_to_cstr(const dstr_t *str) { return str->buf; }
|
||||||
|
@ -408,7 +408,7 @@ lexer_state_t handle_array(lexer_t *lexer, char input) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
lexer_state_t handle_key(lexer_t *lexer, char input) {
|
lexer_state_t handle_key(lexer_t *lexer, char input) {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_STRING;
|
return LEXER_STATE_STRING;
|
||||||
}
|
}
|
||||||
@ -417,7 +417,7 @@ lexer_state_t handle_value(lexer_t *lexer, char input) {
|
|||||||
if (isspace(input)) {
|
if (isspace(input)) {
|
||||||
return LEXER_STATE_VALUE;
|
return LEXER_STATE_VALUE;
|
||||||
} else if (isdigit(input) && input != '0') {
|
} else if (isdigit(input) && input != '0') {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_NUMBER;
|
return LEXER_STATE_NUMBER;
|
||||||
}
|
}
|
||||||
@ -428,7 +428,7 @@ lexer_state_t handle_value(lexer_t *lexer, char input) {
|
|||||||
|
|
||||||
return LEXER_STATE_STRING;
|
return LEXER_STATE_STRING;
|
||||||
case '0':
|
case '0':
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_DECIMAL;
|
return LEXER_STATE_DECIMAL;
|
||||||
case '{':
|
case '{':
|
||||||
@ -449,14 +449,14 @@ lexer_state_t handle_value(lexer_t *lexer, char input) {
|
|||||||
lexer_state_t handle_string(lexer_t *lexer, char input) {
|
lexer_state_t handle_string(lexer_t *lexer, char input) {
|
||||||
switch (input) {
|
switch (input) {
|
||||||
case '\\':
|
case '\\':
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_ESCAPE_SEQUENCE;
|
return LEXER_STATE_ESCAPE_SEQUENCE;
|
||||||
case '"':
|
case '"':
|
||||||
return LEXER_STATE_STRING_END;
|
return LEXER_STATE_STRING_END;
|
||||||
}
|
}
|
||||||
|
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_STRING;
|
return LEXER_STATE_STRING;
|
||||||
}
|
}
|
||||||
@ -466,7 +466,7 @@ lexer_state_t handle_string_end(lexer_t *lexer, char input) {
|
|||||||
return LEXER_STATE_STRING_END;
|
return LEXER_STATE_STRING_END;
|
||||||
}
|
}
|
||||||
|
|
||||||
empty_dstr(lexer->current_string);
|
dstr_clear(lexer->current_string);
|
||||||
|
|
||||||
lexer->current = stack_pop(&(lexer->stack));
|
lexer->current = stack_pop(&(lexer->stack));
|
||||||
|
|
||||||
@ -489,7 +489,7 @@ lexer_state_t handle_string_end(lexer_t *lexer, char input) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
lexer_state_t handle_escape_sequence(lexer_t *lexer, char input) {
|
lexer_state_t handle_escape_sequence(lexer_t *lexer, char input) {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
switch (input) {
|
switch (input) {
|
||||||
case '"':
|
case '"':
|
||||||
@ -510,7 +510,7 @@ lexer_state_t handle_escape_sequence(lexer_t *lexer, char input) {
|
|||||||
|
|
||||||
lexer_state_t handle_unicode_sequence(lexer_t *lexer, char input) {
|
lexer_state_t handle_unicode_sequence(lexer_t *lexer, char input) {
|
||||||
append_to_lex_str(&(lexer->codepoint), input);
|
append_to_lex_str(&(lexer->codepoint), input);
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
if (!ishex(input)) {
|
if (!ishex(input)) {
|
||||||
clear_lex_str(&(lexer->codepoint));
|
clear_lex_str(&(lexer->codepoint));
|
||||||
@ -526,7 +526,7 @@ lexer_state_t handle_unicode_sequence(lexer_t *lexer, char input) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
lexer_state_t handle_decimal(lexer_t *lexer, char input) {
|
lexer_state_t handle_decimal(lexer_t *lexer, char input) {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
if (input == '.') {
|
if (input == '.') {
|
||||||
return LEXER_STATE_FRACTION;
|
return LEXER_STATE_FRACTION;
|
||||||
@ -537,19 +537,19 @@ lexer_state_t handle_decimal(lexer_t *lexer, char input) {
|
|||||||
|
|
||||||
lexer_state_t handle_number(lexer_t *lexer, char input) {
|
lexer_state_t handle_number(lexer_t *lexer, char input) {
|
||||||
if (isdigit(input)) {
|
if (isdigit(input)) {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_NUMBER;
|
return LEXER_STATE_NUMBER;
|
||||||
} else if (input == '.') {
|
} else if (input == '.') {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_FRACTION;
|
return LEXER_STATE_FRACTION;
|
||||||
} else if (input == '}' || input == ']') {
|
} else if (input == '}' || input == ']') {
|
||||||
empty_dstr(lexer->current_string);
|
dstr_clear(lexer->current_string);
|
||||||
|
|
||||||
return handle_collection_end(lexer, input);
|
return handle_collection_end(lexer, input);
|
||||||
} else if (input == ',') {
|
} else if (input == ',') {
|
||||||
empty_dstr(lexer->current_string);
|
dstr_clear(lexer->current_string);
|
||||||
|
|
||||||
return lexer->stack.stack[lexer->stack.size - 1];
|
return lexer->stack.stack[lexer->stack.size - 1];
|
||||||
} else if (isspace(input)) {
|
} else if (isspace(input)) {
|
||||||
@ -561,19 +561,19 @@ lexer_state_t handle_number(lexer_t *lexer, char input) {
|
|||||||
|
|
||||||
lexer_state_t handle_fraction(lexer_t *lexer, char input) {
|
lexer_state_t handle_fraction(lexer_t *lexer, char input) {
|
||||||
if (isdigit(input)) {
|
if (isdigit(input)) {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_FRACTION;
|
return LEXER_STATE_FRACTION;
|
||||||
} else if (input == '}' || input == ']') {
|
} else if (input == '}' || input == ']') {
|
||||||
empty_dstr(lexer->current_string);
|
dstr_clear(lexer->current_string);
|
||||||
|
|
||||||
return handle_collection_end(lexer, input);
|
return handle_collection_end(lexer, input);
|
||||||
} else if (input == 'e' || input == 'E') {
|
} else if (input == 'e' || input == 'E') {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_EXPONENT;
|
return LEXER_STATE_EXPONENT;
|
||||||
} else if (input == ',') {
|
} else if (input == ',') {
|
||||||
empty_dstr(lexer->current_string);
|
dstr_clear(lexer->current_string);
|
||||||
|
|
||||||
return lexer->stack.stack[lexer->stack.size - 1];
|
return lexer->stack.stack[lexer->stack.size - 1];
|
||||||
} else if (isspace(input)) {
|
} else if (isspace(input)) {
|
||||||
@ -584,7 +584,7 @@ lexer_state_t handle_fraction(lexer_t *lexer, char input) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
lexer_state_t handle_exponent(lexer_t *lexer, char input) {
|
lexer_state_t handle_exponent(lexer_t *lexer, char input) {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
if (isdigit(input)) {
|
if (isdigit(input)) {
|
||||||
return LEXER_STATE_POWER;
|
return LEXER_STATE_POWER;
|
||||||
@ -596,7 +596,7 @@ lexer_state_t handle_exponent(lexer_t *lexer, char input) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
lexer_state_t handle_exp_sign(lexer_t *lexer, char input) {
|
lexer_state_t handle_exp_sign(lexer_t *lexer, char input) {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
if (isdigit(input)) {
|
if (isdigit(input)) {
|
||||||
return LEXER_STATE_POWER;
|
return LEXER_STATE_POWER;
|
||||||
@ -607,15 +607,15 @@ lexer_state_t handle_exp_sign(lexer_t *lexer, char input) {
|
|||||||
|
|
||||||
lexer_state_t handle_power(lexer_t *lexer, char input) {
|
lexer_state_t handle_power(lexer_t *lexer, char input) {
|
||||||
if (isdigit(input)) {
|
if (isdigit(input)) {
|
||||||
append_to_dstr(&(lexer->current_string), input);
|
dstr_append(&(lexer->current_string), input);
|
||||||
|
|
||||||
return LEXER_STATE_POWER;
|
return LEXER_STATE_POWER;
|
||||||
} else if (input == '}' || input == ']') {
|
} else if (input == '}' || input == ']') {
|
||||||
empty_dstr(lexer->current_string);
|
dstr_clear(lexer->current_string);
|
||||||
|
|
||||||
return handle_collection_end(lexer, input);
|
return handle_collection_end(lexer, input);
|
||||||
} else if (input == ',') {
|
} else if (input == ',') {
|
||||||
empty_dstr(lexer->current_string);
|
dstr_clear(lexer->current_string);
|
||||||
|
|
||||||
return lexer->stack.stack[lexer->stack.size - 1];
|
return lexer->stack.stack[lexer->stack.size - 1];
|
||||||
} else if (isspace(input)) {
|
} else if (isspace(input)) {
|
||||||
@ -626,7 +626,7 @@ lexer_state_t handle_power(lexer_t *lexer, char input) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
lexer_state_t handle_number_end(lexer_t *lexer, char input) {
|
lexer_state_t handle_number_end(lexer_t *lexer, char input) {
|
||||||
empty_dstr(lexer->current_string);
|
dstr_clear(lexer->current_string);
|
||||||
|
|
||||||
if (isspace(input)) {
|
if (isspace(input)) {
|
||||||
return LEXER_STATE_NUMBER_END;
|
return LEXER_STATE_NUMBER_END;
|
||||||
|
Loading…
Reference in New Issue
Block a user