aboutsummaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--LuaSL/src/LuaSL_LSL_tree.c267
-rw-r--r--LuaSL/src/LuaSL_LSL_tree.h28
-rw-r--r--LuaSL/src/LuaSL_lexer.l27
-rw-r--r--LuaSL/src/LuaSL_yaccer.y7
4 files changed, 207 insertions, 122 deletions
diff --git a/LuaSL/src/LuaSL_LSL_tree.c b/LuaSL/src/LuaSL_LSL_tree.c
index 552de04..a69b0d3 100644
--- a/LuaSL/src/LuaSL_LSL_tree.c
+++ b/LuaSL/src/LuaSL_LSL_tree.c
@@ -7,6 +7,7 @@
7#define LSL_Tokens_define 7#define LSL_Tokens_define
8#include "LuaSL_LSL_tree.h" 8#include "LuaSL_LSL_tree.h"
9#include <stdlib.h> 9#include <stdlib.h>
10#include <stdio.h>
10 11
11 12
12/** 13/**
@@ -88,10 +89,18 @@ LSL_Expression *newTree(const char *expr)
88 LuaSL_yyparseParam param; 89 LuaSL_yyparseParam param;
89 YY_BUFFER_STATE state; 90 YY_BUFFER_STATE state;
90 91
92#ifdef LUASL_DEBUG
93 yydebug= 5;
94#endif
95
91 param.expression = NULL; 96 param.expression = NULL;
92 if (yylex_init(&(param.scanner))) 97 if (yylex_init(&(param.scanner)))
93 return NULL; 98 return NULL;
94 99
100#ifdef LUASL_DEBUG
101 yyset_debug(1, param.scanner);
102#endif
103
95 state = yy_scan_string(expr, param.scanner); 104 state = yy_scan_string(expr, param.scanner);
96 if (yyparse(&param)) 105 if (yyparse(&param))
97 return NULL; 106 return NULL;
@@ -106,88 +115,112 @@ int evaluateExpression(LSL_Expression *exp, int old)
106{ 115{
107 switch(exp->type) 116 switch(exp->type)
108 { 117 {
109// case LSL_COMMENT : 118#ifdef LUASL_USE_ENUM
110// case LSL_TYPE : 119 case LSL_COMMENT :
111// case LSL_NAME : 120 case LSL_TYPE :
112// case LSL_IDENTIFIER : 121 case LSL_NAME :
113// break; 122 case LSL_IDENTIFIER :
114// case LSL_FLOAT : return (int) exp->value.floatValue; 123 break;
115 case LSL_INTEGER : return exp->value.integerValue; 124 case LSL_FLOAT : return (int) exp->value.floatValue;
116// case LSL_STRING : 125#endif
117// case LSL_KEY : 126 case LSL_INTEGER :
118// case LSL_VECTOR : 127#ifdef LUASL_DEBUG
119// case LSL_ROTATION : 128 printf("%d", exp->value.integerValue);
120// case LSL_LIST : 129#endif
121// case LSL_LABEL : 130 return exp->value.integerValue;
122// break; 131#ifdef LUASL_USE_ENUM
132 case LSL_STRING :
133 case LSL_KEY :
134 case LSL_VECTOR :
135 case LSL_ROTATION :
136 case LSL_LIST :
137 case LSL_LABEL :
138 break;
139#endif
123 case LSL_EXPRESSION : 140 case LSL_EXPRESSION :
124 { 141 {
125 switch (exp->expression) 142 switch (exp->expression)
126 { 143 {
127// case LSL_COMMA : 144#ifdef LUASL_USE_ENUM
128// case LSL_INCREMENT_PRE : 145 case LSL_COMMA :
129// case LSL_INCREMENT_POST : 146 case LSL_INCREMENT_PRE :
130// case LSL_DECREMENT_PRE : 147 case LSL_INCREMENT_POST :
131// case LSL_DECREMENT_POST : 148 case LSL_DECREMENT_PRE :
132// case LSL_DOT : 149 case LSL_DECREMENT_POST :
133// case LSL_ASSIGNMENT_PLAIN : 150 case LSL_DOT :
134// case LSL_ASSIGNMENT_DIVIDE : 151 case LSL_ASSIGNMENT_PLAIN :
135// case LSL_ASSIGNMENT_MODULO : 152 case LSL_ASSIGNMENT_DIVIDE :
136// case LSL_ASSIGNMENT_MULTIPLY : 153 case LSL_ASSIGNMENT_MODULO :
137// case LSL_ASSIGNMENT_SUBTRACT : 154 case LSL_ASSIGNMENT_MULTIPLY :
138// case LSL_ASSIGNMENT_ADD : 155 case LSL_ASSIGNMENT_SUBTRACT :
139// case LSL_ASSIGNMENT_CONCATENATE : 156 case LSL_ASSIGNMENT_ADD :
157 case LSL_ASSIGNMENT_CONCATENATE :
140 case LSL_PARENTHESIS_OPEN : 158 case LSL_PARENTHESIS_OPEN :
141 case LSL_PARENTHESIS_CLOSE : 159 case LSL_PARENTHESIS_CLOSE :
142// case LSL_BRACKET_OPEN : 160 case LSL_BRACKET_OPEN :
143// case LSL_BRACKET_CLOSE : 161 case LSL_BRACKET_CLOSE :
144// case LSL_ANGLE_OPEN : 162 case LSL_ANGLE_OPEN :
145// case LSL_ANGLE_CLOSE : 163 case LSL_ANGLE_CLOSE :
146// case LSL_TYPECAST : 164 case LSL_TYPECAST :
147// case LSL_BIT_NOT : 165 case LSL_BIT_NOT :
148// case LSL_BOOL_NOT : 166 case LSL_BOOL_NOT :
149// case LSL_NEGATION : 167 case LSL_NEGATION :
150 break; 168 break;
151// case LSL_DIVIDE : return evaluateExpression(exp->left, old) / evaluateExpression(exp->right, old); 169 case LSL_DIVIDE : return evaluateExpression(exp->left, old) / evaluateExpression(exp->right, old);
152// case LSL_MODULO : return evaluateExpression(exp->left, old) % evaluateExpression(exp->right, old); 170 case LSL_MODULO : return evaluateExpression(exp->left, old) % evaluateExpression(exp->right, old);
153 case LSL_MULTIPLY : return evaluateExpression(exp->left, old) * evaluateExpression(exp->right, old); 171#endif
154// case LSL_DOT_PRODUCT : break; 172 case LSL_MULTIPLY :
155// case LSL_CROSS_PRODUCT : break; 173#ifdef LUASL_DEBUG
156// case LSL_SUBTRACT : return evaluateExpression(exp->left, old) - evaluateExpression(exp->right, old); 174 printf(" * ");
157 case LSL_ADD : return evaluateExpression(exp->left, old) + evaluateExpression(exp->right, old); 175#endif
158// case LSL_CONCATENATE : break; 176 return evaluateExpression(exp->left, old) * evaluateExpression(exp->right, old);
159// case LSL_LEFT_SHIFT : return evaluateExpression(exp->left, old) << evaluateExpression(exp->right, old); 177#ifdef LUASL_USE_ENUM
160// case LSL_RIGHT_SHIFT : return evaluateExpression(exp->left, old) >> evaluateExpression(exp->right, old); 178 case LSL_DOT_PRODUCT : break;
161// case LSL_LESS_THAN : return evaluateExpression(exp->left, old) < evaluateExpression(exp->right, old); 179 case LSL_CROSS_PRODUCT : break;
162// case LSL_GREATER_THAN : return evaluateExpression(exp->left, old) > evaluateExpression(exp->right, old); 180 case LSL_SUBTRACT : return evaluateExpression(exp->left, old) - evaluateExpression(exp->right, old);
163// case LSL_LESS_EQUAL : return evaluateExpression(exp->left, old) <= evaluateExpression(exp->right, old); 181#endif
164// case LSL_GREATER_EQUAL : return evaluateExpression(exp->left, old) >= evaluateExpression(exp->right, old); 182 case LSL_ADD :
165// case LSL_EQUAL : return evaluateExpression(exp->left, old) == evaluateExpression(exp->right, old); 183#ifdef LUASL_DEBUG
166// case LSL_NOT_EQUAL : return evaluateExpression(exp->left, old) != evaluateExpression(exp->right, old); 184 printf(" + ");
167// case LSL_BIT_AND : return evaluateExpression(exp->left, old) & evaluateExpression(exp->right, old); 185#endif
168// case LSL_BIT_XOR : return evaluateExpression(exp->left, old) ^ evaluateExpression(exp->right, old); 186 return evaluateExpression(exp->left, old) + evaluateExpression(exp->right, old);
169// case LSL_BIT_OR : return evaluateExpression(exp->left, old) | evaluateExpression(exp->right, old); 187#ifdef LUASL_USE_ENUM
170// case LSL_BOOL_OR : return evaluateExpression(exp->left, old) || evaluateExpression(exp->right, old); 188 case LSL_CONCATENATE : break;
171// case LSL_BOOL_AND : return evaluateExpression(exp->left, old) && evaluateExpression(exp->right, old); 189 case LSL_LEFT_SHIFT : return evaluateExpression(exp->left, old) << evaluateExpression(exp->right, old);
190 case LSL_RIGHT_SHIFT : return evaluateExpression(exp->left, old) >> evaluateExpression(exp->right, old);
191 case LSL_LESS_THAN : return evaluateExpression(exp->left, old) < evaluateExpression(exp->right, old);
192 case LSL_GREATER_THAN : return evaluateExpression(exp->left, old) > evaluateExpression(exp->right, old);
193 case LSL_LESS_EQUAL : return evaluateExpression(exp->left, old) <= evaluateExpression(exp->right, old);
194 case LSL_GREATER_EQUAL : return evaluateExpression(exp->left, old) >= evaluateExpression(exp->right, old);
195 case LSL_EQUAL : return evaluateExpression(exp->left, old) == evaluateExpression(exp->right, old);
196 case LSL_NOT_EQUAL : return evaluateExpression(exp->left, old) != evaluateExpression(exp->right, old);
197 case LSL_BIT_AND : return evaluateExpression(exp->left, old) & evaluateExpression(exp->right, old);
198 case LSL_BIT_XOR : return evaluateExpression(exp->left, old) ^ evaluateExpression(exp->right, old);
199 case LSL_BIT_OR : return evaluateExpression(exp->left, old) | evaluateExpression(exp->right, old);
200 case LSL_BOOL_OR : return evaluateExpression(exp->left, old) || evaluateExpression(exp->right, old);
201 case LSL_BOOL_AND : return evaluateExpression(exp->left, old) && evaluateExpression(exp->right, old);
202#endif
172 } 203 }
173 break; 204 break;
174 } 205 }
175// case LSL_DO : 206#ifdef LUASL_USE_ENUM
176// case LSL_FOR : 207 case LSL_DO :
177// case LSL_IF : 208 case LSL_FOR :
178// case LSL_ELSE : 209 case LSL_IF :
179// case LSL_ELSEIF : 210 case LSL_ELSE :
180// case LSL_JUMP : 211 case LSL_ELSEIF :
181// case LSL_STATE_CHANGE : 212 case LSL_JUMP :
182// case LSL_WHILE : 213 case LSL_STATE_CHANGE :
183// case LSL_RETURN : 214 case LSL_WHILE :
184// case LSL_STATEMENT : 215 case LSL_RETURN :
185// case LSL_BLOCK : 216 case LSL_STATEMENT :
186// case LSL_PARAMETER : 217 case LSL_BLOCK :
187// case LSL_FUNCTION : 218 case LSL_PARAMETER :
188// case LSL_STATE : 219 case LSL_FUNCTION :
189// case LSL_SCRIPT : 220 case LSL_STATE :
190// break; 221 case LSL_SCRIPT :
222 break;
223#endif
191 } 224 }
192 225
193 return old; 226 return old;
@@ -198,45 +231,54 @@ void outputExpression(LSL_Expression *exp)
198{ 231{
199 switch(exp->type) 232 switch(exp->type)
200 { 233 {
201// case LSL_COMMENT : return; 234#ifdef LUASL_USE_ENUM
202// case LSL_TYPE : return; 235 case LSL_COMMENT : return;
203// case LSL_NAME : return; 236 case LSL_TYPE : return;
204// case LSL_IDENTIFIER : return; 237 case LSL_NAME : return;
205// case LSL_FLOAT : printf("%f", exp->value.floatValue); break; 238 case LSL_IDENTIFIER : return;
239 case LSL_FLOAT : printf("%f", exp->value.floatValue); break;
240#endif
206 case LSL_INTEGER : printf("%d", exp->value.integerValue); break; 241 case LSL_INTEGER : printf("%d", exp->value.integerValue); break;
207// case LSL_STRING : return; 242#ifdef LUASL_USE_ENUM
208// case LSL_KEY : return; 243 case LSL_STRING : return;
209// case LSL_VECTOR : return; 244 case LSL_KEY : return;
210// case LSL_ROTATION : return; 245 case LSL_VECTOR : return;
211// case LSL_LIST : return; 246 case LSL_ROTATION : return;
212// case LSL_LABEL : return; 247 case LSL_LIST : return;
248 case LSL_LABEL : return;
249#endif
213 case LSL_EXPRESSION : 250 case LSL_EXPRESSION :
214 outputExpression(exp->left); 251 outputExpression(exp->left);
215// printf(" %s ", LSL_Tokens[exp->expression].token); 252#ifdef LUASL_USE_ENUM
216printf(" # "); 253 printf(" %s ", LSL_Tokens[exp->expression - LSL_COMMA].token);
254#else
255 printf(" # ");
256#endif
217 outputExpression(exp->right); 257 outputExpression(exp->right);
218 break; 258 break;
219// case LSL_DO : return; 259#ifdef LUASL_USE_ENUM
220// case LSL_FOR : return; 260 case LSL_DO : return;
221// case LSL_IF : return; 261 case LSL_FOR : return;
222// case LSL_ELSE : return; 262 case LSL_IF : return;
223// case LSL_ELSEIF : return; 263 case LSL_ELSE : return;
224// case LSL_JUMP : return; 264 case LSL_ELSEIF : return;
225// case LSL_STATE_CHANGE : return; 265 case LSL_JUMP : return;
226// case LSL_WHILE : return; 266 case LSL_STATE_CHANGE : return;
227// case LSL_RETURN : return; 267 case LSL_WHILE : return;
228// case LSL_STATEMENT : return; 268 case LSL_RETURN : return;
229// case LSL_BLOCK : return; 269 case LSL_STATEMENT : return;
230// case LSL_PARAMETER : return; 270 case LSL_BLOCK : return;
231// case LSL_FUNCTION : return; 271 case LSL_PARAMETER : return;
232// case LSL_STATE : return; 272 case LSL_FUNCTION : return;
233// case LSL_SCRIPT : return; 273 case LSL_STATE : return;
274 case LSL_SCRIPT : return;
275#endif
234 } 276 }
235} 277}
236 278
237void convertExpression2Lua(LSL_Expression *exp) 279void convertExpression2Lua(LSL_Expression *exp)
238{ 280{
239/* 281#ifdef LUASL_USE_ENUM
240 switch(exp->type) 282 switch(exp->type)
241 { 283 {
242 case LSL_COMMENT : return; 284 case LSL_COMMENT : return;
@@ -268,7 +310,7 @@ void convertExpression2Lua(LSL_Expression *exp)
268 case LSL_STATE : return; 310 case LSL_STATE : return;
269 case LSL_SCRIPT : return; 311 case LSL_SCRIPT : return;
270 } 312 }
271*/ 313#endif
272} 314}
273 315
274int yyerror(const char *msg) 316int yyerror(const char *msg)
@@ -277,3 +319,24 @@ int yyerror(const char *msg)
277 return 0; 319 return 0;
278} 320}
279 321
322int main(void)
323{
324 const char test[] = " 4 + 2 * 10 + 3 * ( 5 + 1 )";
325 LSL_Expression *exp;
326
327 if ((exp = newTree(test)))
328 {
329 int result = evaluateExpression(exp, 0);
330
331#ifdef LUASL_DEBUG
332 printf("\n");
333#endif
334 printf("Result of '%s' is %d\n", test, result);
335 outputExpression(exp);
336 printf("\n");
337 burnLSLExpression(exp);
338 }
339
340 return 0;
341}
342
diff --git a/LuaSL/src/LuaSL_LSL_tree.h b/LuaSL/src/LuaSL_LSL_tree.h
index 7973509..42cf0ac 100644
--- a/LuaSL/src/LuaSL_LSL_tree.h
+++ b/LuaSL/src/LuaSL_LSL_tree.h
@@ -8,7 +8,17 @@
8#define YY_NO_UNISTD_H 1 8#define YY_NO_UNISTD_H 1
9#endif // YY_NO_UNISTD_H 9#endif // YY_NO_UNISTD_H
10 10
11//#define LUASL_USE_ENUM
12#define LUASL_DEBUG
13
14#ifndef LUASL_USE_ENUM
11#include "LuaSL_yaccer.tab.h" 15#include "LuaSL_yaccer.tab.h"
16#endif
17
18#define YYERRCODE 256
19#define YYDEBUG 1
20extern int yydebug;
21
12 22
13// http://w-hat.com/stackdepth is a useful discussion about some aspects of the LL parser. 23// http://w-hat.com/stackdepth is a useful discussion about some aspects of the LL parser.
14 24
@@ -22,12 +32,12 @@ typedef enum
22 LSL_CREATION = 16 32 LSL_CREATION = 16
23} LSL_Flags; 33} LSL_Flags;
24 34
25/* 35#ifdef LUASL_USE_ENUM
26typedef enum // In order of precedence, high to low. 36typedef enum // In order of precedence, high to low.
27 // Left to right, unless oterwise stated. 37 // Left to right, unless oterwise stated.
28 // According to http://wiki.secondlife.com/wiki/Category:LSL_Operators 38 // According to http://wiki.secondlife.com/wiki/Category:LSL_Operators
29{ 39{
30 LSL_COMMA, 40 LSL_COMMA = 257,
31 LSL_INCREMENT_PRE, // Right to left. 41 LSL_INCREMENT_PRE, // Right to left.
32 LSL_INCREMENT_POST, // Right to left. 42 LSL_INCREMENT_POST, // Right to left.
33 LSL_DECREMENT_PRE, // Right to left. 43 LSL_DECREMENT_PRE, // Right to left.
@@ -72,9 +82,9 @@ typedef enum // In order of precedence, high to low.
72 LSL_BOOL_OR, 82 LSL_BOOL_OR,
73 LSL_BOOL_AND 83 LSL_BOOL_AND
74} LSL_Operation; 84} LSL_Operation;
75*/ 85#else
76
77typedef int LSL_Operation; 86typedef int LSL_Operation;
87#endif
78 88
79typedef struct 89typedef struct
80{ 90{
@@ -137,10 +147,11 @@ LSL_Operator LSL_Tokens[] =
137}; 147};
138#endif 148#endif
139 149
140/* 150
151#ifdef LUASL_USE_ENUM
141typedef enum 152typedef enum
142{ 153{
143 LSL_COMMENT, 154 LSL_COMMENT = (LSL_BOOL_AND + 1),
144 LSL_TYPE, 155 LSL_TYPE,
145 LSL_NAME, 156 LSL_NAME,
146 LSL_IDENTIFIER, 157 LSL_IDENTIFIER,
@@ -169,11 +180,10 @@ typedef enum
169 LSL_STATE, 180 LSL_STATE,
170 LSL_SCRIPT 181 LSL_SCRIPT
171} LSL_Type; 182} LSL_Type;
172*/ 183#else
173
174typedef int LSL_Type; 184typedef int LSL_Type;
175#define LSL_EXPRESSION 1 185#define LSL_EXPRESSION 1
176 186#endif
177 187
178#ifdef LSL_Keywords_define 188#ifdef LSL_Keywords_define
179char *LSL_Keywords[] = 189char *LSL_Keywords[] =
diff --git a/LuaSL/src/LuaSL_lexer.l b/LuaSL/src/LuaSL_lexer.l
index 478e62c..5e7d930 100644
--- a/LuaSL/src/LuaSL_lexer.l
+++ b/LuaSL/src/LuaSL_lexer.l
@@ -3,26 +3,35 @@
3#define excludeLexer 3#define excludeLexer
4#include "LuaSL_LSL_tree.h" 4#include "LuaSL_LSL_tree.h"
5 5
6#ifdef LUASL_DEBUG
7 #undef ECHO
8 #define ECHO printf ("[%s]\n", yytext)
9#else
10 #undef ECHO
11 #define ECHO {}
12#endif
13
14
6%} 15%}
7 16
8%option reentrant noyywrap never-interactive nounistd 17%option reentrant noyywrap never-interactive nounistd
9%option bison-bridge 18%option bison-bridge
10 19
11SPACE [ \r\n\t]* 20SPACE [ \r\n\t]*
21NAME [a-zA-Z_][a-zA-Z0-9_]*
12NUMBER [0-9]+ 22NUMBER [0-9]+
13NAME [a-zA-Z][a-zA-Z0-9]*
14 23
15%% 24%%
16 25
17{SPACE} { /* Skip blanks. */ } 26{SPACE} { ECHO; /* Skip blanks. */ }
18{NUMBER} { yylval->integerValue = atoi(yytext); return LSL_INTEGER; } 27{NAME} { ECHO; /* yylval->nameValue=strdup(yytext); return LSL_NAME; */ }
19{NAME} { /* yylval->nameValue=strdup(yytext); return LSL_NAME; */ } 28{NUMBER} { ECHO; yylval->integerValue = atoi(yytext); return LSL_INTEGER; }
20 29
21"*" { return LSL_MULTIPLY; } 30"(" { ECHO; return LSL_PARENTHESIS_OPEN; }
22"+" { return LSL_ADD; } 31")" { ECHO; return LSL_PARENTHESIS_CLOSE; }
23"(" { return LSL_PARENTHESIS_OPEN; } 32"*" { ECHO; return LSL_MULTIPLY; }
24")" { return LSL_PARENTHESIS_CLOSE; } 33"+" { ECHO; return LSL_ADD; }
25. { /* This should return an "unknown character" error */ } 34. { ECHO; printf(" unexpected character.\n"); }
26 35
27%% 36%%
28 37
diff --git a/LuaSL/src/LuaSL_yaccer.y b/LuaSL/src/LuaSL_yaccer.y
index 897a83e..414b5e9 100644
--- a/LuaSL/src/LuaSL_yaccer.y
+++ b/LuaSL/src/LuaSL_yaccer.y
@@ -2,6 +2,9 @@
2 2
3#include "LuaSL_LSL_tree.h" 3#include "LuaSL_LSL_tree.h"
4 4
5//extern char *yytext;
6//#define YYDEBUG_LEXER_TEXT yytext
7
5%} 8%}
6 9
7%define api.pure 10%define api.pure
@@ -25,9 +28,9 @@ input:
25 ; 28 ;
26 29
27expr: 30expr:
28 expr LSL_ADD expr { $$ = addOperation( LSL_ADD, $1, $3 ); } 31 LSL_PARENTHESIS_OPEN expr LSL_PARENTHESIS_CLOSE { $$ = $2; }
29 | expr LSL_MULTIPLY expr { $$ = addOperation( LSL_MULTIPLY, $1, $3 ); } 32 | expr LSL_MULTIPLY expr { $$ = addOperation( LSL_MULTIPLY, $1, $3 ); }
30 | LSL_PARENTHESIS_OPEN expr LSL_PARENTHESIS_CLOSE { $$ = $2; } 33 | expr LSL_ADD expr { $$ = addOperation( LSL_ADD, $1, $3 ); }
31 | LSL_INTEGER { $$ = addInteger($1); } 34 | LSL_INTEGER { $$ = addInteger($1); }
32; 35;
33 36