blob: a52d51e8d1b6d4c80ac45f08f67d328cc35ca246 (
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
|
main() => nopipe() |> pipe();
nopipe() {
local s;
s = strdup("yo comment cava\n");
write(s);
stoupper(s);
write(s);
}
pipe() => strdup("coucou le monde\n") |> write() |> stoupper() |> write();
write(s) {
local o;
o = s;
loop {
if ([s] == 0)
return o;
wrt [s];
s = s + 1;
}
}
strlen(s) {
local len;
len = 0;
loop {
if ([s + len] == 0)
return len;
len = len + 1;
}
}
strdup(s) {
return strcpy(malloc(strlen(s) + 1), s);
}
strcpy(dst, src) {
local i;
i = 0;
loop {
[dst + i] = [src + i];
if ([src + i] == 0)
return dst;
i = i + 1;
}
}
stoupper(s) {
local o;
o = s;
loop {
if ([s] == 0)
return o;
[s] = [s] - ([s] >= 'a' & [s] <= 'z') * 32;
s = s + 1;
}
}
define HEAP_SIZE = 4096;
global heap[HEAP_SIZE] = 0x69;
global heap_size = 0;
malloc(n) {
local p;
p = heap + heap_size;
heap_size = heap_size + n;
if (heap_size > 4096) {
write("malloc error: heap is full");
return 0;
}
return p;
}
|