diff options
author | Alan Conway <aconway@apache.org> | 2007-08-01 16:50:33 +0000 |
---|---|---|
committer | Alan Conway <aconway@apache.org> | 2007-08-01 16:50:33 +0000 |
commit | 28b22a308cb6cf0232067636fb6676a4c96d82f7 (patch) | |
tree | 1f5b4cd32c425ffda3a7295dd47f0aaba3c0ce25 /cpp/rubygen/cppgen.rb | |
parent | 9235b5d09b3273c7c495ff266e18781fad363a9b (diff) | |
download | qpid-python-28b22a308cb6cf0232067636fb6676a4c96d82f7.tar.gz |
* src/generate.sh: Moved requirements test to configure.ac
* rubygen: Cleanup and improvements, template for cluster work.
* configure.ac:
- support for ruby code generator + cleanup.
- moved "can generate" tests to configure.ac
- removed redundant APR stuff.
* bootstrap: Remove codegen from bootstrap, all in config/make.
* src/Makefile.am (libqpidcommon_la_LIBADD):
- Ruby code generator.
- Improvements to existing generator rules.
- Removed APR stuff.
* configure.ac (CPPUNIT_CXXFLAGS): Removed APR stuff.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@561869 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/rubygen/cppgen.rb')
-rwxr-xr-x | cpp/rubygen/cppgen.rb | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/cpp/rubygen/cppgen.rb b/cpp/rubygen/cppgen.rb index 3e3800c4cd..b5f4758411 100755 --- a/cpp/rubygen/cppgen.rb +++ b/cpp/rubygen/cppgen.rb @@ -105,6 +105,7 @@ class CppGen < Generator # Write a header file. def h_file(path) + path = (/\.h$/ === path ? path : path+".h") guard=path.upcase.tr('./-','_') file(path) { gen "#ifndef #{guard}\n" @@ -122,5 +123,29 @@ class CppGen < Generator yield end end + + def include(header) genl "#include \"#{header}\""; end + + def scope(open="{",close="}", &block) + genl open; indent(&block); genl close + end + + def namespace(name, &block) + names = name.split("::") + names.each { |n| genl "namespace #{n} {" } + yield + genl('}'*names.size+" // "+name) + end + + def struct_class(type, name, *bases, &block) + gen "#{type} #{name}" + gen ": #{bases.join(', ')}" unless bases.empty + genl "{" + yield + genl "};" + end + + def struct(name, *bases, &block) struc_class("struct", bases, &block); end + def class_(name, *bases, &block) struc_class("struct", bases, &block); end end |