summaryrefslogtreecommitdiff
path: root/src/runtime/c/pgf/parseval.c
diff options
context:
space:
mode:
authorkr.angelov <kr.angelov@gmail.com>2013-09-27 15:09:48 +0000
committerkr.angelov <kr.angelov@gmail.com>2013-09-27 15:09:48 +0000
commit426bc49a52b4efa0ef0129d713842d8c9abdf0ff (patch)
treed9f5985559de0347448e77ff26ce5a2d3ee2f245 /src/runtime/c/pgf/parseval.c
parentb138899512d9aea248160eb17df3007e55dd03da (diff)
a major refactoring in the C and the Haskell runtimes. Note incompatible change in the PGF format!!!
The following are the outcomes: - Predef.nonExist is fully supported by both the Haskell and the C runtimes - Predef.BIND is now an internal compiler defined token. For now it behaves just as usual for the Haskell runtime, i.e. it generates &+. However, the special treatment will let us to handle it properly in the C runtime. - This required a major change in the PGF format since both nonExist and BIND may appear inside 'pre' and this was not supported before.
Diffstat (limited to 'src/runtime/c/pgf/parseval.c')
-rw-r--r--src/runtime/c/pgf/parseval.c31
1 files changed, 13 insertions, 18 deletions
diff --git a/src/runtime/c/pgf/parseval.c b/src/runtime/c/pgf/parseval.c
index 84d93b346..8b38d252d 100644
--- a/src/runtime/c/pgf/parseval.c
+++ b/src/runtime/c/pgf/parseval.c
@@ -19,19 +19,14 @@ typedef struct {
} PgfMetricsLznState;
static void
-pgf_metrics_lzn_symbol_tokens(PgfLinFuncs** funcs, PgfTokens* toks)
+pgf_metrics_lzn_symbol_token(PgfLinFuncs** funcs, PgfToken tok)
{
PgfMetricsLznState* state = gu_container(funcs, PgfMetricsLznState, funcs);
-
- size_t len = gu_seq_length(toks);
- for (size_t i = 0; i < len; i++) {
- PgfToken tok = gu_seq_get(toks, PgfToken, i);
-
- if (state->ps != NULL)
- state->ps = pgf_parser_next_state(state->ps, tok);
+
+ if (state->ps != NULL)
+ state->ps = pgf_parser_next_state(state->ps, tok);
- state->pos++;
- }
+ state->pos++;
}
static void
@@ -128,17 +123,17 @@ pgf_metrics_lzn_end_phrase2(PgfLinFuncs** funcs, PgfCId cat, int fid, int lin_id
}
static PgfLinFuncs pgf_metrics_lin_funcs1 = {
- .symbol_tokens = pgf_metrics_lzn_symbol_tokens,
- .expr_literal = pgf_metrics_lzn_expr_literal,
- .begin_phrase = pgf_metrics_lzn_begin_phrase,
- .end_phrase = pgf_metrics_lzn_end_phrase1
+ .symbol_token = pgf_metrics_lzn_symbol_token,
+ .expr_literal = pgf_metrics_lzn_expr_literal,
+ .begin_phrase = pgf_metrics_lzn_begin_phrase,
+ .end_phrase = pgf_metrics_lzn_end_phrase1
};
static PgfLinFuncs pgf_metrics_lin_funcs2 = {
- .symbol_tokens = pgf_metrics_lzn_symbol_tokens,
- .expr_literal = pgf_metrics_lzn_expr_literal,
- .begin_phrase = pgf_metrics_lzn_begin_phrase,
- .end_phrase = pgf_metrics_lzn_end_phrase2
+ .symbol_token = pgf_metrics_lzn_symbol_token,
+ .expr_literal = pgf_metrics_lzn_expr_literal,
+ .begin_phrase = pgf_metrics_lzn_begin_phrase,
+ .end_phrase = pgf_metrics_lzn_end_phrase2
};
bool