Mercurial > hg > octave-nkf
annotate libinterp/parse-tree/pt-decl.cc @ 20830:b65888ec820e draft default tip gccjit
dmalcom gcc jit import
author | Stefan Mahr <dac922@gmx.de> |
---|---|
date | Fri, 27 Feb 2015 16:59:36 +0100 |
parents | f90c8372b7ba |
children |
rev | line source |
---|---|
2982 | 1 /* |
2 | |
19898
4197fc428c7d
maint: Update copyright notices for 2015.
John W. Eaton <jwe@octave.org>
parents:
17787
diff
changeset
|
3 Copyright (C) 1996-2015 John W. Eaton |
2982 | 4 |
5 This file is part of Octave. | |
6 | |
7 Octave is free software; you can redistribute it and/or modify it | |
8 under the terms of the GNU General Public License as published by the | |
7016 | 9 Free Software Foundation; either version 3 of the License, or (at your |
10 option) any later version. | |
2982 | 11 |
12 Octave is distributed in the hope that it will be useful, but WITHOUT | |
13 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
15 for more details. | |
16 | |
17 You should have received a copy of the GNU General Public License | |
7016 | 18 along with Octave; see the file COPYING. If not, see |
19 <http://www.gnu.org/licenses/>. | |
2982 | 20 |
21 */ | |
22 | |
23 #ifdef HAVE_CONFIG_H | |
24 #include <config.h> | |
25 #endif | |
26 | |
3156 | 27 #include "defun.h" |
2982 | 28 #include "error.h" |
29 #include "pt-cmd.h" | |
30 #include "ov.h" | |
31 #include "oct-lvalue.h" | |
7205 | 32 #include "pt-bp.h" |
2982 | 33 #include "pt-decl.h" |
34 #include "pt-exp.h" | |
35 #include "pt-id.h" | |
36 #include "pt-walk.h" | |
3156 | 37 #include "utils.h" |
38 #include "variables.h" | |
39 | |
2982 | 40 // Declarations (global, static, etc.). |
41 | |
42 tree_decl_elt::~tree_decl_elt (void) | |
43 { | |
44 delete id; | |
45 delete expr; | |
46 } | |
47 | |
6215 | 48 bool |
49 tree_decl_elt::eval (void) | |
50 { | |
51 bool retval = false; | |
52 | |
53 if (id && expr) | |
54 { | |
55 octave_lvalue ult = id->lvalue (); | |
56 | |
8658
73c4516fae10
New evaluator and debugger derived from tree-walker class
John W. Eaton <jwe@octave.org>
parents:
8011
diff
changeset
|
57 octave_value init_val = expr->rvalue1 (); |
6215 | 58 |
20762
f90c8372b7ba
eliminate many more simple uses of error_state
John W. Eaton <jwe@octave.org>
parents:
19898
diff
changeset
|
59 ult.assign (octave_value::op_asn_eq, init_val); |
6215 | 60 |
20762
f90c8372b7ba
eliminate many more simple uses of error_state
John W. Eaton <jwe@octave.org>
parents:
19898
diff
changeset
|
61 retval = true; |
6215 | 62 } |
63 | |
64 return retval; | |
65 } | |
66 | |
5861 | 67 tree_decl_elt * |
7767
71f068b22fcc
scope and context fixes for function handles
John W. Eaton <jwe@octave.org>
parents:
7336
diff
changeset
|
68 tree_decl_elt::dup (symbol_table::scope_id scope, |
10315
57a59eae83cc
untabify src C++ source files
John W. Eaton <jwe@octave.org>
parents:
10160
diff
changeset
|
69 symbol_table::context_id context) const |
5861 | 70 { |
7767
71f068b22fcc
scope and context fixes for function handles
John W. Eaton <jwe@octave.org>
parents:
7336
diff
changeset
|
71 return new tree_decl_elt (id ? id->dup (scope, context) : 0, |
10315
57a59eae83cc
untabify src C++ source files
John W. Eaton <jwe@octave.org>
parents:
10160
diff
changeset
|
72 expr ? expr->dup (scope, context) : 0); |
5861 | 73 } |
74 | |
2982 | 75 void |
76 tree_decl_elt::accept (tree_walker& tw) | |
77 { | |
78 tw.visit_decl_elt (*this); | |
79 } | |
80 | |
81 // Initializer lists for declaration statements. | |
82 | |
5861 | 83 tree_decl_init_list * |
7767
71f068b22fcc
scope and context fixes for function handles
John W. Eaton <jwe@octave.org>
parents:
7336
diff
changeset
|
84 tree_decl_init_list::dup (symbol_table::scope_id scope, |
10315
57a59eae83cc
untabify src C++ source files
John W. Eaton <jwe@octave.org>
parents:
10160
diff
changeset
|
85 symbol_table::context_id context) const |
5861 | 86 { |
87 tree_decl_init_list *new_dil = new tree_decl_init_list (); | |
88 | |
8913
35cd375d4bb3
make tree::dup functions const
John W. Eaton <jwe@octave.org>
parents:
8658
diff
changeset
|
89 for (const_iterator p = begin (); p != end (); p++) |
5861 | 90 { |
8913
35cd375d4bb3
make tree::dup functions const
John W. Eaton <jwe@octave.org>
parents:
8658
diff
changeset
|
91 const tree_decl_elt *elt = *p; |
5861 | 92 |
7767
71f068b22fcc
scope and context fixes for function handles
John W. Eaton <jwe@octave.org>
parents:
7336
diff
changeset
|
93 new_dil->append (elt ? elt->dup (scope, context) : 0); |
5861 | 94 } |
11586
12df7854fa7c
strip trailing whitespace from source files
John W. Eaton <jwe@octave.org>
parents:
11523
diff
changeset
|
95 |
5861 | 96 return new_dil; |
97 } | |
98 | |
2982 | 99 void |
100 tree_decl_init_list::accept (tree_walker& tw) | |
101 { | |
102 tw.visit_decl_init_list (*this); | |
103 } | |
104 | |
105 // Base class for declaration commands (global, static). | |
106 | |
107 tree_decl_command::~tree_decl_command (void) | |
108 { | |
109 delete init_list; | |
110 } | |
111 | |
112 // Global. | |
113 | |
5861 | 114 tree_command * |
7767
71f068b22fcc
scope and context fixes for function handles
John W. Eaton <jwe@octave.org>
parents:
7336
diff
changeset
|
115 tree_global_command::dup (symbol_table::scope_id scope, |
10315
57a59eae83cc
untabify src C++ source files
John W. Eaton <jwe@octave.org>
parents:
10160
diff
changeset
|
116 symbol_table::context_id context) const |
5861 | 117 { |
7767
71f068b22fcc
scope and context fixes for function handles
John W. Eaton <jwe@octave.org>
parents:
7336
diff
changeset
|
118 return |
71f068b22fcc
scope and context fixes for function handles
John W. Eaton <jwe@octave.org>
parents:
7336
diff
changeset
|
119 new tree_global_command (init_list ? init_list->dup (scope, context) : 0, |
10315
57a59eae83cc
untabify src C++ source files
John W. Eaton <jwe@octave.org>
parents:
10160
diff
changeset
|
120 line (), column ()); |
5861 | 121 } |
122 | |
2989 | 123 void |
8658
73c4516fae10
New evaluator and debugger derived from tree-walker class
John W. Eaton <jwe@octave.org>
parents:
8011
diff
changeset
|
124 tree_global_command::accept (tree_walker& tw) |
2982 | 125 { |
8658
73c4516fae10
New evaluator and debugger derived from tree-walker class
John W. Eaton <jwe@octave.org>
parents:
8011
diff
changeset
|
126 tw.visit_global_command (*this); |
2982 | 127 } |
128 | |
8658
73c4516fae10
New evaluator and debugger derived from tree-walker class
John W. Eaton <jwe@octave.org>
parents:
8011
diff
changeset
|
129 // Static. |
2982 | 130 |
5861 | 131 tree_command * |
14294
9e3983c8963c
deprecate the static keyword
John W. Eaton <jwe@octave.org>
parents:
14138
diff
changeset
|
132 tree_persistent_command::dup (symbol_table::scope_id scope, |
17787
175b392e91fe
Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents:
17744
diff
changeset
|
133 symbol_table::context_id context) const |
5861 | 134 { |
7767
71f068b22fcc
scope and context fixes for function handles
John W. Eaton <jwe@octave.org>
parents:
7336
diff
changeset
|
135 return |
17787
175b392e91fe
Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents:
17744
diff
changeset
|
136 new tree_persistent_command (init_list ? init_list->dup (scope, context) |
175b392e91fe
Use GNU style coding conventions for code in libinterp/
Rik <rik@octave.org>
parents:
17744
diff
changeset
|
137 : 0, |
14294
9e3983c8963c
deprecate the static keyword
John W. Eaton <jwe@octave.org>
parents:
14138
diff
changeset
|
138 line (), column ()); |
5861 | 139 } |
140 | |
8658
73c4516fae10
New evaluator and debugger derived from tree-walker class
John W. Eaton <jwe@octave.org>
parents:
8011
diff
changeset
|
141 void |
14294
9e3983c8963c
deprecate the static keyword
John W. Eaton <jwe@octave.org>
parents:
14138
diff
changeset
|
142 tree_persistent_command::accept (tree_walker& tw) |
8658
73c4516fae10
New evaluator and debugger derived from tree-walker class
John W. Eaton <jwe@octave.org>
parents:
8011
diff
changeset
|
143 { |
14294
9e3983c8963c
deprecate the static keyword
John W. Eaton <jwe@octave.org>
parents:
14138
diff
changeset
|
144 tw.visit_persistent_command (*this); |
8658
73c4516fae10
New evaluator and debugger derived from tree-walker class
John W. Eaton <jwe@octave.org>
parents:
8011
diff
changeset
|
145 } |