aboutsummaryrefslogtreecommitdiff
path: root/src/primitives.d
blob: f57771354b288f4ffae9abf6aa35adc01d3a66cb (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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
module src.primitives;

import std.stdio;

import src.stack;
import src.definition;

int[string] variables;
bool        drop_mode;

bool evaluate(int value) {
	return drop_mode;
}

bool evaluate(string word) {
	if ( drop_mode ) {
		if ( word == "then" ) {
			drop_mode = false;
		}

		return true;
	}

	switch ( word ) {
		case "§":
			src.definition.start;
			return true;
		case "$":
			string name  = stack.pop.get!string;
			int    value = stack.pop.get!int;

			variables[name] = value;
			return true;
		case "@":
			string name = stack.pop.get!string;

			if ( name in variables ) {
				stack.push(variables[name]);
			}
			return true;
		case "if":
			switch ( stack.pop.get!int ) {
				case 0:
					drop_mode = true;
					return true;
				case 1:
					drop_mode = false;
					return true;
				default:
					throw new Exception("invalid logic value");
			}
		case "then":
			drop_mode = false;
			return true;
		case "+":
			int b = stack.pop.get!int;
			int a = stack.pop.get!int;

			stack.push(a + b);
			return true;
		case "*":
			int b = stack.pop.get!int;
			int a = stack.pop.get!int;

			stack.push(a * b);
			return true;
		case "/":
			int b = stack.pop.get!int;
			int a = stack.pop.get!int;

			if ( b == 0 ) {
				throw new Exception("division by 0 undefined");
			} else {
				stack.push(a / b);
			}
			return true;
		case "%":
			int b = stack.pop.get!int;
			int a = stack.pop.get!int;

			if ( b == 0 ) {
				throw new Exception("modulo 0 undefined");
			} else {
				stack.push(a % b);
			}
			return true;
		case ".":
			stack.pop;
			return true;
		case "'":
			writeln(stack.top);
			return true;
		default:
			return false;
	}
}