From b0f28bd39db1732db794c6ba1f02d244bce0641c Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Thu, 10 Mar 2011 11:37:49 +0200 Subject: Move tracer to new ctor-less context --- odb/tracer/generate.hxx | 30 ++++++++++++++++++++++++++++ odb/tracer/header.cxx | 45 +++++++++++++++++++++-------------------- odb/tracer/header.hxx | 17 ---------------- odb/tracer/inline.cxx | 45 +++++++++++++++++++++-------------------- odb/tracer/inline.hxx | 17 ---------------- odb/tracer/source.cxx | 53 ++++++++++++++++++++++++++----------------------- odb/tracer/source.hxx | 17 ---------------- 7 files changed, 106 insertions(+), 118 deletions(-) create mode 100644 odb/tracer/generate.hxx delete mode 100644 odb/tracer/header.hxx delete mode 100644 odb/tracer/inline.hxx delete mode 100644 odb/tracer/source.hxx (limited to 'odb/tracer') diff --git a/odb/tracer/generate.hxx b/odb/tracer/generate.hxx new file mode 100644 index 0000000..32cd993 --- /dev/null +++ b/odb/tracer/generate.hxx @@ -0,0 +1,30 @@ +// file : odb/tracer/generate.hxx +// author : Boris Kolpackov +// copyright : Copyright (c) 2009-2011 Code Synthesis Tools CC +// license : GNU GPL v3; see accompanying LICENSE file + +#ifndef ODB_TRACER_GENERATE_HXX +#define ODB_TRACER_GENERATE_HXX + +namespace tracer +{ + namespace header + { + void + generate (); + } + + namespace inline_ + { + void + generate (); + } + + namespace source + { + void + generate (); + } +} + +#endif // ODB_TRACER_GENERATE_HXX diff --git a/odb/tracer/header.cxx b/odb/tracer/header.cxx index 74a27af..c8c5a43 100644 --- a/odb/tracer/header.cxx +++ b/odb/tracer/header.cxx @@ -4,7 +4,9 @@ // license : GNU GPL v3; see accompanying LICENSE file #include -#include +#include + +using namespace std; namespace tracer { @@ -12,11 +14,6 @@ namespace tracer { struct class_: traversal::class_, context { - class_ (context& c) - : context (c) - { - } - virtual void traverse (type& c) { @@ -95,27 +92,33 @@ namespace tracer }; } - void - generate_header (context& ctx) + namespace header { - traversal::unit unit; - traversal::defines unit_defines; - traversal::namespace_ ns; - class_ c (ctx); + void + generate () + { + context ctx; + ostream& os (ctx.os); + + traversal::unit unit; + traversal::defines unit_defines; + traversal::namespace_ ns; + class_ c; - unit >> unit_defines >> ns; - unit_defines >> c; + unit >> unit_defines >> ns; + unit_defines >> c; - traversal::defines ns_defines; + traversal::defines ns_defines; - ns >> ns_defines >> ns; - ns_defines >> c; + ns >> ns_defines >> ns; + ns_defines >> c; - ctx.os << "namespace odb" - << "{"; + os << "namespace odb" + << "{"; - unit.dispatch (ctx.unit); + unit.dispatch (ctx.unit); - ctx.os << "}"; + os << "}"; + } } } diff --git a/odb/tracer/header.hxx b/odb/tracer/header.hxx deleted file mode 100644 index 761b292..0000000 --- a/odb/tracer/header.hxx +++ /dev/null @@ -1,17 +0,0 @@ -// file : odb/tracer/header.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2009-2011 Code Synthesis Tools CC -// license : GNU GPL v3; see accompanying LICENSE file - -#ifndef ODB_TRACER_HEADER_HXX -#define ODB_TRACER_HEADER_HXX - -#include - -namespace tracer -{ - void - generate_header (context&); -} - -#endif // ODB_TRACER_HEADER_HXX diff --git a/odb/tracer/inline.cxx b/odb/tracer/inline.cxx index b8b658e..bf5f0f4 100644 --- a/odb/tracer/inline.cxx +++ b/odb/tracer/inline.cxx @@ -4,7 +4,9 @@ // license : GNU GPL v3; see accompanying LICENSE file #include -#include +#include + +using namespace std; namespace tracer { @@ -12,11 +14,6 @@ namespace tracer { struct class_: traversal::class_, context { - class_ (context& c) - : context (c) - { - } - virtual void traverse (type& c) { @@ -48,27 +45,33 @@ namespace tracer }; } - void - generate_inline (context& ctx) + namespace inline_ { - traversal::unit unit; - traversal::defines unit_defines; - traversal::namespace_ ns; - class_ c (ctx); + void + generate () + { + context ctx; + ostream& os (ctx.os); + + traversal::unit unit; + traversal::defines unit_defines; + traversal::namespace_ ns; + class_ c; - unit >> unit_defines >> ns; - unit_defines >> c; + unit >> unit_defines >> ns; + unit_defines >> c; - traversal::defines ns_defines; + traversal::defines ns_defines; - ns >> ns_defines >> ns; - ns_defines >> c; + ns >> ns_defines >> ns; + ns_defines >> c; - ctx.os << "namespace odb" - << "{"; + os << "namespace odb" + << "{"; - unit.dispatch (ctx.unit); + unit.dispatch (ctx.unit); - ctx.os << "}"; + os << "}"; + } } } diff --git a/odb/tracer/inline.hxx b/odb/tracer/inline.hxx deleted file mode 100644 index 353587c..0000000 --- a/odb/tracer/inline.hxx +++ /dev/null @@ -1,17 +0,0 @@ -// file : odb/tracer/inline.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2009-2011 Code Synthesis Tools CC -// license : GNU GPL v3; see accompanying LICENSE file - -#ifndef ODB_TRACER_INLINE_HXX -#define ODB_TRACER_INLINE_HXX - -#include - -namespace tracer -{ - void - generate_inline (context&); -} - -#endif // ODB_TRACER_INLINE_HXX diff --git a/odb/tracer/source.cxx b/odb/tracer/source.cxx index c0f64c4..73f0a8a 100644 --- a/odb/tracer/source.cxx +++ b/odb/tracer/source.cxx @@ -4,7 +4,9 @@ // license : GNU GPL v3; see accompanying LICENSE file #include -#include +#include + +using namespace std; namespace tracer { @@ -12,11 +14,6 @@ namespace tracer { struct class_: traversal::class_, context { - class_ (context& c) - : context (c) - { - } - virtual void traverse (type& c) { @@ -117,33 +114,39 @@ namespace tracer }; } - void - generate_source (context& ctx) + namespace source { - traversal::unit unit; - traversal::defines unit_defines; - traversal::namespace_ ns; - class_ c (ctx); + void + generate () + { + context ctx; + ostream& os (ctx.os); - unit >> unit_defines >> ns; - unit_defines >> c; + traversal::unit unit; + traversal::defines unit_defines; + traversal::namespace_ ns; + class_ c; - traversal::defines ns_defines; + unit >> unit_defines >> ns; + unit_defines >> c; - ns >> ns_defines >> ns; - ns_defines >> c; + traversal::defines ns_defines; - ctx.os << "#include " << endl - << endl; + ns >> ns_defines >> ns; + ns_defines >> c; - ctx.os << "#include " << endl - << endl; + os << "#include " << endl + << endl; + + os << "#include " << endl + << endl; - ctx.os << "namespace odb" - << "{"; + os << "namespace odb" + << "{"; - unit.dispatch (ctx.unit); + unit.dispatch (ctx.unit); - ctx.os << "}"; + os << "}"; + } } } diff --git a/odb/tracer/source.hxx b/odb/tracer/source.hxx deleted file mode 100644 index a18fec6..0000000 --- a/odb/tracer/source.hxx +++ /dev/null @@ -1,17 +0,0 @@ -// file : odb/tracer/source.hxx -// author : Boris Kolpackov -// copyright : Copyright (c) 2009-2011 Code Synthesis Tools CC -// license : GNU GPL v3; see accompanying LICENSE file - -#ifndef ODB_TRACER_SOURCE_HXX -#define ODB_TRACER_SOURCE_HXX - -#include - -namespace tracer -{ - void - generate_source (context&); -} - -#endif // ODB_TRACER_SOURCE_HXX -- cgit v1.1