khan: always open socket, make %fyrd conditional

Inlines the server initialization in _khan_io_talk. Adds a van_o loobean
that differentiates between having the vane and missing the vane; van_o
is c3n if the %born event failed. In that case, we don't bother
forwarding %fyrd requests at all, but %peek requests still go through.
This commit is contained in:
Jōshin 2021-12-25 08:37:47 +00:00
parent 969115d5c1
commit 845d325dd7
No known key found for this signature in database
GPG Key ID: A8BE5A9A521639D0

View File

@ -99,6 +99,7 @@ u3_khan_io_init(u3_pier* pir_u)
c3_l sev_l; // instance number c3_l sev_l; // instance number
struct _u3_shan* san_u; // server reference struct _u3_shan* san_u; // server reference
u3_cue_xeno* sil_u; // cue handle u3_cue_xeno* sil_u; // cue handle
c3_o van_o; // vane present?
} u3_khan; } u3_khan;
static const c3_c URB_SOCK_PATH[] = ".urb/khan.sock"; static const c3_c URB_SOCK_PATH[] = ".urb/khan.sock";
@ -380,17 +381,24 @@ _khan_moor_poke(void* ptr_v, c3_d len_d, c3_y* byt_y)
} }
case c3__fyrd: { case c3__fyrd: {
u3l_log("khan: fyrd %" PRIu32 "\n", rid);
if ( c3n == kan_u->van_o ) {
_khan_send_noun(
can_u, u3nt(rid, c3__fail,
u3i_string("vane not present")));
}
else {
u3_noun wir = u3nc(c3__khan, u3_noun wir = u3nc(c3__khan,
u3nq(u3dc("scot", c3__uv, kan_u->sev_l), u3nq(u3dc("scot", c3__uv, kan_u->sev_l),
u3dc("scot", c3__ud, can_u->coq_l), u3dc("scot", c3__ud, can_u->coq_l),
u3dc("scot", c3__ud, rid), u3dc("scot", c3__ud, rid),
u3_nul)); u3_nul));
u3l_log("khan: fyrd %" PRIu32 "\n", rid);
u3_auto_peer( u3_auto_peer(
u3_auto_plan(&kan_u->car_u, u3_auto_plan(&kan_u->car_u,
u3_ovum_init(0, c3__k, wir, u3k(can))), u3_ovum_init(0, c3__k, wir, u3k(can))),
0, 0, _khan_poke_bail); 0, 0, _khan_poke_bail);
}
break; break;
} }
@ -541,19 +549,10 @@ _khan_sock_err_chdir:
static void static void
_khan_born_news(u3_ovum* egg_u, u3_ovum_news new_e) _khan_born_news(u3_ovum* egg_u, u3_ovum_news new_e)
{ {
u3_auto* car_u = egg_u->car_u; u3_khan* kan_u = (u3_khan*)egg_u->car_u;
u3_khan* kan_u = (u3_khan*)car_u;
u3_shan* san_u;
if ( u3_ovum_done == new_e ) { if ( u3_ovum_done == new_e ) {
c3_assert(!kan_u->san_u); kan_u->van_o = c3y;
san_u = c3_calloc(sizeof(*san_u));
san_u->nex_l = 1;
san_u->kan_u = kan_u;
kan_u->san_u = san_u;
_khan_sock_init(san_u);
car_u->liv_o = c3y;
u3l_log("khan: live on %s/%s\n", u3_Host.dir_c, URB_SOCK_PATH);
} }
} }
@ -562,10 +561,7 @@ _khan_born_news(u3_ovum* egg_u, u3_ovum_news new_e)
static void static void
_khan_born_bail(u3_ovum* egg_u, u3_noun lud) _khan_born_bail(u3_ovum* egg_u, u3_noun lud)
{ {
u3l_log("khan: %%born failure; socket not opened\n"); u3l_log("khan: %%born failure; %%fyrd not supported\n");
// XX: still say we're "live" so event processing can start.
//
egg_u->car_u->liv_o = c3y;
} }
/* _khan_io_talk(): notify %khan that we're live /* _khan_io_talk(): notify %khan that we're live
@ -574,6 +570,7 @@ static void
_khan_io_talk(u3_auto* car_u) _khan_io_talk(u3_auto* car_u)
{ {
u3_khan* kan_u = (u3_khan*)car_u; u3_khan* kan_u = (u3_khan*)car_u;
u3_shan* san_u;
u3_noun wir = u3nt(c3__khan, u3_noun wir = u3nt(c3__khan,
u3dc("scot", c3__uv, kan_u->sev_l), u3dc("scot", c3__uv, kan_u->sev_l),
u3_nul); u3_nul);
@ -584,6 +581,17 @@ _khan_io_talk(u3_auto* car_u)
0, 0,
_khan_born_news, _khan_born_news,
_khan_born_bail); _khan_born_bail);
// initialize server, opening socket.
//
c3_assert(!kan_u->san_u);
san_u = c3_calloc(sizeof(*san_u));
san_u->nex_l = 1;
san_u->kan_u = kan_u;
kan_u->san_u = san_u;
_khan_sock_init(san_u);
car_u->liv_o = c3y;
u3l_log("khan: live on %s/%s\n", u3_Host.dir_c, URB_SOCK_PATH);
} }
/* _khan_ef_handle(): handle result. /* _khan_ef_handle(): handle result.
@ -685,6 +693,7 @@ u3_khan_io_init(u3_pier* pir_u)
u3_auto* car_u = &kan_u->car_u; u3_auto* car_u = &kan_u->car_u;
kan_u->sil_u = u3s_cue_xeno_init(); kan_u->sil_u = u3s_cue_xeno_init();
kan_u->van_o = c3n;
car_u->nam_m = c3__khan; car_u->nam_m = c3__khan;
car_u->liv_o = c3n; car_u->liv_o = c3n;
car_u->io.talk_f = _khan_io_talk; car_u->io.talk_f = _khan_io_talk;