Don't try to recall() primitive results

This commit is contained in:
Meredith L. Patterson 2015-10-04 15:32:32 +02:00
parent 9235bf793c
commit 99ca500d2b

View file

@ -181,7 +181,10 @@ HParseResult* lr_answer(HParserCacheKey *k, HParseState *state, HLeftRec *growab
HParseResult* h_do_parse(const HParser* parser, HParseState *state) {
HParserCacheKey *key = a_new(HParserCacheKey, 1);
key->input_pos = state->input_stream; key->parser = parser;
HParserCacheValue *m = recall(key, state);
HParserCacheValue *m = NULL;
if (parser->vtable->higher) {
m = recall(key, state);
}
// check to see if there is already a result for this object...
if (!m) {
// It doesn't exist, so create a dummy result to cache