113 lines
3.0 KiB
Diff
113 lines
3.0 KiB
Diff
|
diff --git a/src/gdlc.i.g b/src/gdlc.i.g
|
||
|
index e66902d..1c648c8 100644
|
||
|
--- a/src/gdlc.i.g
|
||
|
+++ b/src/gdlc.i.g
|
||
|
@@ -170,7 +170,7 @@ public:
|
||
|
static bool SearchCompilePro(const std::string& pro, bool searchForPro);
|
||
|
static int GetFunIx( ProgNodeP);
|
||
|
static int GetFunIx( const std::string& subName);
|
||
|
- static int GetProIx( ProgNodeP);//const std::string& subName);
|
||
|
+ static int GetProIx( ProgNodeP, bool throwImmediately=false);//const std::string& subName);
|
||
|
static int GetProIx( const std::string& subName);
|
||
|
DStructGDL* ObjectStruct( DObjGDL* self, ProgNodeP mp);
|
||
|
void SetRootR( ProgNodeP tt, DotAccessDescT* aD, BaseGDL* r, ArrayIndexListT* aL);
|
||
|
@@ -184,7 +184,7 @@ public:
|
||
|
|
||
|
private:
|
||
|
|
||
|
- static void SetProIx( ProgNodeP f); // triggers read/compile
|
||
|
+ static void SetProIx( ProgNodeP f, bool throwImmediately=false); // triggers read/compile
|
||
|
static void AdjustTypes( BaseGDL*&, BaseGDL*&);
|
||
|
|
||
|
|
||
|
@@ -979,18 +979,6 @@ interactive returns[ RetCode retCode]
|
||
|
)+
|
||
|
;
|
||
|
|
||
|
-// execute statement
|
||
|
-execute returns[ RetCode retCode]
|
||
|
-{
|
||
|
-// RetCode retCode;
|
||
|
- ValueGuard<bool> guard( interruptEnable);
|
||
|
- interruptEnable = false;
|
||
|
-
|
||
|
- return statement_list(_t);
|
||
|
-}
|
||
|
- : retCode=statement_list
|
||
|
- ;
|
||
|
-
|
||
|
// used to call functions
|
||
|
// same as statement list, but different behaviour for returncodes
|
||
|
call_fun returns[ BaseGDL* res]
|
||
|
@@ -1083,24 +1071,7 @@ call_pro
|
||
|
;
|
||
|
|
||
|
|
||
|
-// used on many occasions
|
||
|
-statement_list returns[ RetCode retCode]
|
||
|
-{
|
||
|
- for (; _t != NULL;) {
|
||
|
-
|
||
|
- retCode=statement(_t);
|
||
|
- _t = _retTree;
|
||
|
-
|
||
|
- if( retCode != RC_OK) break; // break out if non-regular
|
||
|
- }
|
||
|
- _retTree = _t;
|
||
|
- return retCode;
|
||
|
-}
|
||
|
- : (retCode=statement
|
||
|
- )+
|
||
|
- ;
|
||
|
-
|
||
|
-statement returns[ RetCode retCode]
|
||
|
+statement [bool throwImmediately=false] returns[ RetCode retCode]
|
||
|
{
|
||
|
// ProgNodeP& actPos = statement_AST_in;
|
||
|
assert( _t != NULL);
|
||
|
@@ -1121,7 +1092,7 @@ statement returns[ RetCode retCode]
|
||
|
// track actual line number
|
||
|
callStack.back()->SetLineNumber( last->getLine());
|
||
|
|
||
|
- retCode = last->Run(); // Run() sets _retTree
|
||
|
+ retCode = last->Run(throwImmediately); // Run() sets _retTree
|
||
|
|
||
|
}
|
||
|
while(
|
||
|
@@ -1456,6 +1427,35 @@ statement returns[ RetCode retCode]
|
||
|
} // catch [ GDLException& e]
|
||
|
|
||
|
|
||
|
+// used on many occasions
|
||
|
+statement_list [bool throwImmediately=false] returns[ RetCode retCode]
|
||
|
+{
|
||
|
+ for (; _t != NULL;) {
|
||
|
+
|
||
|
+ retCode=statement(_t, throwImmediately);
|
||
|
+ _t = _retTree;
|
||
|
+
|
||
|
+ if( retCode != RC_OK) break; // break out if non-regular
|
||
|
+ }
|
||
|
+ _retTree = _t;
|
||
|
+ return retCode;
|
||
|
+}
|
||
|
+ : (retCode=statement[throwImmediately]
|
||
|
+ )+
|
||
|
+ ;
|
||
|
+
|
||
|
+// execute statement
|
||
|
+execute [bool throwImmediately=false] returns[ RetCode retCode]
|
||
|
+{
|
||
|
+// RetCode retCode;
|
||
|
+ ValueGuard<bool> guard( interruptEnable);
|
||
|
+ interruptEnable = false;
|
||
|
+
|
||
|
+// return statement_list(_t, throwImmediately);
|
||
|
+}
|
||
|
+ : retCode=statement_list[throwImmediately]
|
||
|
+ ;
|
||
|
+
|
||
|
|
||
|
|
||
|
|