summaryrefslogtreecommitdiff
path: root/vere/pkg/noun/jets/f/fork.c
blob: b2a68eb6a44d7225c318495e2e83f704aa51e926 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
/// @file

#include "jets/k.h"
#include "jets/q.h"
#include "jets/w.h"

#include "noun.h"


  u3_noun
  u3qf_forq(u3_noun hoz,
            u3_noun bur)
  {
    if ( c3y == u3r_sing(hoz, bur) ) {
      return u3k(hoz);
    }
    else if ( c3__void == bur ) {
      return u3k(hoz);
    }
    else if ( c3__void == hoz ) {
      return u3k(bur);
    }
    else return u3kf_fork(u3nt(u3k(hoz), u3k(bur), u3_nul));
  }

  u3_noun
  u3qf_fork(u3_noun yed)
  {
    u3_noun lez = u3_nul;

    while ( u3_nul != yed ) {
      u3_noun i_yed = u3h(yed);

      if ( c3__void != i_yed ) {
        if ( (c3y == u3du(i_yed)) && (c3__fork == u3h(i_yed)) ) {
          lez = u3kdi_uni(lez, u3k(u3t(i_yed)));
        }
        else {
          lez = u3kdi_put(lez, u3k(i_yed));
        }
      }

      yed = u3t(yed);
    }

    if ( u3_nul == lez ) {
      return c3__void;
    }
    else if ( (u3_nul == u3h(u3t(lez))) && (u3_nul == u3t(u3t(lez))) ) {
      u3_noun ret = u3k(u3h(lez));

      u3z(lez);
      return ret;
    }
    else {
      return u3nc(c3__fork, lez);
    }
  }

  u3_noun
  u3wf_fork(u3_noun cor)
  {
    u3_noun yed;

    if ( c3n == u3r_mean(cor, u3x_sam, &yed, 0) ) {
      return u3m_bail(c3__fail);
    } else {
      return u3qf_fork(yed);
    }
  }

  u3_noun
  u3kf_fork(u3_noun yed)
  {
    u3_noun ret = u3qf_fork(yed);

    u3z(yed);
    return ret;
  }