aboutsummaryrefslogtreecommitdiff
path: root/src/definition.d
diff options
context:
space:
mode:
authorAdrian Kummerlaender2017-04-14 23:21:51 +0200
committerAdrian Kummerlaender2017-04-14 23:21:51 +0200
commitc6d2b259a4f253403929f6f1104395a6a71b1be6 (patch)
tree6d4cdfa4ab50fbe0fa982db601d772c67e4dda20 /src/definition.d
parent963ace2e5ba0337130e5f343d7ab97a30b4547ae (diff)
downloadslang-c6d2b259a4f253403929f6f1104395a6a71b1be6.tar
slang-c6d2b259a4f253403929f6f1104395a6a71b1be6.tar.gz
slang-c6d2b259a4f253403929f6f1104395a6a71b1be6.tar.bz2
slang-c6d2b259a4f253403929f6f1104395a6a71b1be6.tar.lz
slang-c6d2b259a4f253403929f6f1104395a6a71b1be6.tar.xz
slang-c6d2b259a4f253403929f6f1104395a6a71b1be6.tar.zst
slang-c6d2b259a4f253403929f6f1104395a6a71b1be6.zip
Convert structure to _dub_ build system
Diffstat (limited to 'src/definition.d')
-rw-r--r--src/definition.d62
1 files changed, 0 insertions, 62 deletions
diff --git a/src/definition.d b/src/definition.d
deleted file mode 100644
index 9c3606e..0000000
--- a/src/definition.d
+++ /dev/null
@@ -1,62 +0,0 @@
-module src.definition;
-
-import std.string;
-import std.variant;
-import std.typecons;
-
-import std.container : DList;
-
-import src.stack;
-
-alias Words = Stack!Token[string];
-
-Nullable!(DList!Token) definition;
-Words words;
-
-void start() {
- definition = DList!Token();
-}
-
-void end() {
- string wordToBeDefined;
-
- definition.front.visit!(
- (int value) => wordToBeDefined = "",
- (bool value) => wordToBeDefined = "",
- (string name ) => wordToBeDefined = name
- );
-
- if ( wordToBeDefined == "" ) {
- throw new Exception("words may not be numeric or boolean");
- }
-
- definition.removeFront;
- words[wordToBeDefined] = Stack!Token(definition[]);
- definition.nullify;
-}
-
-bool handle(Token token) {
- if ( definition.isNull ) {
- return false;
- } else {
- if ( token.type == typeid(string) ) {
- if ( *token.peek!string == ";" ) {
- end;
- } else {
- definition.insertBack(token);
- }
- } else {
- definition.insertBack(token);
- }
-
- return true;
- }
-}
-
-Stack!Token get(string word) {
- if ( word in words ) {
- return words[word].dup;
- } else {
- return Stack!Token(Token(word));
- }
-}