summaryrefslogtreecommitdiff
path: root/cpp/rubygen/cppgen.rb
diff options
context:
space:
mode:
authorAlan Conway <aconway@apache.org>2007-08-01 16:50:33 +0000
committerAlan Conway <aconway@apache.org>2007-08-01 16:50:33 +0000
commit28b22a308cb6cf0232067636fb6676a4c96d82f7 (patch)
tree1f5b4cd32c425ffda3a7295dd47f0aaba3c0ce25 /cpp/rubygen/cppgen.rb
parent9235b5d09b3273c7c495ff266e18781fad363a9b (diff)
downloadqpid-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-xcpp/rubygen/cppgen.rb25
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