[vala] girparser: improve support for generic type arguments
- From: Evan Nemerson <evann src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [vala] girparser: improve support for generic type arguments
- Date: Fri, 18 Jun 2010 22:11:59 +0000 (UTC)
commit 7023a531dffa5d167bada9a33b87e8dbd98dc628
Author: Evan Nemerson <evan coeus-group com>
Date: Fri May 21 01:04:48 2010 -0700
girparser: improve support for generic type arguments
vala/valagirparser.vala | 15 +++++++++------
1 files changed, 9 insertions(+), 6 deletions(-)
---
diff --git a/vala/valagirparser.vala b/vala/valagirparser.vala
index 11a58c2..8cd241d 100644
--- a/vala/valagirparser.vala
+++ b/vala/valagirparser.vala
@@ -348,8 +348,9 @@ public class Vala.GirParser : CodeVisitor {
string transfer = reader.get_attribute ("transfer-ownership");
string allow_none = reader.get_attribute ("allow-none");
next ();
- var type = &ctype != null ? parse_type(out ctype) : parse_type ();
- if (transfer == "full") {
+ var transfer_elements = transfer == "full";
+ var type = &ctype != null ? parse_type(out ctype, null, transfer_elements) : parse_type (null, null, transfer_elements);
+ if (transfer == "full" || transfer == "container") {
type.value_owned = true;
}
if (allow_none == "1") {
@@ -394,8 +395,8 @@ public class Vala.GirParser : CodeVisitor {
param = new FormalParameter.with_ellipsis (get_current_src ());
end_element ("varargs");
} else {
- var type = parse_type (null, out array_length_idx);
- if (transfer == "full") {
+ var type = parse_type (null, out array_length_idx, transfer == "full");
+ if (transfer == "full" || transfer == "container") {
type.value_owned = true;
}
if (allow_none == "1") {
@@ -412,7 +413,7 @@ public class Vala.GirParser : CodeVisitor {
return param;
}
- DataType parse_type (out string? ctype = null, out int array_length_index = null) {
+ DataType parse_type (out string? ctype = null, out int array_length_index = null, bool transfer_elements = false) {
if (reader.name == "array") {
start_element ("array");
if (reader.get_attribute ("length") != null
@@ -436,7 +437,9 @@ public class Vala.GirParser : CodeVisitor {
// type arguments / element types
while (current_token == MarkupTokenType.START_ELEMENT) {
- parse_type ();
+ var element_type = parse_type ();
+ element_type.value_owned = transfer_elements;
+ type.add_type_argument (element_type);
}
end_element ("type");
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]