| /* |
| * ***************************************************************************** |
| * |
| * Copyright (c) 2018-2019 Gavin D. Howard and contributors. |
| * |
| * All rights reserved. |
| * |
| * Redistribution and use in source and binary forms, with or without |
| * modification, are permitted provided that the following conditions are met: |
| * |
| * * Redistributions of source code must retain the above copyright notice, this |
| * list of conditions and the following disclaimer. |
| * |
| * * Redistributions in binary form must reproduce the above copyright notice, |
| * this list of conditions and the following disclaimer in the documentation |
| * and/or other materials provided with the distribution. |
| * |
| * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
| * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE |
| * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR |
| * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF |
| * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN |
| * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) |
| * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE |
| * POSSIBILITY OF SUCH DAMAGE. |
| * |
| * ***************************************************************************** |
| * |
| * Definitions for bc's parser. |
| * |
| */ |
| |
| #ifndef BC_PARSE_H |
| #define BC_PARSE_H |
| |
| #include <stdbool.h> |
| #include <stdint.h> |
| |
| #include <status.h> |
| #include <vector.h> |
| #include <lex.h> |
| #include <lang.h> |
| |
| #define BC_PARSE_STREND ((uchar) UCHAR_MAX) |
| |
| #define BC_PARSE_REL (1<<0) |
| #define BC_PARSE_PRINT (1<<1) |
| #define BC_PARSE_NOCALL (1<<2) |
| #define BC_PARSE_NOREAD (1<<3) |
| #define BC_PARSE_ARRAY (1<<4) |
| |
| #define bc_parse_push(p, i) (bc_vec_pushByte(&(p)->func->code, (uchar) (i))) |
| #define bc_parse_string(p)(bc_parse_addId((p), (p)->l.str.v, BC_INST_STR)) |
| |
| #define bc_parse_err(p, e) (bc_vm_error((e), (p)->l.line)) |
| #define bc_parse_verr(p, e, ...) (bc_vm_error((e), (p)->l.line, __VA_ARGS__)) |
| |
| typedef struct BcParseNext { |
| uchar len; |
| uchar tokens[4]; |
| } BcParseNext; |
| |
| #define BC_PARSE_NEXT_TOKENS(...) .tokens = { __VA_ARGS__ } |
| #define BC_PARSE_NEXT(a, ...) \ |
| { .len = (uchar) (a), BC_PARSE_NEXT_TOKENS(__VA_ARGS__) } |
| |
| struct BcParse; |
| struct BcProgram; |
| |
| typedef BcStatus (*BcParseParse)(struct BcParse*); |
| typedef BcStatus (*BcParseExpr)(struct BcParse*, uint8_t); |
| |
| typedef struct BcParse { |
| |
| BcLex l; |
| |
| #if BC_ENABLED |
| BcVec flags; |
| BcVec exits; |
| BcVec conds; |
| BcVec ops; |
| #endif // BC_ENABLED |
| |
| struct BcProgram *prog; |
| BcFunc *func; |
| size_t fidx; |
| |
| bool auto_part; |
| |
| } BcParse; |
| |
| void bc_parse_init(BcParse *p, struct BcProgram *prog, size_t func); |
| void bc_parse_free(BcParse *p); |
| BcStatus bc_parse_reset(BcParse *p, BcStatus s); |
| |
| void bc_parse_addId(BcParse *p, const char *string, uchar inst); |
| void bc_parse_number(BcParse *p); |
| void bc_parse_updateFunc(BcParse *p, size_t fidx); |
| void bc_parse_pushName(BcParse* p, char *name); |
| void bc_parse_pushIndex(BcParse* p, size_t idx); |
| BcStatus bc_parse_text(BcParse *p, const char *text); |
| |
| #endif // BC_PARSE_H |