[vala/wip/transform] Fix result var for pre/post conditions



commit 2d7d95d7596e08ffbf27f79783d04a3327cf2dba
Author: Luca Bruno <lucabru src gnome org>
Date:   Sat May 4 11:30:05 2013 +0200

    Fix result var for pre/post conditions

 vala/valasemanticanalyzer.vala |    2 +-
 vala/valasubroutine.vala       |   12 +++++++++++-
 2 files changed, 12 insertions(+), 2 deletions(-)
---
diff --git a/vala/valasemanticanalyzer.vala b/vala/valasemanticanalyzer.vala
index 840b8ed..389d508 100644
--- a/vala/valasemanticanalyzer.vala
+++ b/vala/valasemanticanalyzer.vala
@@ -141,7 +141,7 @@ public class Vala.SemanticAnalyzer : CodeVisitor {
        }
 
        public bool is_local_symbol (Symbol sym) {
-               if ((sym is LocalVariable || sym is Constant) && sym.parent_symbol is Block) {
+               if (sym is LocalVariable || (sym is Constant && sym.parent_symbol is Block)) {
                        return true;
                }
                return false;
diff --git a/vala/valasubroutine.vala b/vala/valasubroutine.vala
index 0ef8bf3..14e2b96 100644
--- a/vala/valasubroutine.vala
+++ b/vala/valasubroutine.vala
@@ -32,10 +32,20 @@ public abstract class Vala.Subroutine : Symbol {
        /**
         * Specifies the generated `result` variable for postconditions.
         */
-       public LocalVariable result_var { get; set; }
+       public LocalVariable result_var {
+               get { return _result_var; }
+               set {
+                       _result_var = value;
+                       if (_result_var != null) {
+                               scope.add ("result", _result_var);
+                       }
+               }
+       }
 
        public abstract bool has_result { get; }
 
+       private LocalVariable _result_var;
+
        protected Subroutine (string? name, SourceReference? source_reference, Comment? comment = null) {
                base (name, source_reference, comment);
        }


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]