Updated scanner to be a bit more normed, didn't yet do the big ass functions
This commit is contained in:
parent
7e1e51e90b
commit
00546417ff
6 changed files with 108 additions and 94 deletions
|
|
@ -16,12 +16,14 @@
|
|||
#include "parser/inner/scanner.h"
|
||||
#include "parser/parser.h"
|
||||
|
||||
t_error serialize_heredocs(t_scanner *scanner, t_u8 *buffer, t_u32 *size, t_usize i)
|
||||
t_error serialize_heredocs(t_scanner *scanner, t_u8 *buffer, t_u32 *size,
|
||||
t_usize i)
|
||||
{
|
||||
t_heredoc *heredoc;
|
||||
t_heredoc *heredoc;
|
||||
|
||||
heredoc = vec_heredoc_get(&scanner->heredocs, i);
|
||||
if (heredoc->delimiter.len + 1 + sizeof(t_usize) + (*size) >= TREE_SITTER_SERIALIZATION_BUFFER_SIZE)
|
||||
if (heredoc->delimiter.len + 1 + sizeof(t_usize)
|
||||
+ (*size) >= TREE_SITTER_SERIALIZATION_BUFFER_SIZE)
|
||||
return (ERROR);
|
||||
buffer[(*size)++] = (char)heredoc->is_raw;
|
||||
buffer[(*size)++] = (char)heredoc->started;
|
||||
|
|
@ -31,17 +33,19 @@ t_error serialize_heredocs(t_scanner *scanner, t_u8 *buffer, t_u32 *size, t_usiz
|
|||
size += sizeof(t_usize);
|
||||
if (heredoc->delimiter.len > 0)
|
||||
{
|
||||
mem_copy(&buffer[(*size)], heredoc->delimiter.buf, heredoc->delimiter.len);
|
||||
mem_copy(&buffer[(*size)], heredoc->delimiter.buf,
|
||||
heredoc->delimiter.len);
|
||||
(*size) += heredoc->delimiter.len;
|
||||
}
|
||||
heredoc->delimiter.len--;
|
||||
return (NO_ERROR);
|
||||
}
|
||||
|
||||
t_u32 tree_sitter_sh_external_scanner_serialize(t_scanner *scanner, t_u8 *buffer)
|
||||
t_u32 tree_sitter_sh_external_scanner_serialize(t_scanner *scanner,
|
||||
t_u8 *buffer)
|
||||
{
|
||||
t_u32 size;
|
||||
t_usize i;
|
||||
t_usize i;
|
||||
|
||||
size = 0;
|
||||
buffer[size++] = (char)scanner->last_glob_paren_depth;
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue