mirror of
https://github.com/urbit/shrub.git
synced 2024-12-22 18:31:44 +03:00
roll/reel with while loops
This commit is contained in:
parent
b0d252fa76
commit
e3cafdd464
@ -3,35 +3,48 @@
|
|||||||
*/
|
*/
|
||||||
#include "all.h"
|
#include "all.h"
|
||||||
|
|
||||||
static u3_noun
|
|
||||||
_reel_in(u3j_site* sit_u, u3_noun a, u3_noun b)
|
|
||||||
{
|
|
||||||
if ( 0 == a ) {
|
|
||||||
return b;
|
|
||||||
}
|
|
||||||
else if ( c3n == u3du(a) ) {
|
|
||||||
return u3m_bail(c3__exit);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
u3_noun gim = u3k(u3h(a));
|
|
||||||
u3_noun hur = _reel_in(sit_u, u3t(a), b);
|
|
||||||
|
|
||||||
return u3j_gate_slam(sit_u, u3nc(gim, hur));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* functions
|
/* functions
|
||||||
*/
|
*/
|
||||||
u3_noun
|
u3_noun
|
||||||
u3qb_reel(u3_noun a,
|
u3qb_reel(u3_noun a,
|
||||||
u3_noun b)
|
u3_noun b)
|
||||||
{
|
{
|
||||||
u3_noun pro;
|
u3_noun pro = u3k(u3x_at(u3x_sam_3, b));
|
||||||
u3j_site sit_u;
|
if ( u3_nul == a ) {
|
||||||
u3j_gate_prep(&sit_u, u3k(b));
|
return pro;
|
||||||
pro = _reel_in(&sit_u, a, u3k(u3x_at(u3x_sam_3, b)));
|
}
|
||||||
u3j_gate_lose(&sit_u);
|
else {
|
||||||
return pro;
|
u3j_site sit_u;
|
||||||
|
u3_noun i, t = a;
|
||||||
|
c3_w j_w, len_w = 0, all_w = 89, pre_w = 55;
|
||||||
|
u3_noun* vec = u3a_malloc(all_w);
|
||||||
|
|
||||||
|
// stuff list into an array
|
||||||
|
do {
|
||||||
|
if ( c3n == u3r_cell(t, &i, &t) ) {
|
||||||
|
u3a_free(vec);
|
||||||
|
return u3m_bail(c3__exit);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if ( len_w == all_w ) {
|
||||||
|
// grow vec fib-wise
|
||||||
|
all_w += pre_w;
|
||||||
|
pre_w = len_w;
|
||||||
|
vec = u3a_realloc(vec, all_w);
|
||||||
|
}
|
||||||
|
vec[len_w++] = i;
|
||||||
|
}
|
||||||
|
} while ( u3_nul != t );
|
||||||
|
|
||||||
|
// now we can iterate backwards
|
||||||
|
u3j_gate_prep(&sit_u, u3k(b));
|
||||||
|
for ( j_w = len_w; j_w > 0; ) {
|
||||||
|
pro = u3j_gate_slam(&sit_u, u3nc(u3k(vec[--j_w]), pro));
|
||||||
|
}
|
||||||
|
u3j_gate_lose(&sit_u);
|
||||||
|
u3a_free(vec);
|
||||||
|
return pro;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
u3_noun
|
u3_noun
|
||||||
u3wb_reel(u3_noun cor)
|
u3wb_reel(u3_noun cor)
|
||||||
|
@ -3,32 +3,25 @@
|
|||||||
*/
|
*/
|
||||||
#include "all.h"
|
#include "all.h"
|
||||||
|
|
||||||
static u3_noun
|
|
||||||
_roll_in(u3j_site* sit_u, u3_noun a, u3_noun b)
|
|
||||||
{
|
|
||||||
if ( 0 == a ) {
|
|
||||||
return b;
|
|
||||||
}
|
|
||||||
else if ( c3n == u3du(a) ) {
|
|
||||||
return u3m_bail(c3__exit);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
b = u3j_gate_slam(sit_u, u3nc(u3k(u3h(a)), b));
|
|
||||||
return _roll_in(sit_u, u3t(a), b);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* functions
|
/* functions
|
||||||
*/
|
*/
|
||||||
u3_noun
|
u3_noun
|
||||||
u3qb_roll(u3_noun a,
|
u3qb_roll(u3_noun a,
|
||||||
u3_noun b)
|
u3_noun b)
|
||||||
{
|
{
|
||||||
u3_noun pro;
|
u3_noun pro = u3k(u3x_at(u3x_sam_3, b));
|
||||||
u3j_site sit_u;
|
|
||||||
u3j_gate_prep(&sit_u, u3k(b));
|
if ( u3_nul != a ) {
|
||||||
pro = _roll_in(&sit_u, a, u3k(u3x_at(u3x_sam_3, b)));
|
u3j_site sit_u;
|
||||||
u3j_gate_lose(&sit_u);
|
u3_noun i, t = a;
|
||||||
|
u3j_gate_prep(&sit_u, u3k(b));
|
||||||
|
do {
|
||||||
|
u3x_cell(t, &i, &t);
|
||||||
|
pro = u3j_gate_slam(&sit_u, u3nc(u3k(i), pro));
|
||||||
|
} while ( u3_nul != t );
|
||||||
|
u3j_gate_lose(&sit_u);
|
||||||
|
}
|
||||||
|
|
||||||
return pro;
|
return pro;
|
||||||
}
|
}
|
||||||
u3_noun
|
u3_noun
|
||||||
|
Loading…
Reference in New Issue
Block a user