summaryrefslogtreecommitdiff
path: root/vala/valaarraycreationexpression.vala
diff options
context:
space:
mode:
authorJürg Billeter <j@bitron.ch>2007-05-02 09:42:00 +0000
committerJürg Billeter <juergbi@src.gnome.org>2007-05-02 09:42:00 +0000
commitf8387ad143f1884f8f5f89bd5389605624f4c34f (patch)
treee75e563fc9535200ec146af72962e80778359ae4 /vala/valaarraycreationexpression.vala
parent9db973114ee1449c1764404163ecc8294f8e73d2 (diff)
downloadvala-f8387ad143f1884f8f5f89bd5389605624f4c34f.tar.gz
Move contents of vala-pkg to trunk
2007-05-02 Jürg Billeter <j@bitron.ch> * Move contents of vala-pkg to trunk svn path=/trunk/; revision=300
Diffstat (limited to 'vala/valaarraycreationexpression.vala')
-rw-r--r--vala/valaarraycreationexpression.vala89
1 files changed, 89 insertions, 0 deletions
diff --git a/vala/valaarraycreationexpression.vala b/vala/valaarraycreationexpression.vala
new file mode 100644
index 000000000..376e03f74
--- /dev/null
+++ b/vala/valaarraycreationexpression.vala
@@ -0,0 +1,89 @@
+/* valaarraycreationexpression.vala
+ *
+ * Copyright (C) 2006 Raffaele Sandrini
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Author:
+ * Raffaele Sandrini <rasa@gmx.ch>
+ */
+
+using GLib;
+
+/**
+ * Represents an array creation expression e.g. "new int[] {1,2,3}".
+ */
+public class Vala.ArrayCreationExpression : Expression {
+ /**
+ * The type of the elements of the array.
+ */
+ public TypeReference element_type { get; set construct; }
+
+ /**
+ * The rank of the array.
+ */
+ public int rank { get; set construct; }
+
+ /**
+ * The size for each dimension ascending from left to right.
+ */
+ private List<Expression> sizes;
+
+ /**
+ * The root array initializer list.
+ */
+ public InitializerList initializer_list { get; set construct; }
+
+ /**
+ * Add a size expression.
+ */
+ public void append_size (Expression! size) {
+ sizes.append (size);
+ }
+
+ /**
+ * Get the sizes for all dimensions ascending from left to right.
+ */
+ public ref List<weak Expression> get_sizes () {
+ return sizes.copy ();
+ }
+
+ public ArrayCreationExpression (TypeReference _element_type, int _rank, InitializerList _initializer, SourceReference source) {
+ element_type = _element_type;
+ rank = _rank;
+ initializer_list = _initializer;
+ source_reference = source;
+ }
+
+ public override void accept (CodeVisitor! visitor) {
+ if (element_type != null) {
+ element_type.accept (visitor);
+ }
+
+ if (sizes != null) {
+ foreach (Expression e in sizes) {
+ e.accept (visitor);
+ }
+ }
+
+ visitor.visit_begin_array_creation_expression (this);
+
+ if (initializer_list != null) {
+ initializer_list.accept (visitor);
+ }
+
+ visitor.visit_end_array_creation_expression (this);
+ }
+}