vala: Allow read-only properties
[vala-gnome.git] / vala / valadestructor.vala
blob7ee3843bd0e80b8b7597d5dad2464d3ea944b0e3
1 /* valadestructor.vala
3 * Copyright (C) 2006-2010 Jürg Billeter
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2.1 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19 * Author:
20 * Jürg Billeter <j@bitron.ch>
23 using GLib;
25 /**
26 * Represents a class or instance destructor.
28 public class Vala.Destructor : Subroutine {
29 /**
30 * Specifies the generated `this` parameter for instance methods.
32 public Parameter this_parameter { get; set; }
34 /**
35 * Specifies whether this is an instance or a class destructor.
37 public MemberBinding binding { get; set; default = MemberBinding.INSTANCE; }
39 public override bool has_result {
40 get { return false; }
43 /**
44 * Creates a new destructor.
46 * @param source_reference reference to source code
47 * @return newly created destructor
49 public Destructor (SourceReference? source_reference = null) {
50 base (null, source_reference);
53 public override void accept (CodeVisitor visitor) {
54 visitor.visit_destructor (this);
57 public override void accept_children (CodeVisitor visitor) {
58 if (body != null) {
59 body.accept (visitor);
63 public override bool check (CodeContext context) {
64 if (checked) {
65 return !error;
68 checked = true;
70 owner = context.analyzer.current_symbol.scope;
71 context.analyzer.current_symbol = this;
73 if (body != null) {
74 body.check (context);
77 context.analyzer.current_symbol = context.analyzer.current_symbol.parent_symbol;
79 return !error;