8 #include <boost/filesystem.hpp> 9 #include <boost/format.hpp> 23 namespace classic = boost::spirit::classic;
24 namespace bf = boost::filesystem;
36 while ( !ifs.
eof() ) {
43 ifs.
seekg( 0, ifs.beg );
46 template <
typename Grammar>
50 int last_line, last_column;
52 GetLastLineAndColumn( stream, last_line, last_column );
58 ForwardIterator fwd_begin = boost::spirit::make_default_multi_pass( in_begin );
63 Iterator position_begin( fwd_begin, fwd_end, stream_name );
67 gp::SkipperGrammar<Iterator> skipper;
69 root->value = stream_name;
70 bool result = qi::phrase_parse( position_begin, position_end, gr, skipper, *root );
73 if ( result && ( pos.line == last_line ) && ( pos.column == last_column ) ) {
77 messages->AddError( gp::Position( stream_name, pos.line, pos.column ),
"parse error" );
82 template <
typename Grammar>
84 gp::IncludedFiles* included, gp::Messages* messages, gp::Node* root )
87 if ( !from.filename().empty() ) {
88 bf::path file_path( from.filename() );
89 search_path_with_current_dir =
90 file_path.parent_path().
string() +
91 ( search_path_with_current_dir.empty() ?
"" : (
"," + search_path_with_current_dir ) );
96 if ( absolute_path.
empty() ) {
97 messages->AddError( from,
"Couldn't find a file " + filename +
" in search path '" +
98 search_path_with_current_dir +
"'" );
101 const gp::Position* included_from;
102 if ( !included->GetPosition( absolute_path, &included_from ) ) {
103 included->AddFile( absolute_path, from );
105 if ( !file.is_open() ) {
106 messages->AddError( from,
"Couldn't open a file " + filename );
109 return ParseStream<Grammar>( file, absolute_path, messages,
root );
111 assert( included_from != NULL );
112 messages->AddWarning( from, str(
boost::format(
"File %1% already included from %2%" ) % absolute_path %
113 included_from->ToString() ) );
123 return Parse(
Position(), filename, search_path, included, messages, root );
130 return ParseFile<Grammar>( from,
filename, search_path, included, messages,
root );
138 return ParseFile<Grammar>( from,
filename, search_path, included, messages,
root );
GAUDI_API std::string format(const char *,...)
MsgStream format utility "a la sprintf(...)".
bool ParseUnits(const Position &from, const std::string &filename, const std::string &search_path, IncludedFiles *included, Messages *messages, Node *root)
static std::string find_file_from_list(const std::string &logical_file_name, const std::string &search_list, SearchType search_type=LocalSearch)
std::string::const_iterator BaseIterator
std::string replaceEnvironments(const std::string &input)
boost::spirit::multi_pass< BaseIterator > ForwardIterator
bool Parse(const std::string &filename, const std::string &search_path, IncludedFiles *included, Messages *messages, Node *root)
boost::spirit::classic::position_iterator2< ForwardIterator > Iterator
boost::spirit::classic::file_position_base< std::string > IteratorPosition