[vala/staging] Revert "Use ErrorType-based collection for CodeNode.get_error_types()"
- From: Rico Tzschichholz <ricotz src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [vala/staging] Revert "Use ErrorType-based collection for CodeNode.get_error_types()"
- Date: Mon, 25 Oct 2021 07:17:34 +0000 (UTC)
commit 01affa4019bab9c4cc2366cd2224148c1bfb3bea
Author: Rico Tzschichholz <ricotz ubuntu com>
Date: Mon Oct 25 09:13:51 2021 +0200
Revert "Use ErrorType-based collection for CodeNode.get_error_types()"
Unfortunately, it is causing issues with the way the GIR/GIDL parser works.
This reverts commit 0751a9e3bf46fc830d3e7ca3d0cfd3ae48846e68.
codegen/valaccodemethodmodule.vala | 4 ++--
codegen/valagdbusclientmodule.vala | 7 ++++---
codegen/valagerrormodule.vala | 14 +++++++-------
vala/valaassignment.vala | 2 +-
vala/valabinaryexpression.vala | 2 +-
vala/valablock.vala | 2 +-
vala/valacallabletype.vala | 4 ++--
vala/valacastexpression.vala | 2 +-
vala/valacodenode.vala | 4 ++--
vala/valacodewriter.vala | 4 ++--
vala/valaconditionalexpression.vala | 2 +-
vala/valaconstructor.vala | 6 +++---
vala/valacreationmethod.vala | 12 ++++++------
vala/valadeclarationstatement.vala | 2 +-
vala/valadelegate.vala | 14 +++++++-------
vala/valadelegatetype.vala | 8 ++++----
vala/valadestructor.vala | 6 +++---
vala/valaelementaccess.vala | 2 +-
vala/valaexpressionstatement.vala | 2 +-
vala/valaflowanalyzer.vala | 7 ++++---
vala/valaforeachstatement.vala | 2 +-
vala/valagirparser.vala | 6 +++---
vala/valaifstatement.vala | 2 +-
vala/valalambdaexpression.vala | 4 ++--
vala/valaloopstatement.vala | 2 +-
vala/valamemberaccess.vala | 2 +-
vala/valamethod.vala | 30 +++++++++++++++++-------------
vala/valamethodcall.vala | 2 +-
vala/valaobjectcreationexpression.vala | 2 +-
vala/valapointerindirection.vala | 2 +-
vala/valapropertyaccessor.vala | 6 +++---
vala/valareturnstatement.vala | 2 +-
vala/valastatementlist.vala | 2 +-
vala/valaswitchstatement.vala | 2 +-
vala/valathrowstatement.vala | 4 ++--
vala/valatrystatement.vala | 4 ++--
vala/valaunaryexpression.vala | 2 +-
vala/valawithstatement.vala | 2 +-
valadoc/symbolresolver.vala | 6 +++---
vapigen/valagidlparser.vala | 4 ++--
40 files changed, 100 insertions(+), 94 deletions(-)
---
diff --git a/codegen/valaccodemethodmodule.vala b/codegen/valaccodemethodmodule.vala
index d4f9931ad..840aa14bc 100644
--- a/codegen/valaccodemethodmodule.vala
+++ b/codegen/valaccodemethodmodule.vala
@@ -94,9 +94,9 @@ public abstract class Vala.CCodeMethodModule : CCodeStructModule {
}
if (m.has_error_type_parameter ()) {
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
m.get_error_types (error_types);
- foreach (var error_type in error_types) {
+ foreach (DataType error_type in error_types) {
generate_type_declaration (error_type, decl_space);
}
diff --git a/codegen/valagdbusclientmodule.vala b/codegen/valagdbusclientmodule.vala
index be102bf55..697b08758 100644
--- a/codegen/valagdbusclientmodule.vala
+++ b/codegen/valagdbusclientmodule.vala
@@ -594,11 +594,12 @@ public class Vala.GDBusClientModule : GDBusModule {
}
// register errors
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
m.get_error_types (error_types);
foreach (var error_type in error_types) {
- if (error_type.error_domain != null) {
- ccode.add_expression (new CCodeIdentifier (get_ccode_upper_case_name
(error_type.error_domain)));
+ var errtype = (ErrorType) error_type;
+ if (errtype.error_domain != null) {
+ ccode.add_expression (new CCodeIdentifier (get_ccode_upper_case_name
(errtype.error_domain)));
}
}
diff --git a/codegen/valagerrormodule.vala b/codegen/valagerrormodule.vala
index 40fee3920..a559a4d00 100644
--- a/codegen/valagerrormodule.vala
+++ b/codegen/valagerrormodule.vala
@@ -203,21 +203,21 @@ public class Vala.GErrorModule : CCodeDelegateModule {
append_local_free (current_symbol, null, current_try);
}
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
node.get_error_types (error_types);
bool has_general_catch_clause = false;
if (!is_in_catch) {
- var handled_error_types = new ArrayList<ErrorType> ();
+ var handled_error_types = new ArrayList<DataType> ();
foreach (CatchClause clause in current_try.get_catch_clauses ()) {
// keep track of unhandled error types
- foreach (var node_error_type in error_types) {
+ foreach (DataType node_error_type in error_types) {
if (clause.error_type == null || node_error_type.compatible
(clause.error_type)) {
handled_error_types.add (node_error_type);
}
}
- foreach (var handled_error_type in handled_error_types) {
+ foreach (DataType handled_error_type in handled_error_types) {
error_types.remove (handled_error_type);
}
handled_error_types.clear ();
@@ -273,9 +273,9 @@ public class Vala.GErrorModule : CCodeDelegateModule {
// current method can fail, propagate error
CCodeBinaryExpression ccond = null;
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
current_method.get_error_types (error_types);
- foreach (var error_type in error_types) {
+ foreach (DataType error_type in error_types) {
// If GLib.Error is allowed we propagate everything
if (error_type.equals (gerror_type)) {
ccond = null;
@@ -284,7 +284,7 @@ public class Vala.GErrorModule : CCodeDelegateModule {
// Check the allowed error domains to propagate
var domain_check = new CCodeBinaryExpression (CCodeBinaryOperator.EQUALITY,
new CCodeMemberAccess.pointer
- (get_inner_error_cexpression (), "domain"), new CCodeIdentifier
(get_ccode_upper_case_name (error_type.error_domain)));
+ (get_inner_error_cexpression (), "domain"), new CCodeIdentifier
(get_ccode_upper_case_name (((ErrorType) error_type).error_domain)));
if (ccond == null) {
ccond = domain_check;
} else {
diff --git a/vala/valaassignment.vala b/vala/valaassignment.vala
index bf369b883..46f9445a4 100644
--- a/vala/valaassignment.vala
+++ b/vala/valaassignment.vala
@@ -105,7 +105,7 @@ public class Vala.Assignment : Expression {
return left.is_accessible (sym) && right.is_accessible (sym);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
left.get_error_types (collection, source_reference);
right.get_error_types (collection, source_reference);
}
diff --git a/vala/valabinaryexpression.vala b/vala/valabinaryexpression.vala
index 401dc6daa..d379927c0 100644
--- a/vala/valabinaryexpression.vala
+++ b/vala/valabinaryexpression.vala
@@ -128,7 +128,7 @@ public class Vala.BinaryExpression : Expression {
return left.is_accessible (sym) && right.is_accessible (sym);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
left.get_error_types (collection, source_reference);
right.get_error_types (collection, source_reference);
}
diff --git a/vala/valablock.vala b/vala/valablock.vala
index 47819f5b1..e002909bf 100644
--- a/vala/valablock.vala
+++ b/vala/valablock.vala
@@ -183,7 +183,7 @@ public class Vala.Block : Symbol, Statement {
return !error;
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
// use get_statements () instead of statement_list to not miss errors within StatementList
objects
foreach (Statement stmt in get_statements ()) {
stmt.get_error_types (collection, source_reference);
diff --git a/vala/valacallabletype.vala b/vala/valacallabletype.vala
index cb584fb9e..6ea2349d0 100644
--- a/vala/valacallabletype.vala
+++ b/vala/valacallabletype.vala
@@ -126,13 +126,13 @@ public abstract class Vala.CallableType : DataType {
builder.append_c (')');
// Append error-types
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
callable_symbol.get_error_types (error_types);
if (error_types.size > 0) {
builder.append (" throws ");
bool first = true;
- foreach (var type in error_types) {
+ foreach (DataType type in error_types) {
if (!first) {
builder.append (", ");
} else {
diff --git a/vala/valacastexpression.vala b/vala/valacastexpression.vala
index fccc1d191..1d1dbb0f2 100644
--- a/vala/valacastexpression.vala
+++ b/vala/valacastexpression.vala
@@ -132,7 +132,7 @@ public class Vala.CastExpression : Expression {
}
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
inner.get_error_types (collection, source_reference);
}
diff --git a/vala/valacodenode.vala b/vala/valacodenode.vala
index 73a3ab417..05ba53a0a 100644
--- a/vala/valacodenode.vala
+++ b/vala/valacodenode.vala
@@ -63,7 +63,7 @@ public abstract class Vala.CodeNode {
*/
public bool tree_can_fail {
get {
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
get_error_types (error_types);
return error_types.size > 0;
}
@@ -409,7 +409,7 @@ public abstract class Vala.CodeNode {
public virtual void get_used_variables (Collection<Variable> collection) {
}
- public virtual void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public virtual void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
}
public static string get_temp_name () {
diff --git a/vala/valacodewriter.vala b/vala/valacodewriter.vala
index d73f341d7..cb3bd998d 100644
--- a/vala/valacodewriter.vala
+++ b/vala/valacodewriter.vala
@@ -731,7 +731,7 @@ public class Vala.CodeWriter : CodeVisitor {
write_params (cb.get_parameters ());
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
cb.get_error_types (error_types);
write_error_domains (error_types);
@@ -849,7 +849,7 @@ public class Vala.CodeWriter : CodeVisitor {
write_params (m.get_parameters ());
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
m.get_error_types (error_types);
write_error_domains (error_types);
diff --git a/vala/valaconditionalexpression.vala b/vala/valaconditionalexpression.vala
index 66bbfbaeb..c8bfdbce1 100644
--- a/vala/valaconditionalexpression.vala
+++ b/vala/valaconditionalexpression.vala
@@ -104,7 +104,7 @@ public class Vala.ConditionalExpression : Expression {
return condition.is_accessible (sym) && true_expression.is_accessible (sym) &&
false_expression.is_accessible (sym);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
condition.get_error_types (collection, source_reference);
true_expression.get_error_types (collection, source_reference);
false_expression.get_error_types (collection, source_reference);
diff --git a/vala/valaconstructor.vala b/vala/valaconstructor.vala
index a83acee7e..8c916f8a5 100644
--- a/vala/valaconstructor.vala
+++ b/vala/valaconstructor.vala
@@ -79,10 +79,10 @@ public class Vala.Constructor : Subroutine {
}
if (body != null && !body.error) {
- var body_errors = new ArrayList<ErrorType> ();
+ var body_errors = new ArrayList<DataType> ();
body.get_error_types (body_errors);
- foreach (var body_error_type in body_errors) {
- if (!body_error_type.dynamic_error) {
+ foreach (DataType body_error_type in body_errors) {
+ if (!((ErrorType) body_error_type).dynamic_error) {
Report.warning (body_error_type.source_reference, "unhandled error
`%s'", body_error_type.to_string());
}
}
diff --git a/vala/valacreationmethod.vala b/vala/valacreationmethod.vala
index c47ea10e5..77b311f31 100644
--- a/vala/valacreationmethod.vala
+++ b/vala/valacreationmethod.vala
@@ -61,7 +61,7 @@ public class Vala.CreationMethod : Method {
}
if (error_types != null) {
- foreach (var error_type in error_types) {
+ foreach (DataType error_type in error_types) {
error_type.accept (visitor);
}
}
@@ -143,7 +143,7 @@ public class Vala.CreationMethod : Method {
}
if (error_types != null) {
- foreach (var error_type in error_types) {
+ foreach (DataType error_type in error_types) {
error_type.check (context);
// check whether error type is at least as accessible as the creation method
@@ -215,18 +215,18 @@ public class Vala.CreationMethod : Method {
// check that all errors that can be thrown in the method body are declared
if (body != null && !body.error) {
- var body_errors = new ArrayList<ErrorType> ();
+ var body_errors = new ArrayList<DataType> ();
body.get_error_types (body_errors);
- foreach (var body_error_type in body_errors) {
+ foreach (DataType body_error_type in body_errors) {
bool can_propagate_error = false;
if (error_types != null) {
- foreach (var method_error_type in error_types) {
+ foreach (DataType method_error_type in error_types) {
if (body_error_type.compatible (method_error_type)) {
can_propagate_error = true;
}
}
}
- if (!can_propagate_error && !body_error_type.dynamic_error) {
+ if (!can_propagate_error && !((ErrorType) body_error_type).dynamic_error) {
Report.warning (body_error_type.source_reference, "unhandled error
`%s'", body_error_type.to_string());
}
}
diff --git a/vala/valadeclarationstatement.vala b/vala/valadeclarationstatement.vala
index c6841ea2d..30732b4a6 100644
--- a/vala/valadeclarationstatement.vala
+++ b/vala/valadeclarationstatement.vala
@@ -62,7 +62,7 @@ public class Vala.DeclarationStatement : CodeNode, Statement {
declaration.accept (visitor);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (source_reference == null) {
source_reference = this.source_reference;
}
diff --git a/vala/valadelegate.vala b/vala/valadelegate.vala
index 8bb318d43..249adcdfc 100644
--- a/vala/valadelegate.vala
+++ b/vala/valadelegate.vala
@@ -206,7 +206,7 @@ public class Vala.Delegate : TypeSymbol, Callable {
return false;
}
- var method_error_types = new ArrayList<ErrorType> ();
+ var method_error_types = new ArrayList<DataType> ();
m.get_error_types (method_error_types);
// method must throw error if the delegate does
@@ -215,10 +215,10 @@ public class Vala.Delegate : TypeSymbol, Callable {
}
// method may throw less but not more errors than the delegate
- foreach (var method_error_type in method_error_types) {
+ foreach (DataType method_error_type in method_error_types) {
bool match = false;
if (error_types != null) {
- foreach (var delegate_error_type in error_types) {
+ foreach (DataType delegate_error_type in error_types) {
if (method_error_type.compatible (delegate_error_type)) {
match = true;
break;
@@ -250,7 +250,7 @@ public class Vala.Delegate : TypeSymbol, Callable {
}
if (error_types != null) {
- foreach (var error_type in error_types) {
+ foreach (DataType error_type in error_types) {
error_type.accept (visitor);
}
}
@@ -272,15 +272,15 @@ public class Vala.Delegate : TypeSymbol, Callable {
error_type.parent_node = this;
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (error_types != null) {
foreach (var error_type in error_types) {
if (source_reference != null) {
- var type = (ErrorType) error_type.copy ();
+ var type = error_type.copy ();
type.source_reference = source_reference;
collection.add (type);
} else {
- collection.add ((ErrorType) error_type);
+ collection.add (error_type);
}
}
}
diff --git a/vala/valadelegatetype.vala b/vala/valadelegatetype.vala
index 33d9c5521..8b51f324c 100644
--- a/vala/valadelegatetype.vala
+++ b/vala/valadelegatetype.vala
@@ -167,13 +167,13 @@ public class Vala.DelegateType : CallableType {
}
// target-delegate may throw less but not more errors than the delegate
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
delegate_symbol.get_error_types (error_types);
- foreach (var error_type in error_types) {
+ foreach (DataType error_type in error_types) {
bool match = false;
- var delegate_error_types = new ArrayList<ErrorType> ();
+ var delegate_error_types = new ArrayList<DataType> ();
dt_target.delegate_symbol.get_error_types (delegate_error_types);
- foreach (var delegate_error_type in delegate_error_types) {
+ foreach (DataType delegate_error_type in delegate_error_types) {
if (error_type.compatible (delegate_error_type)) {
match = true;
break;
diff --git a/vala/valadestructor.vala b/vala/valadestructor.vala
index 84a10280f..2febe55d3 100644
--- a/vala/valadestructor.vala
+++ b/vala/valadestructor.vala
@@ -79,10 +79,10 @@ public class Vala.Destructor : Subroutine {
}
if (body != null && !body.error) {
- var body_errors = new ArrayList<ErrorType> ();
+ var body_errors = new ArrayList<DataType> ();
body.get_error_types (body_errors);
- foreach (var body_error_type in body_errors) {
- if (!body_error_type.dynamic_error) {
+ foreach (DataType body_error_type in body_errors) {
+ if (!((ErrorType) body_error_type).dynamic_error) {
Report.warning (body_error_type.source_reference, "unhandled error
`%s'", body_error_type.to_string());
}
}
diff --git a/vala/valaelementaccess.vala b/vala/valaelementaccess.vala
index de050bc3b..ce6281870 100644
--- a/vala/valaelementaccess.vala
+++ b/vala/valaelementaccess.vala
@@ -127,7 +127,7 @@ public class Vala.ElementAccess : Expression {
return container.is_accessible (sym);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
container.get_error_types (collection, source_reference);
foreach (Expression e in indices) {
e.get_error_types (collection, source_reference);
diff --git a/vala/valaexpressionstatement.vala b/vala/valaexpressionstatement.vala
index ee521f623..ac435d081 100644
--- a/vala/valaexpressionstatement.vala
+++ b/vala/valaexpressionstatement.vala
@@ -87,7 +87,7 @@ public class Vala.ExpressionStatement : CodeNode, Statement {
return !error;
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
expression.get_error_types (collection, source_reference);
}
diff --git a/vala/valaflowanalyzer.vala b/vala/valaflowanalyzer.vala
index bb4153d2a..a5a8be993 100644
--- a/vala/valaflowanalyzer.vala
+++ b/vala/valaflowanalyzer.vala
@@ -908,10 +908,11 @@ public class Vala.FlowAnalyzer : CodeVisitor {
var last_block = current_block;
// exceptional control flow
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
node.get_error_types (error_types);
- foreach (var error_type in error_types) {
- unowned Class? error_class = error_type.type_symbol as Class;
+ foreach (DataType error_data_type in error_types) {
+ unowned ErrorType? error_type = error_data_type as ErrorType;
+ unowned Class? error_class = error_data_type.type_symbol as Class;
current_block = last_block;
unreachable_reported = true;
diff --git a/vala/valaforeachstatement.vala b/vala/valaforeachstatement.vala
index ef957839d..3d8ce2ba9 100644
--- a/vala/valaforeachstatement.vala
+++ b/vala/valaforeachstatement.vala
@@ -413,7 +413,7 @@ public class Vala.ForeachStatement : Block {
return !error;
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (source_reference == null) {
source_reference = this.source_reference;
}
diff --git a/vala/valagirparser.vala b/vala/valagirparser.vala
index 94c9e2534..31b8ad4c6 100644
--- a/vala/valagirparser.vala
+++ b/vala/valagirparser.vala
@@ -3944,7 +3944,7 @@ public class Vala.GirParser : CodeVisitor {
deleg.add_parameter (param.copy ());
}
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
orig.get_error_types (error_types, alias.source_reference);
foreach (var error_type in error_types) {
deleg.add_error_type (error_type.copy ());
@@ -4448,9 +4448,9 @@ public class Vala.GirParser : CodeVisitor {
}
}
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
finish_method.get_error_types (error_types, method.source_reference);
- foreach (var error_type in error_types) {
+ foreach (DataType error_type in error_types) {
method.add_error_type (error_type);
}
finish_method_node.processed = true;
diff --git a/vala/valaifstatement.vala b/vala/valaifstatement.vala
index 85b98eeec..bed1dfe9a 100644
--- a/vala/valaifstatement.vala
+++ b/vala/valaifstatement.vala
@@ -102,7 +102,7 @@ public class Vala.IfStatement : CodeNode, Statement {
}
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
condition.get_error_types (collection, source_reference);
true_statement.get_error_types (collection, source_reference);
if (false_statement != null) {
diff --git a/vala/valalambdaexpression.vala b/vala/valalambdaexpression.vala
index 291e451a5..be33765f8 100644
--- a/vala/valalambdaexpression.vala
+++ b/vala/valalambdaexpression.vala
@@ -225,10 +225,10 @@ public class Vala.LambdaExpression : Expression {
return false;
}
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
cb.get_error_types (error_types);
foreach (var error_type in error_types) {
- method.add_error_type ((ErrorType) error_type.copy ());
+ method.add_error_type (error_type.copy ());
}
if (expression_body != null) {
diff --git a/vala/valaloopstatement.vala b/vala/valaloopstatement.vala
index b99172b21..e522fd1b0 100644
--- a/vala/valaloopstatement.vala
+++ b/vala/valaloopstatement.vala
@@ -45,7 +45,7 @@ public class Vala.LoopStatement : Loop, Statement {
body.accept (visitor);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
body.get_error_types (collection, source_reference);
}
diff --git a/vala/valamemberaccess.vala b/vala/valamemberaccess.vala
index b1c53c64d..5be3fa0da 100644
--- a/vala/valamemberaccess.vala
+++ b/vala/valamemberaccess.vala
@@ -205,7 +205,7 @@ public class Vala.MemberAccess : Expression {
}
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (inner != null) {
inner.get_error_types (collection, source_reference);
}
diff --git a/vala/valamethod.vala b/vala/valamethod.vala
index d40875d47..dc41e3d77 100644
--- a/vala/valamethod.vala
+++ b/vala/valamethod.vala
@@ -421,12 +421,12 @@ public class Vala.Method : Subroutine, Callable {
}
/* this method may throw less but not more errors than the base method */
- var base_method_errors = new ArrayList<ErrorType> ();
+ var base_method_errors = new ArrayList<DataType> ();
base_method.get_error_types (base_method_errors);
if (error_types != null) {
- foreach (var method_error_type in error_types) {
+ foreach (DataType method_error_type in error_types) {
bool match = false;
- foreach (var base_method_error_type in base_method_errors) {
+ foreach (DataType base_method_error_type in base_method_errors) {
if (method_error_type.compatible (base_method_error_type)) {
match = true;
break;
@@ -563,15 +563,15 @@ public class Vala.Method : Subroutine, Callable {
error_type.parent_node = this;
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (error_types != null) {
foreach (var error_type in error_types) {
if (source_reference != null) {
- var type = (ErrorType) error_type.copy ();
+ var type = error_type.copy ();
type.source_reference = source_reference;
collection.add (type);
} else {
- collection.add ((ErrorType) error_type);
+ collection.add (error_type);
}
}
}
@@ -1034,18 +1034,19 @@ public class Vala.Method : Subroutine, Callable {
// check that all errors that can be thrown in the method body are declared
if (body != null && !body.error) {
- var body_errors = new ArrayList<ErrorType> ();
+ var body_errors = new ArrayList<DataType> ();
body.get_error_types (body_errors);
- foreach (var body_error_type in body_errors) {
+ foreach (DataType body_error_type in body_errors) {
bool can_propagate_error = false;
if (error_types != null) {
- foreach (var method_error_type in error_types) {
+ foreach (DataType method_error_type in error_types) {
if (body_error_type.compatible (method_error_type)) {
can_propagate_error = true;
}
}
}
- if (!can_propagate_error && !body_error_type.dynamic_error) {
+ bool is_dynamic_error = body_error_type is ErrorType && ((ErrorType)
body_error_type).dynamic_error;
+ if (!can_propagate_error && !is_dynamic_error) {
Report.warning (body_error_type.source_reference, "unhandled error
`%s'", body_error_type.to_string());
}
}
@@ -1060,10 +1061,13 @@ public class Vala.Method : Subroutine, Callable {
bool throws_gerror = false;
bool throws_gioerror = false;
bool throws_gdbuserror = false;
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
get_error_types (error_types);
- foreach (var error_type in error_types) {
- unowned ErrorDomain? error_domain = error_type.error_domain;
+ foreach (DataType error_type in error_types) {
+ if (!(error_type is ErrorType)) {
+ continue;
+ }
+ unowned ErrorDomain? error_domain = ((ErrorType)
error_type).error_domain;
if (error_domain == null) {
throws_gerror = true;
break;
diff --git a/vala/valamethodcall.vala b/vala/valamethodcall.vala
index 0a714ffd4..aff7db77a 100644
--- a/vala/valamethodcall.vala
+++ b/vala/valamethodcall.vala
@@ -142,7 +142,7 @@ public class Vala.MethodCall : Expression, CallableExpression {
return call.is_accessible (sym);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (source_reference == null) {
source_reference = this.source_reference;
}
diff --git a/vala/valaobjectcreationexpression.vala b/vala/valaobjectcreationexpression.vala
index 0b668ea64..a6ce8a14f 100644
--- a/vala/valaobjectcreationexpression.vala
+++ b/vala/valaobjectcreationexpression.vala
@@ -565,7 +565,7 @@ public class Vala.ObjectCreationExpression : Expression, CallableExpression {
return !error;
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (symbol_reference is Method) {
if (source_reference == null) {
source_reference = this.source_reference;
diff --git a/vala/valapointerindirection.vala b/vala/valapointerindirection.vala
index 86c441ff3..5e14de7f6 100644
--- a/vala/valapointerindirection.vala
+++ b/vala/valapointerindirection.vala
@@ -77,7 +77,7 @@ public class Vala.PointerIndirection : Expression {
return inner.is_accessible (sym);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
inner.get_error_types (collection, source_reference);
}
diff --git a/vala/valapropertyaccessor.vala b/vala/valapropertyaccessor.vala
index 46d8604a3..393284301 100644
--- a/vala/valapropertyaccessor.vala
+++ b/vala/valapropertyaccessor.vala
@@ -245,10 +245,10 @@ public class Vala.PropertyAccessor : Subroutine {
}
if (body != null && !body.error) {
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
body.get_error_types (error_types);
- foreach (var body_error_type in error_types) {
- if (!body_error_type.dynamic_error) {
+ foreach (DataType body_error_type in error_types) {
+ if (!((ErrorType) body_error_type).dynamic_error) {
Report.warning (body_error_type.source_reference, "unhandled error
`%s'", body_error_type.to_string ());
}
}
diff --git a/vala/valareturnstatement.vala b/vala/valareturnstatement.vala
index 7a9f14c45..3873083ee 100644
--- a/vala/valareturnstatement.vala
+++ b/vala/valareturnstatement.vala
@@ -70,7 +70,7 @@ public class Vala.ReturnStatement : CodeNode, Statement {
}
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (return_expression != null) {
return_expression.get_error_types (collection, source_reference);
}
diff --git a/vala/valastatementlist.vala b/vala/valastatementlist.vala
index 265cefcf5..b76b74cae 100644
--- a/vala/valastatementlist.vala
+++ b/vala/valastatementlist.vala
@@ -48,7 +48,7 @@ public class Vala.StatementList : CodeNode, Statement {
list.insert (index, stmt);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
foreach (var stmt in list) {
stmt.get_error_types (collection, source_reference);
}
diff --git a/vala/valaswitchstatement.vala b/vala/valaswitchstatement.vala
index ac44691c5..31ef82622 100644
--- a/vala/valaswitchstatement.vala
+++ b/vala/valaswitchstatement.vala
@@ -93,7 +93,7 @@ public class Vala.SwitchStatement : CodeNode, Statement {
}
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
foreach (SwitchSection section in sections) {
section.get_error_types (collection, source_reference);
}
diff --git a/vala/valathrowstatement.vala b/vala/valathrowstatement.vala
index d8f03909b..8a6e04be7 100644
--- a/vala/valathrowstatement.vala
+++ b/vala/valathrowstatement.vala
@@ -72,14 +72,14 @@ public class Vala.ThrowStatement : CodeNode, Statement {
}
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (error) {
return;
}
if (source_reference == null) {
source_reference = this.source_reference;
}
- var error_type = (ErrorType) error_expression.value_type.copy ();
+ var error_type = error_expression.value_type.copy ();
error_type.source_reference = source_reference;
collection.add (error_type);
}
diff --git a/vala/valatrystatement.vala b/vala/valatrystatement.vala
index ebec4dd53..7cbc78a27 100644
--- a/vala/valatrystatement.vala
+++ b/vala/valatrystatement.vala
@@ -104,8 +104,8 @@ public class Vala.TryStatement : CodeNode, Statement {
}
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
- var error_types = new ArrayList<ErrorType> ();
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
+ var error_types = new ArrayList<DataType> ();
body.get_error_types (error_types, source_reference);
foreach (CatchClause clause in catch_clauses) {
diff --git a/vala/valaunaryexpression.vala b/vala/valaunaryexpression.vala
index 37f8788b0..a725456fa 100644
--- a/vala/valaunaryexpression.vala
+++ b/vala/valaunaryexpression.vala
@@ -128,7 +128,7 @@ public class Vala.UnaryExpression : Expression {
return st.is_integer_type ();
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
inner.get_error_types (collection, source_reference);
}
diff --git a/vala/valawithstatement.vala b/vala/valawithstatement.vala
index fd556583e..52210284a 100644
--- a/vala/valawithstatement.vala
+++ b/vala/valawithstatement.vala
@@ -134,7 +134,7 @@ public class Vala.WithStatement : Block {
body.emit (codegen);
}
- public override void get_error_types (Collection<ErrorType> collection, SourceReference?
source_reference = null) {
+ public override void get_error_types (Collection<DataType> collection, SourceReference?
source_reference = null) {
if (source_reference == null) {
source_reference = this.source_reference;
}
diff --git a/valadoc/symbolresolver.vala b/valadoc/symbolresolver.vala
index 4d41c823c..20021c5fa 100644
--- a/valadoc/symbolresolver.vala
+++ b/valadoc/symbolresolver.vala
@@ -38,10 +38,10 @@ public class Valadoc.SymbolResolver : Visitor {
}
private void resolve_thrown_list (Symbol symbol, Vala.Symbol vala_symbol) {
- var error_types = new Vala.ArrayList<Vala.ErrorType> ();
+ var error_types = new Vala.ArrayList<Vala.DataType> ();
vala_symbol.get_error_types (error_types);
- foreach (var type in error_types) {
- unowned Vala.ErrorDomain? vala_edom = type.error_domain;
+ foreach (Vala.DataType type in error_types) {
+ unowned Vala.ErrorDomain? vala_edom = ((Vala.ErrorType) type).error_domain;
Symbol? edom = symbol_map.get (vala_edom);
symbol.add_child (edom ?? glib_error);
}
diff --git a/vapigen/valagidlparser.vala b/vapigen/valagidlparser.vala
index 87ef022e9..007896ec4 100644
--- a/vapigen/valagidlparser.vala
+++ b/vapigen/valagidlparser.vala
@@ -1827,9 +1827,9 @@ public class Vala.GIdlParser : CodeVisitor {
m.add_parameter (async_param);
}
}
- var error_types = new ArrayList<ErrorType> ();
+ var error_types = new ArrayList<DataType> ();
finish_method.get_error_types (error_types, m.source_reference);
- foreach (var error_type in error_types) {
+ foreach (DataType error_type in error_types) {
m.add_error_type (error_type);
}
finish_methods.add (finish_method);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]