Skip to content
Snippets Groups Projects
ch.c 1012 B
Newer Older
Dan Hirsch's avatar
Dan Hirsch committed
#include "parser_internal.h"

static HParseResult* parse_ch(void* env, HParseState *state) {
  uint8_t c = (uint8_t)(unsigned long)(env);
Dan Hirsch's avatar
Dan Hirsch committed
  uint8_t r = (uint8_t)h_read_bits(&state->input_stream, 8, false);
  if (c == r) {
    HParsedToken *tok = a_new(HParsedToken, 1);    
    tok->token_type = TT_UINT; tok->uint = r;
    return make_result(state, tok);
  } else {
    return NULL;
  }
}

static bool ch_ctrvm(HRVMProg *prog, void* env) {
  uint8_t c = (uint8_t)(unsigned long)(env);
  h_rvm_insert_insn(prog, RVM_MATCH, c & c << 8);
  h_rvm_insert_insn(prog, RVM_STEP, 0);
  return true;
}

Dan Hirsch's avatar
Dan Hirsch committed
static const HParserVtable ch_vt = {
  .parse = parse_ch,
  .isValidRegular = h_true,
  .isValidCF = h_true,
Dan Hirsch's avatar
Dan Hirsch committed
};

const HParser* h_ch(const uint8_t c) {
  return h_ch__m(&system_allocator, c);
}
const HParser* h_ch__m(HAllocator* mm__, const uint8_t c) {  
  HParser *ret = h_new(HParser, 1);
Dan Hirsch's avatar
Dan Hirsch committed
  ret->vtable = &ch_vt;
  ret->env = (void*)(unsigned long)(c);
Dan Hirsch's avatar
Dan Hirsch committed
  return (const HParser*)ret;
}