as_base_specifier_to_ss_base_specifier.cc

Go to the documentation of this file.
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 

Generated on Mon Feb 12 18:22:11 2007 for lestes by doxygen 1.5.1-20070107