diff options
| author | polwex <polwex@sortug.com> | 2025-10-06 01:01:41 +0700 |
|---|---|---|
| committer | polwex <polwex@sortug.com> | 2025-10-06 01:01:41 +0700 |
| commit | c4b392a179048f936c062f5ffccc2bc25627e500 (patch) | |
| tree | 09be0904be8ec4d7ea52992ef7580d42ed0c28c1 /vere/pkg/noun/jets/b/lien.c | |
working
Diffstat (limited to 'vere/pkg/noun/jets/b/lien.c')
| -rw-r--r-- | vere/pkg/noun/jets/b/lien.c | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/vere/pkg/noun/jets/b/lien.c b/vere/pkg/noun/jets/b/lien.c new file mode 100644 index 0000000..5d04907 --- /dev/null +++ b/vere/pkg/noun/jets/b/lien.c @@ -0,0 +1,49 @@ +/// @file + +#include "jets/q.h" +#include "jets/w.h" + +#include "noun.h" + + static u3_noun + _lien_in(u3j_site* sit_u, u3_noun a) + { + if ( 0 == a ) { + return c3n; + } else { + u3_noun loz; + + if ( c3n == u3du(a) ) { + return u3m_bail(c3__exit); + } + else switch ( (loz = u3j_gate_slam(sit_u, u3k(u3h(a)))) ) { + case c3y: return c3y; + case c3n: return _lien_in(sit_u, u3t(a)); + default: u3z(loz); + return u3m_bail(c3__exit); + } + } + } + + u3_noun + u3qb_lien(u3_noun a, + u3_noun b) + { + u3_noun pro; + u3j_site sit_u; + u3j_gate_prep(&sit_u, u3k(b)); + pro = _lien_in(&sit_u, a); + u3j_gate_lose(&sit_u); + return pro; + } + u3_noun + u3wb_lien(u3_noun cor) + { + u3_noun a, b; + + if ( c3n == u3r_mean(cor, u3x_sam_2, &a, u3x_sam_3, &b, 0) ) { + return u3m_bail(c3__exit); + } else { + return u3qb_lien(a, b); + } + } |
