[vala/0.40] parser: Improve source-location for local Constant declarations



commit 995638dd678ee33e496b27800ac7f0ccd08c6c4c
Author: Rico Tzschichholz <ricotz ubuntu com>
Date:   Wed Apr 10 14:12:21 2019 +0200

    parser: Improve source-location for local Constant declarations

 vala/valaparser.vala | 14 +++++++++++---
 1 file changed, 11 insertions(+), 3 deletions(-)
---
diff --git a/vala/valaparser.vala b/vala/valaparser.vala
index 34ed9fa2e..35228c48d 100644
--- a/vala/valaparser.vala
+++ b/vala/valaparser.vala
@@ -1858,6 +1858,7 @@ public class Vala.Parser : CodeVisitor {
        }
 
        void parse_local_constant_declarations (Block block) throws ParseError {
+               var begin = get_location ();
                expect (TokenType.CONST);
                var constant_type = parse_type (false, false);
 
@@ -1867,10 +1868,17 @@ public class Vala.Parser : CodeVisitor {
                        array_type.element_type.value_owned = false;
                }
 
+               bool is_first = true;
                do {
+                       if (!is_first) {
+                               begin = get_location ();
+                       } else {
+                               is_first = false;
+                       }
+
                        DataType type_copy = constant_type.copy ();
                        var local = parse_local_constant (type_copy);
-                       block.add_statement (new DeclarationStatement (local, local.source_reference));
+                       block.add_statement (new DeclarationStatement (local, get_src (begin)));
                        block.add_local_constant (local);
                        local.active = false;
                } while (accept (TokenType.COMMA));
@@ -1880,13 +1888,13 @@ public class Vala.Parser : CodeVisitor {
        Constant parse_local_constant (DataType constant_type) throws ParseError {
                var begin = get_location ();
                string id = parse_identifier ();
-
                var type = parse_inline_array_type (constant_type);
+               var src = get_src (begin);
 
                expect (TokenType.ASSIGN);
                var initializer = parse_expression ();
 
-               return new Constant (id, type, initializer, get_src (begin));
+               return new Constant (id, type, initializer, src);
        }
 
        Statement parse_expression_statement () throws ParseError {


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