summaryrefslogtreecommitdiffhomepage
path: root/lexer.c
diff options
context:
space:
mode:
Diffstat (limited to 'lexer.c')
-rw-r--r--lexer.c92
1 files changed, 46 insertions, 46 deletions
diff --git a/lexer.c b/lexer.c
index 2ba2017..8e6378a 100644
--- a/lexer.c
+++ b/lexer.c
@@ -44,7 +44,7 @@ struct token {
char pat[4];
} u;
unsigned plen;
- uc_token *(*parse)(uc_lexer *);
+ uc_token_t *(*parse)(uc_lexer_t *);
};
#define dec(o) \
@@ -54,11 +54,11 @@ struct token {
(((x) >= 'a') ? (10 + (x) - 'a') : \
(((x) >= 'A') ? (10 + (x) - 'A') : dec(x)))
-static uc_token *parse_comment(uc_lexer *);
-static uc_token *parse_string(uc_lexer *);
-static uc_token *parse_regexp(uc_lexer *);
-static uc_token *parse_number(uc_lexer *);
-static uc_token *parse_label(uc_lexer *);
+static uc_token_t *parse_comment(uc_lexer_t *);
+static uc_token_t *parse_string(uc_lexer_t *);
+static uc_token_t *parse_regexp(uc_lexer_t *);
+static uc_token_t *parse_number(uc_lexer_t *);
+static uc_token_t *parse_label(uc_lexer_t *);
static const struct token tokens[] = {
{ TK_ASLEFT, { .pat = "<<=" }, 3, NULL },
@@ -220,8 +220,8 @@ utf8enc(char **out, int *rem, int code)
/* length of the longest token in our lookup table */
#define UC_LEX_MAX_TOKEN_LEN 3
-static uc_token *
-emit_op(uc_lexer *lex, uint32_t pos, int type, uc_value_t *uv)
+static uc_token_t *
+emit_op(uc_lexer_t *lex, uint32_t pos, int type, uc_value_t *uv)
{
lex->curr.type = type;
lex->curr.uv = uv;
@@ -230,7 +230,7 @@ emit_op(uc_lexer *lex, uint32_t pos, int type, uc_value_t *uv)
return &lex->curr;
}
-static void lookbehind_append(uc_lexer *lex, const char *data, size_t len)
+static void lookbehind_append(uc_lexer_t *lex, const char *data, size_t len)
{
if (len) {
lex->lookbehind = xrealloc(lex->lookbehind, lex->lookbehindlen + len);
@@ -239,15 +239,15 @@ static void lookbehind_append(uc_lexer *lex, const char *data, size_t len)
}
}
-static void lookbehind_reset(uc_lexer *lex) {
+static void lookbehind_reset(uc_lexer_t *lex) {
free(lex->lookbehind);
lex->lookbehind = NULL;
lex->lookbehindlen = 0;
}
-static uc_token *
-lookbehind_to_text(uc_lexer *lex, uint32_t pos, int type, const char *strip_trailing_chars) {
- uc_token *rv = NULL;
+static uc_token_t *
+lookbehind_to_text(uc_lexer_t *lex, uint32_t pos, int type, const char *strip_trailing_chars) {
+ uc_token_t *rv = NULL;
if (lex->lookbehind) {
if (strip_trailing_chars) {
@@ -264,12 +264,12 @@ lookbehind_to_text(uc_lexer *lex, uint32_t pos, int type, const char *strip_trai
}
static inline size_t
-buf_remaining(uc_lexer *lex) {
+buf_remaining(uc_lexer_t *lex) {
return (lex->bufend - lex->bufstart);
}
static inline bool
-_buf_startswith(uc_lexer *lex, const char *str, size_t len) {
+_buf_startswith(uc_lexer_t *lex, const char *str, size_t len) {
return (buf_remaining(lex) >= len && !strncmp(lex->bufstart, str, len));
}
@@ -290,18 +290,18 @@ _buf_startswith(uc_lexer *lex, const char *str, size_t len) {
*/
static void
-next_lineinfo(uc_lexer *lex)
+next_lineinfo(uc_lexer_t *lex)
{
- uc_lineinfo *lines = &lex->source->lineinfo;
+ uc_lineinfo_t *lines = &lex->source->lineinfo;
uc_vector_grow(lines);
lines->entries[lines->count++] = 0x80;
}
static void
-update_lineinfo(uc_lexer *lex, size_t off)
+update_lineinfo(uc_lexer_t *lex, size_t off)
{
- uc_lineinfo *lines = &lex->source->lineinfo;
+ uc_lineinfo_t *lines = &lex->source->lineinfo;
uint8_t *entry, n;
entry = uc_vector_last(lines);
@@ -325,7 +325,7 @@ update_lineinfo(uc_lexer *lex, size_t off)
}
static void
-buf_consume(uc_lexer *lex, size_t len) {
+buf_consume(uc_lexer_t *lex, size_t len) {
size_t i, linelen;
if (!lex->source->lineinfo.count)
@@ -350,8 +350,8 @@ buf_consume(uc_lexer *lex, size_t len) {
lex->source->off += len;
}
-static uc_token *
-parse_comment(uc_lexer *lex)
+static uc_token_t *
+parse_comment(uc_lexer_t *lex)
{
const struct token *tok = lex->tok;
const char *ptr, *end;
@@ -387,7 +387,7 @@ parse_comment(uc_lexer *lex)
}
static void
-append_utf8(uc_lexer *lex, int code) {
+append_utf8(uc_lexer_t *lex, int code) {
char ustr[8], *up;
int rem;
@@ -398,13 +398,13 @@ append_utf8(uc_lexer *lex, int code) {
lookbehind_append(lex, ustr, up - ustr);
}
-static uc_token *
-parse_string(uc_lexer *lex)
+static uc_token_t *
+parse_string(uc_lexer_t *lex)
{
const struct token *tok = lex->tok;
char q = tok->u.pat[0];
char *ptr, *c;
- uc_token *rv;
+ uc_token_t *rv;
int code;
if (!buf_remaining(lex))
@@ -626,11 +626,11 @@ enum {
UC_LEX_PARSE_REGEX_FLAGS
};
-static uc_token *
-parse_regexp(uc_lexer *lex)
+static uc_token_t *
+parse_regexp(uc_lexer_t *lex)
{
bool is_reg_global = false, is_reg_icase = false, is_reg_newline = false;
- uc_token *rv;
+ uc_token_t *rv;
size_t len;
char *s;
@@ -663,7 +663,7 @@ parse_regexp(uc_lexer *lex)
break;
case UC_LEX_PARSE_REGEX_FLAGS:
- rv = (uc_token *)lex->lookbehind;
+ rv = (uc_token_t *)lex->lookbehind;
while (lex->bufstart < lex->bufend || lex->eof) {
switch (lex->eof ? EOF : lex->bufstart[0]) {
@@ -717,8 +717,8 @@ parse_regexp(uc_lexer *lex)
* -UC_ERROR_OVERLONG_STRING Label too long
*/
-static uc_token *
-parse_label(uc_lexer *lex)
+static uc_token_t *
+parse_label(uc_lexer_t *lex)
{
const struct token *tok = lex->tok;
const struct keyword *word;
@@ -763,7 +763,7 @@ parse_label(uc_lexer *lex)
*/
static inline bool
-is_numeric_char(uc_lexer *lex, char c)
+is_numeric_char(uc_lexer_t *lex, char c)
{
char prev = lex->lookbehindlen ? lex->lookbehind[lex->lookbehindlen-1] : 0;
@@ -773,11 +773,11 @@ is_numeric_char(uc_lexer *lex, char c)
return prev ? (isxdigit(c) || c == 'x' || c == 'X' || c == '.') : (isdigit(c) || c == '.');
}
-static uc_token *
-parse_number(uc_lexer *lex)
+static uc_token_t *
+parse_number(uc_lexer_t *lex)
{
const struct token *tok = lex->tok;
- uc_token *rv = NULL;
+ uc_token_t *rv = NULL;
long long int n;
char *ptr, *e;
double d;
@@ -826,15 +826,15 @@ parse_number(uc_lexer *lex)
return NULL;
}
-static uc_token *
-lex_step(uc_lexer *lex, FILE *fp)
+static uc_token_t *
+lex_step(uc_lexer_t *lex, FILE *fp)
{
uint32_t masks[] = { 0, le32toh(0x000000ff), le32toh(0x0000ffff), le32toh(0x00ffffff), le32toh(0xffffffff) };
union { uint32_t n; char str[4]; } search;
const struct token *tok;
size_t rlen, rem;
char *ptr, c;
- uc_token *rv;
+ uc_token_t *rv;
size_t i;
/* only less than UC_LEX_MAX_TOKEN_LEN unread buffer chars remaining,
@@ -1132,9 +1132,9 @@ lex_step(uc_lexer *lex, FILE *fp)
}
static void
-uc_lexer_skip_shebang(uc_lexer *lex)
+uc_lexer_skip_shebang(uc_lexer_t *lex)
{
- uc_source *source = lex->source;
+ uc_source_t *source = lex->source;
FILE *fp = source->fp;
int c1, c2;
@@ -1164,7 +1164,7 @@ uc_lexer_skip_shebang(uc_lexer *lex)
}
void
-uc_lexer_init(uc_lexer *lex, uc_parse_config *config, uc_source *source)
+uc_lexer_init(uc_lexer_t *lex, uc_parse_config_t *config, uc_source_t *source)
{
lex->state = UC_LEX_IDENTIFY_BLOCK;
@@ -1205,7 +1205,7 @@ uc_lexer_init(uc_lexer *lex, uc_parse_config *config, uc_source *source)
}
void
-uc_lexer_free(uc_lexer *lex)
+uc_lexer_free(uc_lexer_t *lex)
{
uc_source_put(lex->source);
@@ -1213,10 +1213,10 @@ uc_lexer_free(uc_lexer *lex)
free(lex->buf);
}
-uc_token *
-uc_lexer_next_token(uc_lexer *lex)
+uc_token_t *
+uc_lexer_next_token(uc_lexer_t *lex)
{
- uc_token *rv = NULL;
+ uc_token_t *rv = NULL;
while (lex->state != UC_LEX_EOF) {
rv = lex_step(lex, lex->source->fp);