diff options
author | Boris Kolpackov <boris@codesynthesis.com> | 2011-03-10 11:37:49 +0200 |
---|---|---|
committer | Boris Kolpackov <boris@codesynthesis.com> | 2011-03-21 15:40:00 +0200 |
commit | b0f28bd39db1732db794c6ba1f02d244bce0641c (patch) | |
tree | ffe5c5898eed770b4a8256b9e78c9b1792feb70e /odb/tracer | |
parent | ecf31f6252c7c02935a6ce174d6700beb3f0b7fa (diff) |
Move tracer to new ctor-less context
Diffstat (limited to 'odb/tracer')
-rw-r--r-- | odb/tracer/generate.hxx | 30 | ||||
-rw-r--r-- | odb/tracer/header.cxx | 45 | ||||
-rw-r--r-- | odb/tracer/header.hxx | 17 | ||||
-rw-r--r-- | odb/tracer/inline.cxx | 45 | ||||
-rw-r--r-- | odb/tracer/inline.hxx | 17 | ||||
-rw-r--r-- | odb/tracer/source.cxx | 53 | ||||
-rw-r--r-- | odb/tracer/source.hxx | 17 |
7 files changed, 106 insertions, 118 deletions
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 <boris@codesynthesis.com> +// 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 <odb/common.hxx> -#include <odb/tracer/header.hxx> +#include <odb/tracer/generate.hxx> + +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 <boris@codesynthesis.com> -// 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 <odb/context.hxx> - -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 <odb/common.hxx> -#include <odb/tracer/inline.hxx> +#include <odb/tracer/generate.hxx> + +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 <boris@codesynthesis.com> -// 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 <odb/context.hxx> - -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 <odb/common.hxx> -#include <odb/tracer/source.hxx> +#include <odb/tracer/generate.hxx> + +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 <iostream>" << endl - << endl; + ns >> ns_defines >> ns; + ns_defines >> c; - ctx.os << "#include <odb/exceptions.hxx>" << endl - << endl; + os << "#include <iostream>" << endl + << endl; + + os << "#include <odb/exceptions.hxx>" << 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 <boris@codesynthesis.com> -// 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 <odb/context.hxx> - -namespace tracer -{ - void - generate_source (context&); -} - -#endif // ODB_TRACER_SOURCE_HXX |