summaryrefslogtreecommitdiffstats
path: root/Sencha-lang/main.cpp
blob: 9130c3fba3fcdd9de7a45a94a835077d27f67517 (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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
#include <iostream>
#include <string>
#include "Token.h"
#include "Lexer.h"
#include "Parser.h"
#include "Tests/TestLexer.h"
#include "Context.h"

using namespace std;

void test_lexer()
{
    string test_line = "dupa";
    string test_line2 = "def how_many_trees = 1; how_many_trees + 3 == 2; num cut_tree( num how_many) {return how_many -1; != <=}";
    Lexer lexer;
    vector<Token> tokens = lexer.parse_line(test_line);


    for(unsigned int i=0; i< tokens.size(); i++)
    {
        cout << tokens[i].get_value() << " type: " << tokens[i].get_type() << endl;
    }


    tokens = lexer.parse_line(test_line2);

}

void test_parser()
{
    vector<string> lines;
    lines.push_back("def i; bulb; i + 3; string banan = \"kartofel\"; banan = \"banan\"; string kaboom(num how_many_times) { def z; }");
    lines.push_back("num pun");
    lines.push_back("def how_many_trees = 1; how_many_trees + 3 == 2; num cut_tree(num how_many) {return how_many -1}");
    Lexer lexer;
    Context context;
    vector<Token> tokens;

    for(unsigned int i=0; i<lines.size(); i++)
    {
        tokens = lexer.parse_line(lines[i]);
        Parser parser(&context);
        parser.add_tokens(tokens);
        parser.interpret();
        cout << "<<<Parsing number: " << i << " >>>" << endl;
        cout << "Instructions: " << endl ;
        cout << lines[i] << endl << endl;
        cout << parser.report_message;
        cout << parser.error_message << endl;
    }

}

int how_depth_change(vector<Token> tokens)
{
	int change = 0;
	for (unsigned int i = 0; i < tokens.size(); i++)
	{
		if(tokens[i].value == "{") change++;
		else if(tokens[i].value == "}") change--;
	}
	return change;
}

string compute_indentation(int depth_level)
{
	string indent = "";
	for(int i=0; i< depth_level; i++)
	{
		indent += "    ";
	}
	return indent;
}

void interactive()
{
	Lexer lexer;

	Context context;
	Parser parser(&context);

	vector<Token> tokens;

	string input;
	int level_of_depth = 0;
	string indentation = "";
	while(true)
	{
		cout << ">> " + indentation;
		getline(cin, input);
		if(input == "quit()") break;
		tokens = lexer.parse_line(input);

		level_of_depth += how_depth_change(tokens);
		indentation = compute_indentation(level_of_depth);

		parser.add_tokens(tokens);

		if(level_of_depth == 0) {
			parser.interpret();
			parser.program->execute_last();

			//cout << parser.report_message << endl;
			//cout << parser.error_message << endl;
			//cout << parser.show_tokens() << endl;
			//cout << "My tree:\n";
			//cout << parser.program->debug();
			cout << parser.context->debug();
		}
	}

}

int main()
{
    cout << "Sencha-lang interpreter, version 0.12" << endl;

    TestLexer test_l;
    //test_l.run_tests();

    //test_parser();
    //test_lexer();
    interactive();
    return 0;
}