00001 /* 00002 The lestes compiler suite 00003 Copyright (C) 2002, 2003, 2004, 2005 Miroslav Tichy 00004 Copyright (C) 2002, 2003, 2004, 2005 Petr Zika 00005 Copyright (C) 2002, 2003, 2004, 2005 Vojtech Hala 00006 Copyright (C) 2002, 2003, 2004, 2005 Jiri Kosina 00007 Copyright (C) 2002, 2003, 2004, 2005 Pavel Sanda 00008 Copyright (C) 2002, 2003, 2004, 2005 Jan Zouhar 00009 Copyright (C) 2002, 2003, 2004, 2005 Rudolf Thomas 00010 00011 This program is free software; you can redistribute it and/or modify 00012 it under the terms of the GNU General Public License as published by 00013 the Free Software Foundation; version 2 of the License. 00014 00015 This program is distributed in the hope that it will be useful, 00016 but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00018 GNU General Public License for more details. 00019 00020 See the full text of the GNU General Public License version 2, and 00021 the limitations in the file doc/LICENSE. 00022 00023 By accepting the license the licensee waives any and all claims 00024 against the copyright holder(s) related in whole or in part to the 00025 work, its use, and/or the inability to use it. 00026 00027 */ 00028 #include <lestes/lang/cplus/lex/cpp_token.hh> 00029 #include <lestes/lang/cplus/sem/as_access_specifier_to_ss_access_specifier.g.hh> 00030 #include <lestes/lang/cplus/sem/as_base_specifier_to_ss_base_specifier.g.hh> 00031 #include <lestes/lang/cplus/sem/as_decl.g.hh> 00032 #include <lestes/lang/cplus/sem/as_id_to_declaration_set.g.hh> 00033 #include <lestes/lang/cplus/sem/sa_loggers.hh> 00034 #include <lestes/lang/cplus/sem/ss_declaration.g.hh> 00035 #include <lestes/lang/cplus/sem/ss_misc.g.hh> 00036 #include <lestes/lang/cplus/sem/ss_type.g.hh> 00037 #include <lestes/msg/logger.hh> 00038 #include <lestes/msg/logger_util.hh> 00039 //#include <lestes/lang/cplus/syn/token.hh> 00040 00041 00042 package(lestes); 00043 package(lang); 00044 package(cplus); 00045 package(sem); 00046 00047 /*! 00048 \todo TMA after lookup: look up the class 00049 */ 00050 ptr < ss_base_specifier > as_base_specifier_to_ss_base_specifier::process(ptr < as_base_specifier > bs) 00051 { 00052 bool is_virtual_base = bs->virtual_base_get(); 00053 ss_access_specifier::type access_specifier; 00054 00055 sa_class_base_logger << "base\n" << msg::eolog; 00056 00057 if (bs->access_specifier_get()) { 00058 sa_class_base_logger << "access specifier given\n" << msg::eolog; 00059 access_specifier = as_access_specifier_to_ss_access_specifier::create()->process(bs->access_specifier_get()); 00060 } else { 00061 sa_class_base_logger << "access specifier default\n" << msg::eolog; 00062 access_specifier = default_access_specifier_get(); 00063 } 00064 00065 sa_class_base_logger << "base type FIXME\n" << msg::eolog; 00066 /* FIXME: lookup here */ 00067 ptr < as_name > name = bs->class_name_get(); 00068 lassert(name); 00069 ptr < as_identifier > id = name->identifier_get().dncast<as_identifier>(); 00070 lassert(id); 00071 00072 ptr < set < srp < ss_declaration > > > decls = as_id_to_declaration_set::instance()->process(id); 00073 if (decls->empty()) { 00074 lassert2(false, "FIXME report"); 00075 //report << identifier_shall_have_a_visible_declaration << name->location_get(); 00076 } 00077 if (decls->size() != 1) { 00078 lassert2(false, "FIXME report"); 00079 //report << identifier_shall_name_a_unique_class << name->location_get(); 00080 } 00081 ptr < ss_structure_declaration > decl = decls->begin()->dncast<ss_structure_declaration>(); 00082 ptr < ss_class > a_class = decl->type_get().dncast<ss_class>(); 00083 if (! a_class->completion_time_get()->is_before(ss_declaration_time::infinity())) { 00084 lassert2(false, "FIXME report"); 00085 //report << incomplete_class_shall_not_be_base << name->location_get(); 00086 } 00087 00088 sa_class_base_logger << "ss_base_specifier::create\n" << msg::eolog; 00089 return ss_base_specifier::create(bs->location_get(), access_specifier, a_class, is_virtual_base); 00090 } 00091 00092 ptr< ::lestes::std::list < srp < ss_base_specifier > > > as_base_specifier_to_ss_base_specifier::process_list(ptr< ::lestes::std::list < srp < as_base_specifier > > > l) 00093 { 00094 ::lestes::std::list < srp < as_base_specifier > >::iterator it = l->begin(); 00095 ptr< ::lestes::std::list < srp < ss_base_specifier > > > r = ::lestes::std::list < srp < ss_base_specifier > >::create(); 00096 00097 for (; it != l->end(); ++it) { 00098 r->push_back(process(*it)); 00099 } 00100 return r; 00101 } 00102 00103 end_package(sem); 00104 end_package(cplus); 00105 end_package(lang); 00106 end_package(lestes); 00107
1.5.1-20070107