[vala/0.48] codegen: Correctly handle cast-expression of real struct to nullable struct
- From: Rico Tzschichholz <ricotz src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [vala/0.48] codegen: Correctly handle cast-expression of real struct to nullable struct
- Date: Mon, 18 May 2020 12:38:27 +0000 (UTC)
commit 75fb363cd98632ee7b04bf53260181e02a4aa724
Author: Rico Tzschichholz <ricotz ubuntu com>
Date: Sun May 10 08:46:33 2020 +0200
codegen: Correctly handle cast-expression of real struct to nullable struct
Don't generate invalid c-code leading to "cannot convert to a pointer type"
Fix https://gitlab.gnome.org/GNOME/vala/issues/991
codegen/valaccodebasemodule.vala | 4 ++++
tests/Makefile.am | 1 +
tests/structs/struct-boxed-cast.vala | 21 +++++++++++++++++++++
3 files changed, 26 insertions(+)
---
diff --git a/codegen/valaccodebasemodule.vala b/codegen/valaccodebasemodule.vala
index 06b612cc9..b0d655dda 100644
--- a/codegen/valaccodebasemodule.vala
+++ b/codegen/valaccodebasemodule.vala
@@ -5315,6 +5315,10 @@ public abstract class Vala.CCodeBaseModule : CodeGenerator {
expr.inner.value_type is ValueType && expr.inner.value_type.nullable) {
// nullable integer or float or boolean or struct or enum cast to non-nullable
innercexpr = new CCodeUnaryExpression (CCodeUnaryOperator.POINTER_INDIRECTION,
innercexpr);
+ } else if (expr.type_reference is ValueType && expr.type_reference.nullable &&
+ expr.inner.value_type.is_real_non_null_struct_type ()) {
+ // real non-null struct cast to nullable
+ innercexpr = new CCodeUnaryExpression (CCodeUnaryOperator.ADDRESS_OF, innercexpr);
} else if (expr.type_reference is ArrayType && !(expr.inner is Literal)
&& expr.inner.value_type is ValueType && !expr.inner.value_type.nullable) {
// integer or float or boolean or struct or enum to array cast
diff --git a/tests/Makefile.am b/tests/Makefile.am
index 29dae348c..d0f3eb68d 100644
--- a/tests/Makefile.am
+++ b/tests/Makefile.am
@@ -266,6 +266,7 @@ TESTS = \
enums/bug780050.vala \
structs/struct_only.vala \
structs/struct-base-types.vala \
+ structs/struct-boxed-cast.vala \
structs/struct-empty-still.test \
structs/struct-initializer-list-in-array.vala \
structs/struct-no-gtype.vala \
diff --git a/tests/structs/struct-boxed-cast.vala b/tests/structs/struct-boxed-cast.vala
new file mode 100644
index 000000000..260819dcf
--- /dev/null
+++ b/tests/structs/struct-boxed-cast.vala
@@ -0,0 +1,21 @@
+void foo<T> (T t) {
+ assert (((Bar?) t).s == "foo");
+ assert (((Bar?) t).i == 23);
+}
+
+struct Bar {
+ public string s;
+ public int i;
+}
+
+void main () {
+ Bar f = { "bar", 42 };
+ var cast = (Bar?) f;
+ assert (cast.s == "bar");
+ assert (cast.i == 42);
+
+ Bar arg = { "foo", 23 };
+ foo ((Bar?) arg);
+ foo<Bar?> (arg);
+ foo<Bar?> ((Bar?) arg);
+}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]