OSDN Git Service

8c688761098eab8a68a12d7f51fb5e30040eb276
[pf3gnuchains/gcc-fork.git] / gcc / objcp / objcp-decl.c
1 /* Process the ObjC-specific declarations and variables for 
2    the Objective-C++ compiler.
3    Copyright (C) 2005, 2007 Free Software Foundation, Inc.
4    Contributed by Ziemowit Laski  <zlaski@apple.com>
5
6 This file is part of GCC.
7
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 3, or (at your option) any later
11 version.
12
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
16 for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING3.  If not see
20 <http://www.gnu.org/licenses/>.  */
21
22 #include "config.h"
23 #include "system.h"
24 #include "coretypes.h"
25 #include "tm.h"
26 #include "tree.h"
27 #include "cp-tree.h"
28
29 #include "objc-act.h"
30 #include "objcp-decl.h"
31
32 /* Hacks to simulate start_struct() and finish_struct(). */
33
34 tree 
35 objcp_start_struct (location_t loc ATTRIBUTE_UNUSED,
36                     enum tree_code code ATTRIBUTE_UNUSED, tree name)
37 {
38   tree s;
39   /* The idea here is to mimic the actions that the C++ parser takes when
40      constructing 'extern "C" struct NAME {'.  */
41   push_lang_context (lang_name_c);
42
43   if (!name)
44     name = make_anon_name ();
45
46   s = xref_tag (record_type, name, ts_global, 0);
47   CLASSTYPE_DECLARED_CLASS (s) = 0;  /* this is a 'struct', not a 'class'.  */
48   xref_basetypes (s, NULL_TREE);     /* no base classes here!  */
49
50   return begin_class_definition (s, NULL_TREE);
51 }
52
53 tree 
54 objcp_finish_struct (location_t loc ATTRIBUTE_UNUSED,
55                      tree t, tree fieldlist, tree attributes)
56 {
57   tree field, next_field;
58
59   for (field = fieldlist; field; field = next_field)
60   {
61     next_field = TREE_CHAIN (field);      /* insert one field at a time;  */
62     TREE_CHAIN (field) = NULL_TREE;       /* otherwise, grokfield croaks. */
63     finish_member_declaration (field);
64   }
65   t = finish_struct (t, attributes);
66   pop_lang_context ();
67
68   return t;
69 }
70
71 void
72 objcp_finish_function (void)
73 {
74   /* The C++ flavor of 'finish_function' does not generate RTL -- one has
75      to call 'expand_or_defer_fn' to do that.  */
76   expand_or_defer_fn (finish_function (0));
77 }
78
79 tree
80 objcp_xref_tag (enum tree_code code ATTRIBUTE_UNUSED, tree name)
81 {
82   return xref_tag (record_type, name, ts_global, false);
83 }
84
85 int
86 objcp_comptypes (tree type1, tree type2)
87 {     
88   return comptypes (type1, type2, COMPARE_STRICT);
89 }
90
91 tree
92 objcp_begin_compound_stmt (int flags ATTRIBUTE_UNUSED)
93 {
94   return begin_compound_stmt (0);
95 }
96
97 tree
98 objcp_end_compound_stmt (tree stmt, int flags ATTRIBUTE_UNUSED)
99 {
100   /* The following has been snarfed from
101      cp/semantics.c:finish_compound_stmt().  */
102   if (TREE_CODE (stmt) == BIND_EXPR)
103     BIND_EXPR_BODY (stmt) = do_poplevel (BIND_EXPR_BODY (stmt));
104   else if (STATEMENT_LIST_NO_SCOPE (stmt))
105     stmt = pop_stmt_list (stmt);
106   else
107     stmt = do_poplevel (stmt);
108
109   return stmt;
110 }