diff options
Diffstat (limited to 'linden/indra/lscript/lscript_compile/lscript_tree.cpp')
-rw-r--r-- | linden/indra/lscript/lscript_compile/lscript_tree.cpp | 31 |
1 files changed, 26 insertions, 5 deletions
diff --git a/linden/indra/lscript/lscript_compile/lscript_tree.cpp b/linden/indra/lscript/lscript_compile/lscript_tree.cpp index 70d8195..2a41d91 100644 --- a/linden/indra/lscript/lscript_compile/lscript_tree.cpp +++ b/linden/indra/lscript/lscript_compile/lscript_tree.cpp | |||
@@ -4,7 +4,7 @@ | |||
4 | * | 4 | * |
5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ | 5 | * $LicenseInfo:firstyear=2002&license=viewergpl$ |
6 | * | 6 | * |
7 | * Copyright (c) 2002-2008, Linden Research, Inc. | 7 | * Copyright (c) 2002-2009, Linden Research, Inc. |
8 | * | 8 | * |
9 | * Second Life Viewer Source Code | 9 | * Second Life Viewer Source Code |
10 | * The source code in this file ("Source Code") is provided by Linden Lab | 10 | * The source code in this file ("Source Code") is provided by Linden Lab |
@@ -46,7 +46,8 @@ | |||
46 | 46 | ||
47 | static void print_cil_box(LLFILE* fp, LSCRIPTType type) | 47 | static void print_cil_box(LLFILE* fp, LSCRIPTType type) |
48 | { | 48 | { |
49 | switch(type) | 49 | |
50 | switch(type) | ||
50 | { | 51 | { |
51 | case LST_INTEGER: | 52 | case LST_INTEGER: |
52 | fprintf(fp, "box [mscorlib]System.Int32\n"); | 53 | fprintf(fp, "box [mscorlib]System.Int32\n"); |
@@ -1257,10 +1258,10 @@ static void print_cil_init_variable(LLFILE* fp, LSCRIPTType type) | |||
1257 | fprintf(fp, "call class [ScriptTypes]LindenLab.SecondLife.Vector class [LslUserScript]LindenLab.SecondLife.LslUserScript::'CreateVector'(float32, float32, float32)\n"); | 1258 | fprintf(fp, "call class [ScriptTypes]LindenLab.SecondLife.Vector class [LslUserScript]LindenLab.SecondLife.LslUserScript::'CreateVector'(float32, float32, float32)\n"); |
1258 | break; | 1259 | break; |
1259 | case LST_QUATERNION: | 1260 | case LST_QUATERNION: |
1260 | fprintf(fp, "ldc.r8 1\n"); | ||
1261 | fprintf(fp, "ldc.r8 0\n"); | 1261 | fprintf(fp, "ldc.r8 0\n"); |
1262 | fprintf(fp, "ldc.r8 0\n"); | 1262 | fprintf(fp, "ldc.r8 0\n"); |
1263 | fprintf(fp, "ldc.r8 0\n"); | 1263 | fprintf(fp, "ldc.r8 0\n"); |
1264 | fprintf(fp, "ldc.r8 1\n"); | ||
1264 | fprintf(fp, "call class [ScriptTypes]LindenLab.SecondLife.Quaternion class [LslUserScript]LindenLab.SecondLife.LslUserScript::'CreateQuaternion'(float32, float32, float32, float32)\n"); | 1265 | fprintf(fp, "call class [ScriptTypes]LindenLab.SecondLife.Quaternion class [LslUserScript]LindenLab.SecondLife.LslUserScript::'CreateQuaternion'(float32, float32, float32, float32)\n"); |
1265 | break; | 1266 | break; |
1266 | case LST_LIST: | 1267 | case LST_LIST: |
@@ -3517,7 +3518,7 @@ void LLScriptRezEvent::recurse(LLFILE *fp, S32 tabs, S32 tabsize, LSCRIPTCompile | |||
3517 | fprintf(fp, " )\n"); | 3518 | fprintf(fp, " )\n"); |
3518 | break; | 3519 | break; |
3519 | case LSCP_SCOPE_PASS1: | 3520 | case LSCP_SCOPE_PASS1: |
3520 | checkForDuplicateHandler(fp, this, scope, "rez"); | 3521 | checkForDuplicateHandler(fp, this, scope, "on_rez"); |
3521 | if (scope->checkEntry(mStartParam->mName)) | 3522 | if (scope->checkEntry(mStartParam->mName)) |
3522 | { | 3523 | { |
3523 | gErrorToText.writeError(fp, this, LSERROR_DUPLICATE_NAME); | 3524 | gErrorToText.writeError(fp, this, LSERROR_DUPLICATE_NAME); |
@@ -8689,8 +8690,12 @@ void LLScriptIf::recurse(LLFILE *fp, S32 tabs, S32 tabsize, LSCRIPTCompilePass p | |||
8689 | break; | 8690 | break; |
8690 | case LSCP_TYPE: | 8691 | case LSCP_TYPE: |
8691 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8692 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
8693 | if (type == LST_NULL) | ||
8694 | { | ||
8695 | gErrorToText.writeError(fp, mExpression, LSERROR_TYPE_MISMATCH); | ||
8696 | } | ||
8692 | mType = type; | 8697 | mType = type; |
8693 | mStatement->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8698 | mStatement->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
8694 | break; | 8699 | break; |
8695 | case LSCP_EMIT_BYTE_CODE: | 8700 | case LSCP_EMIT_BYTE_CODE: |
8696 | { | 8701 | { |
@@ -8770,6 +8775,10 @@ void LLScriptIfElse::recurse(LLFILE *fp, S32 tabs, S32 tabsize, LSCRIPTCompilePa | |||
8770 | break; | 8775 | break; |
8771 | case LSCP_TYPE: | 8776 | case LSCP_TYPE: |
8772 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8777 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
8778 | if (type == LST_NULL) | ||
8779 | { | ||
8780 | gErrorToText.writeError(fp, mExpression, LSERROR_TYPE_MISMATCH); | ||
8781 | } | ||
8773 | mType = type; | 8782 | mType = type; |
8774 | mStatement1->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8783 | mStatement1->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
8775 | mStatement2->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8784 | mStatement2->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
@@ -8869,6 +8878,10 @@ void LLScriptFor::recurse(LLFILE *fp, S32 tabs, S32 tabsize, LSCRIPTCompilePass | |||
8869 | if(mSequence) | 8878 | if(mSequence) |
8870 | mSequence->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8879 | mSequence->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
8871 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8880 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
8881 | if (type == LST_NULL) | ||
8882 | { | ||
8883 | gErrorToText.writeError(fp, mExpression, LSERROR_TYPE_MISMATCH); | ||
8884 | } | ||
8872 | mType = type; | 8885 | mType = type; |
8873 | if(mExpressionList) | 8886 | if(mExpressionList) |
8874 | mExpressionList->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8887 | mExpressionList->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
@@ -8968,6 +8981,10 @@ void LLScriptDoWhile::recurse(LLFILE *fp, S32 tabs, S32 tabsize, LSCRIPTCompileP | |||
8968 | case LSCP_TYPE: | 8981 | case LSCP_TYPE: |
8969 | mStatement->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8982 | mStatement->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
8970 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 8983 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
8984 | if (type == LST_NULL) | ||
8985 | { | ||
8986 | gErrorToText.writeError(fp, mExpression, LSERROR_TYPE_MISMATCH); | ||
8987 | } | ||
8971 | mType = type; | 8988 | mType = type; |
8972 | break; | 8989 | break; |
8973 | case LSCP_EMIT_BYTE_CODE: | 8990 | case LSCP_EMIT_BYTE_CODE: |
@@ -9039,6 +9056,10 @@ void LLScriptWhile::recurse(LLFILE *fp, S32 tabs, S32 tabsize, LSCRIPTCompilePas | |||
9039 | break; | 9056 | break; |
9040 | case LSCP_TYPE: | 9057 | case LSCP_TYPE: |
9041 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 9058 | mExpression->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
9059 | if (type == LST_NULL) | ||
9060 | { | ||
9061 | gErrorToText.writeError(fp, mExpression, LSERROR_TYPE_MISMATCH); | ||
9062 | } | ||
9042 | mType = type; | 9063 | mType = type; |
9043 | mStatement->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); | 9064 | mStatement->recurse(fp, tabs, tabsize, pass, ptype, prunearg, scope, type, basetype, count, chunk, heap, stacksize, entry, entrycount, NULL); |
9044 | break; | 9065 | break; |