struct rsapub *st=sst;
if (!st) return;
- mpz_clear(&st->e);
- mpz_clear(&st->n);
+ RSAPUB_BNS(RSAPUB_CLEAR_ST_BN)
rsacommon_dispose(&st->common);
free(st);
}
#define RSAPUB_LOADCORE_DEFBN(ix,en,what) \
const char *en##s, struct cloc en##_loc,
-#define LDPUBFATAL(enloc,...) \
- cfgfatal(enloc, "rsa-public", __VA_ARGS__)
+#define LDPUBFATAL(lc,...) ({ \
+ load_err(l,(lc),0,0,__VA_ARGS__); \
+ goto error_out; \
+ })
static struct rsapub *rsa_loadpub_core(RSAPUB_BNS(RSAPUB_LOADCORE_DEFBN)
- struct cloc overall_loc)
+ struct load_ctx *l)
{
struct rsapub *st;
st->ops.check=rsa_sig_check;
st->ops.hash=0;
st->ops.dispose=rsapub_dispose;
- st->loc=overall_loc;
+ st->loc=l->loc;
RSAPUB_BNS(RSAPUB_INIT_ST_BN)
#define RSAPUB_LOADCORE_GETBN(ix,en,what) \
if (mpz_init_set_str(&st->en,en##s,10)!=0) { \
- LDPUBFATAL(en##_loc, what " \"%s\" is not a " \
+ LDPUBFATAL(&en##_loc, what " \"%s\" is not a " \
"decimal number string\n",en##s); \
} \
if (mpz_sizeinbase(&st->en, 256) > RSA_MAX_MODBYTES) { \
- LDPUBFATAL(en##_loc, "implausibly large " what "\n"); \
+ LDPUBFATAL(&en##_loc, "implausibly large " what "\n"); \
}
RSAPUB_BNS(RSAPUB_LOADCORE_GETBN)
static list_t *rsapub_apply(closure_t *self, struct cloc loc, dict_t *context,
list_t *args)
{
+ struct load_ctx l[1];
+ l->verror=verror_cfgfatal;
+ l->postreadcheck=0;
+ l->what="rsa-public";
+ l->loc=loc;
#define RSAPUB_APPLY_GETBN(ix,en,what) \
item_t *en##i; \
RSAPUB_BNS(RSAPUB_APPLY_GETBN)
struct rsapub *st=rsa_loadpub_core(RSAPUB_BNS(RSAPUB_LOADCORE_PASSBN)
- loc);
+ l);
return new_closure(&st->cl);
}