diff options
Diffstat (limited to 'LuaSL')
-rw-r--r-- | LuaSL/src/LuaSL_compile.c | 51 |
1 files changed, 43 insertions, 8 deletions
diff --git a/LuaSL/src/LuaSL_compile.c b/LuaSL/src/LuaSL_compile.c index d68161a..d13df68 100644 --- a/LuaSL/src/LuaSL_compile.c +++ b/LuaSL/src/LuaSL_compile.c | |||
@@ -7,6 +7,7 @@ static LSL_Leaf *evaluateNoToken(LSL_Leaf *content, LSL_Leaf *left, LSL_Leaf *ri | |||
7 | static LSL_Leaf *evaluateOperationToken(LSL_Leaf *content, LSL_Leaf *left, LSL_Leaf *right); | 7 | static LSL_Leaf *evaluateOperationToken(LSL_Leaf *content, LSL_Leaf *left, LSL_Leaf *right); |
8 | static LSL_Leaf *eveluateParenthesisToken(LSL_Leaf *content, LSL_Leaf *left, LSL_Leaf *right); | 8 | static LSL_Leaf *eveluateParenthesisToken(LSL_Leaf *content, LSL_Leaf *left, LSL_Leaf *right); |
9 | static LSL_Leaf *evaluateStatementToken(LSL_Leaf *content, LSL_Leaf *left, LSL_Leaf *right); | 9 | static LSL_Leaf *evaluateStatementToken(LSL_Leaf *content, LSL_Leaf *left, LSL_Leaf *right); |
10 | static void outputBitOp(FILE *file, outputMode mode, LSL_Leaf *leaf); | ||
10 | static void outputBlockToken(FILE *file, outputMode mode, LSL_Leaf *content); | 11 | static void outputBlockToken(FILE *file, outputMode mode, LSL_Leaf *content); |
11 | static void outputCrementsToken(FILE *file, outputMode mode, LSL_Leaf *content); | 12 | static void outputCrementsToken(FILE *file, outputMode mode, LSL_Leaf *content); |
12 | static void outputFloatToken(FILE *file, outputMode mode, LSL_Leaf *content); | 13 | static void outputFloatToken(FILE *file, outputMode mode, LSL_Leaf *content); |
@@ -39,9 +40,9 @@ LSL_Token LSL_Tokens[] = | |||
39 | // LUA - "and" returns its first argument if it is false, otherwise, it returns its second argument. "or" returns its first argument if it is not false, otherwise it returns its second argument. | 40 | // LUA - "and" returns its first argument if it is false, otherwise, it returns its second argument. "or" returns its first argument if it is not false, otherwise it returns its second argument. |
40 | // Note that the above means that "and/or" can return any type. | 41 | // Note that the above means that "and/or" can return any type. |
41 | {LSL_BOOL_OR, ST_BOOLEAN, "||", LSL_RIGHT2LEFT, NULL, evaluateOperationToken}, | 42 | {LSL_BOOL_OR, ST_BOOLEAN, "||", LSL_RIGHT2LEFT, NULL, evaluateOperationToken}, |
42 | {LSL_BIT_OR, ST_BITWISE, "|", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, | 43 | {LSL_BIT_OR, ST_BITWISE, "|", LSL_LEFT2RIGHT, outputBitOp, evaluateOperationToken}, |
43 | {LSL_BIT_XOR, ST_BITWISE, "^", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, | 44 | {LSL_BIT_XOR, ST_BITWISE, "^", LSL_LEFT2RIGHT, outputBitOp, evaluateOperationToken}, |
44 | {LSL_BIT_AND, ST_BITWISE, "&", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, | 45 | {LSL_BIT_AND, ST_BITWISE, "&", LSL_LEFT2RIGHT, outputBitOp, evaluateOperationToken}, |
45 | // QUIRK - Booleans and conditionals are executed right to left. Or maybe not, depending on who you believe. | 46 | // QUIRK - Booleans and conditionals are executed right to left. Or maybe not, depending on who you believe. |
46 | {LSL_NOT_EQUAL, ST_EQUALITY, "!=", LSL_RIGHT2LEFT, NULL, evaluateOperationToken}, | 47 | {LSL_NOT_EQUAL, ST_EQUALITY, "!=", LSL_RIGHT2LEFT, NULL, evaluateOperationToken}, |
47 | {LSL_EQUAL, ST_EQUALITY, "==", LSL_RIGHT2LEFT, NULL, evaluateOperationToken}, | 48 | {LSL_EQUAL, ST_EQUALITY, "==", LSL_RIGHT2LEFT, NULL, evaluateOperationToken}, |
@@ -51,8 +52,8 @@ LSL_Token LSL_Tokens[] = | |||
51 | {LSL_LESS_THAN, ST_COMPARISON, "<", LSL_RIGHT2LEFT, NULL, evaluateOperationToken}, | 52 | {LSL_LESS_THAN, ST_COMPARISON, "<", LSL_RIGHT2LEFT, NULL, evaluateOperationToken}, |
52 | // LUA - comparisons are always false if they are different types. Tables, userdata, and functions are compared by reference. Strings campare in alphabetical order, depending on current locale. | 53 | // LUA - comparisons are always false if they are different types. Tables, userdata, and functions are compared by reference. Strings campare in alphabetical order, depending on current locale. |
53 | // LUA - really only has three conditionals, as it translates a ~= b to not (a == b), a > b to b < a, and a >= b to b <= a. | 54 | // LUA - really only has three conditionals, as it translates a ~= b to not (a == b), a > b to b < a, and a >= b to b <= a. |
54 | {LSL_RIGHT_SHIFT, ST_BITWISE, ">>", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, | 55 | {LSL_RIGHT_SHIFT, ST_BITWISE, ">>", LSL_LEFT2RIGHT, outputBitOp, evaluateOperationToken}, |
55 | {LSL_LEFT_SHIFT, ST_BITWISE, "<<", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, | 56 | {LSL_LEFT_SHIFT, ST_BITWISE, "<<", LSL_LEFT2RIGHT, outputBitOp, evaluateOperationToken}, |
56 | {LSL_CONCATENATE, ST_ADD, "+", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, | 57 | {LSL_CONCATENATE, ST_ADD, "+", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, |
57 | {LSL_ADD, ST_ADD, "+", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, | 58 | {LSL_ADD, ST_ADD, "+", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, |
58 | {LSL_SUBTRACT, ST_SUBTRACT, "-", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, | 59 | {LSL_SUBTRACT, ST_SUBTRACT, "-", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, |
@@ -63,7 +64,7 @@ LSL_Token LSL_Tokens[] = | |||
63 | {LSL_DIVIDE, ST_MULTIPLY, "/", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, | 64 | {LSL_DIVIDE, ST_MULTIPLY, "/", LSL_LEFT2RIGHT, NULL, evaluateOperationToken}, |
64 | {LSL_NEGATION, ST_NEGATE, "-", LSL_RIGHT2LEFT | LSL_UNARY, NULL, evaluateOperationToken}, | 65 | {LSL_NEGATION, ST_NEGATE, "-", LSL_RIGHT2LEFT | LSL_UNARY, NULL, evaluateOperationToken}, |
65 | {LSL_BOOL_NOT, ST_BOOL_NOT, "!", LSL_RIGHT2LEFT | LSL_UNARY, NULL, evaluateOperationToken}, | 66 | {LSL_BOOL_NOT, ST_BOOL_NOT, "!", LSL_RIGHT2LEFT | LSL_UNARY, NULL, evaluateOperationToken}, |
66 | {LSL_BIT_NOT, ST_BIT_NOT, "~", LSL_RIGHT2LEFT | LSL_UNARY, NULL, evaluateOperationToken}, | 67 | {LSL_BIT_NOT, ST_BIT_NOT, "~", LSL_RIGHT2LEFT | LSL_UNARY, outputBitOp, evaluateOperationToken}, |
67 | 68 | ||
68 | // LUA precedence - (it has no bit operators, at least not until 5.2, but LuaJIT has them.) | 69 | // LUA precedence - (it has no bit operators, at least not until 5.2, but LuaJIT has them.) |
69 | // or | 70 | // or |
@@ -1515,7 +1516,8 @@ static void outputLeaf(FILE *file, outputMode mode, LSL_Leaf *leaf) | |||
1515 | { | 1516 | { |
1516 | if (leaf) | 1517 | if (leaf) |
1517 | { | 1518 | { |
1518 | outputLeaf(file, mode, leaf->left); | 1519 | if ((OM_LUA == mode) &&(ST_BITWISE != leaf->toKen->subType)) |
1520 | outputLeaf(file, mode, leaf->left); | ||
1519 | #if LUASL_DIFF_CHECK | 1521 | #if LUASL_DIFF_CHECK |
1520 | if ((!(LSL_NOIGNORE & leaf->toKen->flags)) && (leaf->ignorable)) | 1522 | if ((!(LSL_NOIGNORE & leaf->toKen->flags)) && (leaf->ignorable)) |
1521 | fwrite(eina_strbuf_string_get(leaf->ignorable), 1, eina_strbuf_length_get(leaf->ignorable), file); | 1523 | fwrite(eina_strbuf_string_get(leaf->ignorable), 1, eina_strbuf_length_get(leaf->ignorable), file); |
@@ -1552,7 +1554,8 @@ static void outputLeaf(FILE *file, outputMode mode, LSL_Leaf *leaf) | |||
1552 | else | 1554 | else |
1553 | fprintf(file, "%s", leaf->toKen->toKen); | 1555 | fprintf(file, "%s", leaf->toKen->toKen); |
1554 | } | 1556 | } |
1555 | outputLeaf(file, mode, leaf->right); | 1557 | if ((OM_LUA == mode) &&(ST_BITWISE != leaf->toKen->subType)) |
1558 | outputLeaf(file, mode, leaf->right); | ||
1556 | } | 1559 | } |
1557 | } | 1560 | } |
1558 | 1561 | ||
@@ -1857,6 +1860,37 @@ static void outputRawStatement(FILE *file, outputMode mode, LSL_Statement *state | |||
1857 | } | 1860 | } |
1858 | } | 1861 | } |
1859 | 1862 | ||
1863 | static void outputBitOp(FILE *file, outputMode mode, LSL_Leaf *leaf) | ||
1864 | { | ||
1865 | if (OM_LSL == mode) | ||
1866 | outputLeaf(file, mode, leaf); | ||
1867 | else if (OM_LUA == mode) | ||
1868 | { | ||
1869 | /* | ||
1870 | swap = (integer)((string)pkey) & 1; | ||
1871 | bit.band(swap= --[[(integer)]] ( --[[(string)]] pkey), 1) ; | ||
1872 | */ | ||
1873 | |||
1874 | switch (leaf->toKen->type) | ||
1875 | { | ||
1876 | case LSL_BIT_AND : fprintf(file, " bit.band("); break; | ||
1877 | case LSL_BIT_OR : fprintf(file, " bit.bor("); break; | ||
1878 | case LSL_BIT_XOR : fprintf(file, " bit.xor("); break; | ||
1879 | case LSL_BIT_NOT : fprintf(file, " bit.bnot("); break; | ||
1880 | case LSL_LEFT_SHIFT : fprintf(file, " bit.lshift("); break; | ||
1881 | case LSL_RIGHT_SHIFT : fprintf(file, " bit.rshift("); break; | ||
1882 | default : break; | ||
1883 | } | ||
1884 | outputLeaf(file, mode, leaf->left); | ||
1885 | if (LSL_BIT_NOT != leaf->toKen->type) | ||
1886 | { | ||
1887 | fprintf(file, ", "); | ||
1888 | outputLeaf(file, mode, leaf->right); | ||
1889 | } | ||
1890 | fprintf(file, ") "); | ||
1891 | } | ||
1892 | } | ||
1893 | |||
1860 | static void outputBlockToken(FILE *file, outputMode mode, LSL_Leaf *content) | 1894 | static void outputBlockToken(FILE *file, outputMode mode, LSL_Leaf *content) |
1861 | { | 1895 | { |
1862 | if (content) | 1896 | if (content) |
@@ -2223,6 +2257,7 @@ static boolean doneParsing(LuaSL_compiler *compiler) | |||
2223 | if (out) | 2257 | if (out) |
2224 | { | 2258 | { |
2225 | fprintf(out, "--// Pre declared helper stuff.\n"); | 2259 | fprintf(out, "--// Pre declared helper stuff.\n"); |
2260 | fprintf(out, "local bit = require(\"bit\")\n"); | ||
2226 | fprintf(out, "function preDecrement(x) x = x - 1; return x; end;\n"); | 2261 | fprintf(out, "function preDecrement(x) x = x - 1; return x; end;\n"); |
2227 | fprintf(out, "function preIncrement(x) x = x + 1; return x; end;\n"); | 2262 | fprintf(out, "function preIncrement(x) x = x + 1; return x; end;\n"); |
2228 | fprintf(out, "function postDecrement(x) x = x - 1; return x; end;\n"); | 2263 | fprintf(out, "function postDecrement(x) x = x - 1; return x; end;\n"); |