aboutsummaryrefslogtreecommitdiff
path: root/odb/include.cxx
diff options
context:
space:
mode:
authorBoris Kolpackov <boris@codesynthesis.com>2011-04-24 18:07:18 +0200
committerBoris Kolpackov <boris@codesynthesis.com>2011-04-24 18:07:18 +0200
commit698d170bb92d30feeb67b8ba23c8a8a134c3cf16 (patch)
treef9cf5f9daf51eab641b593dbdccbbdf5464da319 /odb/include.cxx
parentb9fe963646367f2da21ba1053bc086bd17b09967 (diff)
Add --odb-{prologue,epilogue}-file options
Diffstat (limited to 'odb/include.cxx')
-rw-r--r--odb/include.cxx49
1 files changed, 41 insertions, 8 deletions
diff --git a/odb/include.cxx b/odb/include.cxx
index ccdc8bc..de3be4a 100644
--- a/odb/include.cxx
+++ b/odb/include.cxx
@@ -121,8 +121,9 @@ namespace
}
void
- parse_file (string const& f, include_lines& lines)
+ parse_file (string const& file, include_lines& lines)
{
+ string f (file);
size_t n (f.size ());
// Check if we have a synthesized prologue/epilogue fragment.
@@ -144,24 +145,42 @@ namespace
istr >> n;
}
+ n--; // Prologues/epilogues are counted from 1.
+
stringstream ss;
+ f.clear ();
// We don't need the #line part.
//
if (name == "odb-prologue")
- ss << options_.odb_prologue ()[n - 1];
+ {
+ size_t size (options_.odb_prologue ().size ());
+
+ if (n < size)
+ ss << options_.odb_prologue ()[n];
+ else
+ f = options_.odb_prologue_file ()[n - size];
+ }
else
- ss << options_.odb_epilogue ()[n - 1];
+ {
+ size_t size (options_.odb_epilogue ().size ());
- ss << endl;
+ if (n < size)
+ ss << options_.odb_epilogue ()[n];
+ else
+ f = options_.odb_epilogue_file ()[n - size];
+ }
- parse_stream (ss, f, lines);
- return;
+ if (f.empty ())
+ {
+ parse_stream (ss, file, lines);
+ return;
+ }
+ // Otherwise use the code below to parse the file.
}
}
}
-
ifstream is (f.c_str ());
if (!is.is_open ())
@@ -183,9 +202,23 @@ namespace
string line;
bool bslash (false);
size_t lb (1), le (1);
+ bool eof (false);
- for (int_type c (is.get ()); is.good (); c = is.get ())
+ for (int_type c (is.get ()); !eof; c = is.get ())
{
+ if (is.fail ())
+ {
+ if (is.eof ())
+ {
+ // If we are still in the range, treat this as the last newline.
+ //
+ c = '\n';
+ eof = true;
+ }
+ else
+ break; // Some other failure -- bail out.
+ }
+
if (c == '\n')
{
le++;