Mercurial > projects > dil
annotate trunk/src/main.d @ 309:b4d842b0d2c7
- Added new files Settings.d, config.d and lang_en.d
- Removed redundant break statements from Lexer.d.
- Added function Cast() to SyntaxTree.d.
- Relocated compiler version info to Settings.d.
- Removed messages variable from module Messages. Compiler messages are loaded dynamically now.
- Relocated some functions from module Information to module Messages, and added some format functions to it.
- Message tables are located in their own lang_*.d files.
- Added getString() method to class StringLiteralsExpression.
- Module Settings has a static struct GlobalSettings. It loads global settings from config.d and a language file.
author | aziz |
---|---|
date | Wed, 15 Aug 2007 16:07:05 +0000 |
parents | 3b9fc1e72210 |
children | fa0b6f32c1ae |
rev | line source |
---|---|
0 | 1 /++ |
2 Author: Aziz Köksal | |
249 | 3 License: GPL3 |
0 | 4 +/ |
5 module dparser; | |
69
24db7c5522d5
- Added module Information for compiler messages like warnings, info and errors to the user.
aziz
parents:
66
diff
changeset
|
6 import Parser; |
3 | 7 import Lexer; |
8 import Token; | |
54 | 9 import Messages; |
3 | 10 import std.stdio; |
4 | 11 import std.file; |
309 | 12 import Settings; |
13 import Declarations, Expressions, SyntaxTree; | |
306 | 14 |
0 | 15 void main(char[][] args) |
16 { | |
309 | 17 GlobalSettings.load(); |
18 | |
306 | 19 if (args.length <= 1) |
309 | 20 return writefln(format(MID.HelpMain, VERSION, usageHighlight, COMPILED_WITH, COMPILED_VERSION, COMPILED_DATE)); |
306 | 21 |
22 string command = args[1]; | |
23 switch (command) | |
24 { | |
25 case "hl", "highlight": | |
26 if (args.length == 3) | |
309 | 27 tokensToXML(args[2]); |
306 | 28 break; |
29 default: | |
30 } | |
31 } | |
32 | |
33 void parse(string fileName) | |
34 { | |
35 auto sourceText = cast(char[]) std.file.read(fileName); | |
36 auto parser = new Parser(sourceText, fileName); | |
213
b0ebde88d2d4
- Added members trying, errorCount and prev (for debugging) to Parser.
aziz
parents:
112
diff
changeset
|
37 parser.start(); |
305 | 38 auto root = parser.parseModule(); |
299
559d5d62e0c1
- Added checks for null before adding member to Node.children.
aziz
parents:
249
diff
changeset
|
39 |
559d5d62e0c1
- Added checks for null before adding member to Node.children.
aziz
parents:
249
diff
changeset
|
40 void print(Node[] decls, char[] indent) |
559d5d62e0c1
- Added checks for null before adding member to Node.children.
aziz
parents:
249
diff
changeset
|
41 { |
559d5d62e0c1
- Added checks for null before adding member to Node.children.
aziz
parents:
249
diff
changeset
|
42 foreach(decl; decls) |
559d5d62e0c1
- Added checks for null before adding member to Node.children.
aziz
parents:
249
diff
changeset
|
43 { |
559d5d62e0c1
- Added checks for null before adding member to Node.children.
aziz
parents:
249
diff
changeset
|
44 assert(decl !is null); |
303 | 45 writefln(indent, decl.classinfo.name, ": begin=%s end=%s", decl.begin ? decl.begin.srcText : "\33[31mnull\33[0m", decl.end ? decl.end.srcText : "\33[31mnull\33[0m"); |
299
559d5d62e0c1
- Added checks for null before adding member to Node.children.
aziz
parents:
249
diff
changeset
|
46 print(decl.children, indent ~ " "); |
559d5d62e0c1
- Added checks for null before adding member to Node.children.
aziz
parents:
249
diff
changeset
|
47 } |
559d5d62e0c1
- Added checks for null before adding member to Node.children.
aziz
parents:
249
diff
changeset
|
48 } |
305 | 49 print(root.children, ""); |
213
b0ebde88d2d4
- Added members trying, errorCount and prev (for debugging) to Parser.
aziz
parents:
112
diff
changeset
|
50 foreach (error; parser.errors) |
b0ebde88d2d4
- Added members trying, errorCount and prev (for debugging) to Parser.
aziz
parents:
112
diff
changeset
|
51 { |
b0ebde88d2d4
- Added members trying, errorCount and prev (for debugging) to Parser.
aziz
parents:
112
diff
changeset
|
52 writefln(`%s(%d)P: %s`, parser.lx.fileName, error.loc, error.getMsg); |
b0ebde88d2d4
- Added members trying, errorCount and prev (for debugging) to Parser.
aziz
parents:
112
diff
changeset
|
53 } |
306 | 54 } |
213
b0ebde88d2d4
- Added members trying, errorCount and prev (for debugging) to Parser.
aziz
parents:
112
diff
changeset
|
55 |
306 | 56 char[] xml_escape(char[] text) |
57 { | |
58 char[] result; | |
59 foreach(c; text) | |
60 switch(c) | |
61 { | |
62 case '<': result ~= "<"; break; | |
63 case '>': result ~= ">"; break; | |
64 case '&': result ~= "&"; break; | |
65 default: result ~= c; | |
66 } | |
67 return result; | |
68 } | |
0 | 69 |
309 | 70 void tokensToXML(string fileName) |
306 | 71 { |
72 auto sourceText = cast(char[]) std.file.read(fileName); | |
73 auto lx = new Lexer(sourceText, fileName); | |
74 | |
75 auto token = lx.getTokens(); | |
5 | 76 char* end = lx.text.ptr; |
77 | |
306 | 78 writef(`<?xml version="1.0"?>` |
79 `<?xml-stylesheet href="format.css" type="text/css"?>` | |
80 `<root>`); | |
81 if (lx.errors.length) | |
51 | 82 { |
306 | 83 writefln("<compilerinfo>"); |
84 foreach (error; lx.errors) | |
85 { | |
86 writefln(`<error t="%s">%s(%d): %s</error>`, "l", lx.fileName, error.loc, xml_escape(error.getMsg)); | |
87 } | |
88 writefln("</compilerinfo>"); | |
51 | 89 } |
306 | 90 writef(`<sourcetext>`); |
91 | |
92 // Traverse linked list and print tokens. | |
93 while (token.type != TOK.EOF) | |
4 | 94 { |
306 | 95 token = token.next; |
96 | |
97 // Print whitespace between previous and current token. | |
5 | 98 if (end != token.start) |
306 | 99 writef("%s", xml_escape(end[0 .. token.start - end])); |
100 | |
101 string srcText = xml_escape(token.srcText); | |
102 | |
5 | 103 switch(token.type) |
104 { | |
306 | 105 case TOK.Identifier: |
106 writef("<i>%s</i>", srcText); | |
5 | 107 break; |
306 | 108 case TOK.Comment: |
109 string c; | |
110 switch (token.start[1]) | |
111 { | |
112 case '/': c = "l"; break; | |
113 case '*': c = "b"; break; | |
114 case '+': c = "n"; break; | |
115 default: | |
116 assert(0); | |
117 } | |
118 writef(`<c c="%s">%s</c>`, c, srcText); | |
5 | 119 break; |
306 | 120 case TOK.String: |
121 writef("<sl>%s</sl>", srcText); | |
9
5d6968cc751e
- Parsing string and character literals now (rudimentary implementation.)
aziz
parents:
5
diff
changeset
|
122 break; |
306 | 123 case TOK.CharLiteral, TOK.WCharLiteral, TOK.DCharLiteral: |
124 writef("<cl>%s</cl>", srcText); | |
9
5d6968cc751e
- Parsing string and character literals now (rudimentary implementation.)
aziz
parents:
5
diff
changeset
|
125 break; |
308 | 126 case TOK.Assign, TOK.Equal, |
127 TOK.Less, TOK.Greater, | |
128 TOK.LShiftAssign, TOK.LShift, | |
129 TOK.RShiftAssign, TOK.RShift, | |
306 | 130 TOK.URShiftAssign, TOK.URShift, |
308 | 131 TOK.OrAssign, TOK.OrBinary, |
132 TOK.AndAssign, TOK.AndBinary, | |
133 TOK.PlusAssign, TOK.PlusPlus, TOK.Plus, | |
134 TOK.MinusAssign, TOK.MinusMinus, TOK.Minus, | |
135 TOK.DivAssign, TOK.Div, | |
136 TOK.MulAssign, TOK.Mul, | |
137 TOK.ModAssign, TOK.Mod, | |
138 TOK.XorAssign, TOK.Xor, | |
139 TOK.CatAssign, | |
306 | 140 TOK.Tilde, |
141 TOK.Unordered, | |
142 TOK.UorE, | |
143 TOK.UorG, | |
144 TOK.UorGorE, | |
145 TOK.UorL, | |
146 TOK.UorLorE, | |
147 TOK.LorEorG: | |
148 writef("<op>%s</op>", srcText); | |
14 | 149 break; |
306 | 150 case TOK.LorG: |
151 writef(`<op c="lg"><></op>`); | |
39
69b940398d7b
- Added unittest to test correct parsing of operator tokens.
aziz
parents:
35
diff
changeset
|
152 break; |
306 | 153 case TOK.LessEqual: |
154 writef(`<op c="le"><=</op>`); | |
39
69b940398d7b
- Added unittest to test correct parsing of operator tokens.
aziz
parents:
35
diff
changeset
|
155 break; |
306 | 156 case TOK.GreaterEqual: |
157 writef(`<op c="ge">>=</op>`); | |
39
69b940398d7b
- Added unittest to test correct parsing of operator tokens.
aziz
parents:
35
diff
changeset
|
158 break; |
306 | 159 case TOK.AndLogical: |
160 writef(`<op c="aa">&&</op>`); | |
31
94f09f4e988e
- Added struct for strings to Token with 'pf' = postfix.
aziz
parents:
30
diff
changeset
|
161 break; |
306 | 162 case TOK.OrLogical: |
163 writef(`<op c="oo">||</op>`); | |
31
94f09f4e988e
- Added struct for strings to Token with 'pf' = postfix.
aziz
parents:
30
diff
changeset
|
164 break; |
306 | 165 case TOK.NotEqual: |
166 writef(`<op c="ne">!=</op>`); | |
44
5055947e0f98
- Specific operators and comments can be formatted with CSS now.
aziz
parents:
39
diff
changeset
|
167 break; |
306 | 168 case TOK.Not: |
307
5f6a173d4ad3
- Don't consider '\!' as an operator when it begins a template argument list.
aziz
parents:
306
diff
changeset
|
169 // Check if this is part of a template instantiation. |
5f6a173d4ad3
- Don't consider '\!' as an operator when it begins a template argument list.
aziz
parents:
306
diff
changeset
|
170 // TODO: comments aren't skipped. |
5f6a173d4ad3
- Don't consider '\!' as an operator when it begins a template argument list.
aziz
parents:
306
diff
changeset
|
171 if (token.prev.type == TOK.Identifier && token.next.type == TOK.LParen) |
5f6a173d4ad3
- Don't consider '\!' as an operator when it begins a template argument list.
aziz
parents:
306
diff
changeset
|
172 goto default; |
306 | 173 writef(`<op c="n">!</op>`); |
35
c470b9356e35
- Added code for parsing Unordered, UorE, UorG, UorGorE, UorL, UorLorE, NotEqual and Not tokens.
aziz
parents:
33
diff
changeset
|
174 break; |
306 | 175 case TOK.Int32, TOK.Int64, TOK.Uint32, TOK.Uint64, |
308 | 176 TOK.Float32, TOK.Float64, TOK.Float80, |
177 TOK.Imaginary32, TOK.Imaginary64, TOK.Imaginary80: | |
306 | 178 writef("<n>%s</n>", srcText); |
15 | 179 break; |
306 | 180 case TOK.LParen, TOK.RParen, TOK.LBracket, |
308 | 181 TOK.RBracket, TOK.LBrace, TOK.RBrace: |
306 | 182 writef("<br>%s</br>", srcText); |
20 | 183 break; |
306 | 184 default: |
185 if (token.isKeyword()) | |
186 writef("<k>%s</k>", srcText); | |
187 else | |
188 writef("%s", srcText); | |
5 | 189 } |
190 end = token.end; | |
4 | 191 } |
51 | 192 writef("\n</sourcetext>\n</root>"); |
0 | 193 } |