aboutsummaryrefslogtreecommitdiff
path: root/src/stack.d
blob: 2fb602bb0270d29f399e52efe951cca94b74b085 (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
module src.stack;

import std.variant;
import std.string;
import std.container : SList;

static import src.definition;

alias Token = Algebraic!(int, bool, string);
alias Stack = SList;

Stack!Token stack;

Token top(ref Stack!Token stack) {
	if ( stack.empty ) {
		throw new Exception("stack is empty");
	} else {
		return stack.front;
	}
}

Token pop(ref Stack!Token stack) {
	Token token = stack.top;
	stack.removeFront;
	return token;
}

void push(ref Stack!Token stack, Token token) {
	if ( !src.definition.handle(token) ) {
		stack.insertFront(token);
	}
}

template push(T)
if ( is(T == int) || is(T == bool) || is (T == string) ) {
	void push(ref Stack!Token stack, T value) {
		stack.push(Token(value));
	}
}