mirror of
https://github.com/urbit/shrub.git
synced 2025-01-06 21:18:42 +03:00
83 lines
1.8 KiB
C
83 lines
1.8 KiB
C
/* jets/d/by_bif.c
|
|
**
|
|
*/
|
|
#include "all.h"
|
|
|
|
/* internal functions
|
|
*/
|
|
static
|
|
u3_noun _b_bif_putroot(u3_noun a,
|
|
u3_noun b)
|
|
{
|
|
if ( u3_nul == a) {
|
|
return u3nt(u3k(b), u3_nul, u3_nul);
|
|
}
|
|
else {
|
|
u3_noun n_a, l_a, r_a;
|
|
u3_noun p_n_a, q_n_a;
|
|
u3_noun p_b, q_b;
|
|
|
|
if ( (c3n == u3r_trel(a, &n_a, &l_a, &r_a))
|
|
|| (c3n == u3r_cell(b, &p_b, &q_b))
|
|
|| (c3n == u3r_cell(n_a, &p_n_a, &q_n_a)) ) {
|
|
return u3m_bail(c3__exit);
|
|
}
|
|
else if ( c3y == u3r_sing(p_b, p_n_a) ) {
|
|
return u3nt(u3k(b), u3k(l_a), u3k(r_a));
|
|
}
|
|
else {
|
|
u3_noun c, n_c, l_c, r_c;
|
|
u3_noun d;
|
|
|
|
if ( c3y == u3qc_gor(p_b, p_n_a) ) {
|
|
c = _b_bif_putroot(l_a, b);
|
|
u3r_trel(c, &n_c, &l_c, &r_c);
|
|
d = u3nt(u3k(n_c),
|
|
u3k(l_c),
|
|
u3nt(u3k(n_a), u3k(r_c), u3k(r_a))
|
|
);
|
|
u3z(c);
|
|
return d;
|
|
} else {
|
|
c = _b_bif_putroot(r_a, b);
|
|
u3r_trel(c, &n_c, &l_c, &r_c);
|
|
d = u3nt(u3k(n_c),
|
|
u3nt(u3k(n_a), u3k(l_a), u3k(l_c)),
|
|
u3k(r_c)
|
|
);
|
|
u3z(c);
|
|
return d;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
/* functions
|
|
*/
|
|
u3_noun u3wdb_bif(u3_noun cor)
|
|
{
|
|
u3_noun a, b;
|
|
if ( c3n == u3r_mean(cor, u3x_sam, &b, u3x_con_sam, &a, 0) ) {
|
|
return u3m_bail(c3__exit);
|
|
} else {
|
|
return u3qdb_bif(a, b);
|
|
}
|
|
}
|
|
|
|
u3_noun u3qdb_bif(u3_noun a,
|
|
u3_noun b)
|
|
{
|
|
u3_noun c, n_c, l_c, r_c;
|
|
u3_noun d;
|
|
|
|
c = _b_bif_putroot(a, b);
|
|
u3r_trel(c, &n_c, &l_c, &r_c);
|
|
d = u3nc(u3k(l_c), u3k(r_c));
|
|
u3z(c);
|
|
return d;
|
|
}
|
|
|
|
/*
|
|
u3_weak u3kdi_bif(u3_noun a, u3_noun b);
|
|
*/
|