mirror of
https://github.com/urbit/shrub.git
synced 2024-12-23 10:52:12 +03:00
119 lines
2.3 KiB
C
119 lines
2.3 KiB
C
/* j/6/core.c
|
|
**
|
|
*/
|
|
#include "all.h"
|
|
|
|
|
|
/* functions
|
|
*/
|
|
u3_noun
|
|
u3qf_core(u3_noun pac,
|
|
u3_noun con)
|
|
{
|
|
if ( (c3__void == pac) ) {
|
|
return c3__void;
|
|
} else {
|
|
{
|
|
u3_noun p_con, q_con, r_con, hr_con, tr_con;
|
|
|
|
u3r_trel(con, &p_con, &q_con, &r_con);
|
|
u3r_cell(r_con, &hr_con, &tr_con);
|
|
if ( (c3y == u3du(hr_con)) &&
|
|
(u3_nul == u3h(hr_con)) &&
|
|
(u3_nul == u3t(hr_con)) )
|
|
{
|
|
fprintf(stderr, "old core\r\n");
|
|
abort();
|
|
}
|
|
}
|
|
return u3nt(c3__core, u3k(pac), u3k(con));
|
|
}
|
|
}
|
|
u3_noun
|
|
u3wf_core(u3_noun cor)
|
|
{
|
|
u3_noun pac, con;
|
|
|
|
if ( c3n == u3r_mean(cor, u3x_sam_2, &pac, u3x_sam_3, &con, 0) ) {
|
|
return u3m_bail(c3__fail);
|
|
} else {
|
|
return u3qf_core(pac, con);
|
|
}
|
|
}
|
|
|
|
#if 0
|
|
static void
|
|
_fork_test(const c3_c *lab_c, u3_noun set)
|
|
{
|
|
if ( u3_nul == set ) {
|
|
return;
|
|
} else {
|
|
u3_noun n_set, l_set, r_set;
|
|
|
|
u3x_trel(set, &n_set, &l_set, &r_set);
|
|
|
|
u3qf_test(lab_c, n_set);
|
|
_fork_test(lab_c, l_set);
|
|
_fork_test(lab_c, r_set);
|
|
}
|
|
}
|
|
void
|
|
u3qf_test(const c3_c* lab_c, u3_noun sut)
|
|
{
|
|
u3_noun p_sut, q_sut;
|
|
|
|
if ( c3n == u3du(sut) ) switch ( sut ) {
|
|
default: u3m_bail(c3__fail); return;
|
|
|
|
case c3__noun:
|
|
{
|
|
return;
|
|
}
|
|
case c3__void:
|
|
{
|
|
return;
|
|
}
|
|
}
|
|
else switch ( u3h(sut) ) {
|
|
default: u3m_bail(c3__fail); return;
|
|
|
|
case c3__atom: u3x_cell(u3t(sut), &p_sut, &q_sut);
|
|
{
|
|
return;
|
|
}
|
|
case c3__cell: u3x_cell(u3t(sut), &p_sut, &q_sut);
|
|
{
|
|
u3qf_test(lab_c, p_sut);
|
|
u3qf_test(lab_c, q_sut);
|
|
return;
|
|
}
|
|
case c3__core: u3x_cell(u3t(sut), &p_sut, &q_sut);
|
|
{
|
|
u3qf_test(lab_c, p_sut);
|
|
return;
|
|
}
|
|
case c3__face: u3x_cell(u3t(sut), &p_sut, &q_sut);
|
|
{
|
|
u3qf_test(lab_c, q_sut);
|
|
return;
|
|
}
|
|
case c3__fork: p_sut = u3t(sut);
|
|
{
|
|
_fork_test(lab_c, p_sut);
|
|
return;
|
|
}
|
|
case c3__hint: u3x_cell(u3t(sut), &p_sut, &q_sut);
|
|
{
|
|
u3qf_test(lab_c, q_sut);
|
|
u3qf_test(lab_c, u3h(p_sut));
|
|
return;
|
|
}
|
|
case c3__hold: u3x_cell(u3t(sut), &p_sut, &q_sut);
|
|
{
|
|
u3qf_test(lab_c, p_sut);
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
#endif
|