source file of the LilyPond music typesetter
- (c) 1997--2005 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+ (c) 1997--2008 Han-Wen Nienhuys <hanwen@xs4all.nl>
*/
#include "includable-lexer.hh"
#include <sstream>
+using namespace std;
#include "config.hh"
+
+#include "file-name.hh"
#include "file-path.hh"
+#include "international.hh"
+#include "main.hh"
#include "source-file.hh"
-#include "source.hh"
+#include "sources.hh"
#include "warn.hh"
-#include "main.hh"
#ifndef YY_BUF_SIZE
#define YY_BUF_SIZE 16384
(yy_buffer_stack != 0 ? yy_buffer_stack[yy_buffer_stack_top] : 0)
#endif
+extern bool relative_includes;
+
Includable_lexer::Includable_lexer ()
{
#if HAVE_FLEXLEXER_YY_CURRENT_BUFFER
yy_current_buffer = 0;
#endif
- allow_includes_b_ = true;
}
/** Set the new input file to NAME, remember old file. */
void
-Includable_lexer::new_input (String name, Sources *sources)
+Includable_lexer::new_input (string name, Sources *sources)
{
- if (!allow_includes_b_)
- {
- LexerError (_ ("include files are not allowed in safe mode").to_str0 ());
- return;
- }
+ string current_dir = dir_name (main_input_name_);
+ if (relative_includes)
+ current_dir = include_stack_.size () ? dir_name (include_stack_.back ()->name_string ()) : "";
- Source_file *file = sources->get_file (name);
+ Source_file *file = sources->get_file (name, current_dir);
if (!file)
{
- String msg = _f ("can't find file: `%s'", name);
+ string msg = _f ("cannot find file: `%s'", name);
msg += "\n";
msg += _f ("(search path: `%s')",
- sources->path_->to_string ().to_str0 ());
- msg += "\n";
- LexerError (msg.to_str0 ());
+ (current_dir.length () ? (current_dir + PATHSEP) : "") + sources->path_->to_string ().c_str ());
+ LexerError (msg.c_str ());
return;
}
- file_name_strings_.push (file->name_string ());
+ file_name_strings_.push_back (file->name_string ());
- char_count_stack_.push (0);
+ char_count_stack_.push_back (0);
if (yy_current_buffer)
- state_stack_.push (yy_current_buffer);
+ state_stack_.push_back (yy_current_buffer);
if (be_verbose_global)
- progress_indication (String ("[") + name);
+ progress_indication (string ("[") + file->name_string ());
- include_stack_.push (file);
+ include_stack_.push_back (file);
/* Ugh. We'd want to create a buffer from the bytes directly.
}
void
-Includable_lexer::new_input (String name, String data, Sources *sources)
+Includable_lexer::new_input (string name, string data, Sources *sources)
{
Source_file *file = new Source_file (name, data);
sources->add (file);
- file_name_strings_.push (name);
+ file_name_strings_.push_back (name);
- char_count_stack_.push (0);
+ char_count_stack_.push_back (0);
if (yy_current_buffer)
- state_stack_.push (yy_current_buffer);
+ state_stack_.push_back (yy_current_buffer);
if (be_verbose_global)
- progress_indication (String ("[") + name);
- include_stack_.push (file);
+ progress_indication (string ("[") + name);
+ include_stack_.push_back (file);
yy_switch_to_buffer (yy_create_buffer (file->get_istream (), YY_BUF_SIZE));
}
bool
Includable_lexer::close_input ()
{
- include_stack_.pop ();
- char_count_stack_.pop ();
+ include_stack_.pop_back ();
+ char_count_stack_.pop_back ();
if (be_verbose_global)
progress_indication ("]");
yy_delete_buffer (yy_current_buffer);
#if HAVE_FLEXLEXER_YY_CURRENT_BUFFER
yy_current_buffer = 0;
#endif
- if (state_stack_.is_empty ())
+ if (state_stack_.empty ())
{
#if HAVE_FLEXLEXER_YY_CURRENT_BUFFER
yy_current_buffer = 0;
#endif
return false;
}
- yy_switch_to_buffer (state_stack_.pop ());
+ yy_switch_to_buffer (state_stack_.back ());
+ state_stack_.pop_back ();
return true;
}
char const *
Includable_lexer::here_str0 () const
{
- if (include_stack_.is_empty ())
+ if (include_stack_.empty ())
return 0;
- return include_stack_.top ()->to_str0 () + char_count_stack_.top ();
+ return include_stack_.back ()->c_str () + char_count_stack_.back ();
}
Includable_lexer::~Includable_lexer ()
{
- while (!include_stack_.is_empty ())
- {
- close_input ();
- }
+ while (!include_stack_.empty ())
+ close_input ();
}
Source_file *
Includable_lexer::get_source_file () const
{
- if (include_stack_.is_empty ())
+ if (include_stack_.empty ())
return 0;
- else
- return include_stack_.top ();
+ return include_stack_.back ();
}