summaryrefslogtreecommitdiff
path: root/vere/pkg/noun/jets/b/zing.c
blob: 1172d5e3a025c20b344c72cd571921766a9c2fee (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
/// @file

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

#include "noun.h"

u3_noun
u3qb_zing(u3_noun a)
{
  u3_noun  pro;
  u3_noun* lit = &pro;

  if ( u3_nul == a ) {
    *lit = u3_nul;
  }
  else {
    u3_noun i, t = a;
    u3x_cell(t, &i, &t);

    while ( u3_nul != t ) {
      u3_noun* hed;
      u3_noun* tel;
      u3_noun  i_i, t_i = i;

      while ( u3_nul != t_i ) {
        u3x_cell(t_i, &i_i, &t_i);

        *lit = u3i_defcons(&hed, &tel);
        *hed = u3k(i_i);
        lit  = tel;
      }

      u3x_cell(t, &i, &t);
    }

    *lit = u3k(i);
  }

  return pro;
}

u3_noun
u3wb_zing(u3_noun cor)
{
  return u3qb_zing(u3x_at(u3x_sam, cor));
}