63a82c21ce4ba686908c2641ddc32b015e872b68
[mes.git] / lib.c
1 /* -*-comment-start: "//";comment-end:""-*-
2  * Mes --- Maxwell Equations of Software
3  * Copyright © 2016 Jan Nieuwenhuizen <janneke@gnu.org>
4  *
5  * This file is part of Mes.
6  *
7  * Mes is free software; you can redistribute it and/or modify it
8  * under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 3 of the License, or (at
10  * your option) any later version.
11  *
12  * Mes is distributed in the hope that it will be useful, but
13  * WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with Mes.  If not, see <http://www.gnu.org/licenses/>.
19  */
20
21 SCM caar (SCM x) {return car (car (x));}
22 SCM cadr (SCM x) {return car (cdr (x));}
23 SCM cdar (SCM x) {return cdr (car (x));}
24 SCM cddr (SCM x) {return cdr (cdr (x));}
25 SCM caaar (SCM x) {return car (car (car (x)));}
26 SCM caadr (SCM x) {return car (car (cdr (x)));}
27 SCM caddr (SCM x) {return car (cdr (cdr (x)));}
28 SCM cdadr (SCM x) {return cdr (car (cdr (x)));}
29 SCM cadar (SCM x) {return car (cdr (car (x)));}
30 SCM cddar (SCM x) {return cdr (cdr (car (x)));}
31 SCM cdddr (SCM x) {return cdr (cdr (cdr (x)));}
32 SCM cadddr (SCM x) {return car (cdr (cdr (cdr (x))));}
33
34 SCM
35 length (SCM x)
36 {
37   int n = 0;
38   while (x != cell_nil)
39     {
40       n++;
41       x = cdr (x);
42     }
43   return make_number (n);
44 }
45
46 SCM
47 last_pair (SCM x)
48 {
49   while (x != cell_nil && cdr (x) != cell_nil)
50     x = cdr (x);
51   return x;
52 }
53
54 SCM
55 list (SCM x) ///((arity . n))
56 {
57   return x;
58 }
59
60 SCM
61 list_ref (SCM x, SCM k)
62 {
63   assert (type (x) == PAIR);
64   assert (type (k) == NUMBER);
65   int n = value (k);
66   while (n-- && g_cells[x].cdr != cell_nil) x = g_cells[x].cdr;
67   return x != cell_nil ? car (x) : cell_undefined;
68 }
69
70 SCM
71 vector_to_list (SCM v)
72 {
73   SCM x = cell_nil;
74   for (int i = 0; i < LENGTH (v); i++) {
75     SCM e = VECTOR (v)+i;
76     if (type (e) == REF) e = g_cells[e].ref;
77     x = append2 (x, cons (e, cell_nil));
78   }
79   return x;
80 }
81
82 SCM
83 integer_to_char (SCM x)
84 {
85   assert (type (x) == NUMBER);
86   return make_char (value (x));
87 }
88
89 SCM
90 char_to_integer (SCM x)
91 {
92   assert (type (x) == CHAR);
93   return make_number (value (x));
94 }
95
96 SCM
97 builtin_exit (SCM x)
98 {
99   assert (type (x) == NUMBER);
100   exit (value (x));
101 }