diff options
| author | Alan Conway <aconway@apache.org> | 2007-08-09 00:03:43 +0000 |
|---|---|---|
| committer | Alan Conway <aconway@apache.org> | 2007-08-09 00:03:43 +0000 |
| commit | ba57e373864d44cfae17ec8c2c9de7a55f0b4113 (patch) | |
| tree | bb16616df6e2a48b9cf164a52ca30fa99f90e1fd /cpp/rubygen/samples | |
| parent | b3eb629f662dc2df11ce3981a7c4cc8ab58a8c28 (diff) | |
| download | qpid-python-ba57e373864d44cfae17ec8c2c9de7a55f0b4113.tar.gz | |
Moved Proxy generation to rubygen.
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@564051 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/rubygen/samples')
| -rwxr-xr-x | cpp/rubygen/samples/Proxy.rb | 153 |
1 files changed, 0 insertions, 153 deletions
diff --git a/cpp/rubygen/samples/Proxy.rb b/cpp/rubygen/samples/Proxy.rb deleted file mode 100755 index f7765f3729..0000000000 --- a/cpp/rubygen/samples/Proxy.rb +++ /dev/null @@ -1,153 +0,0 @@ -#!/usr/bin/env ruby -$: << ".." # Include .. in load path -require 'cppgen' - -class ProxyGen < CppGen - - def initialize(chassis, outdir, amqp) - super(outdir, amqp) - @chassis=chassis - @classname="AMQP_#{@chassis.caps}Proxy" - end - - def include(m) gen "#include \"#{m.body_name}.h\"\n"; end - - def proxy_member(c) c.name.lcaps+"Proxy"; end - - def inner_class_decl(c) - cname=c.name.caps - gen <<EOS - // ==================== class #{cname} ==================== - class #{cname} - { - private: - ChannelAdapter& channel; - - public: - // Constructors and destructors - - #{cname}(ChannelAdapter& ch) : - channel(ch) {} - virtual ~#{cname}() {} - - static #{cname}& get(#{@classname}& proxy) { return proxy.get#{cname}();} - - // Protocol methods -EOS - indent(2) { c.methods_on(@chassis).each { |m| inner_method_decl(m) } } - gen "\n }; // class #{cname}\n\n" - end - - def inner_method_decl(m) - gen "virtual void #{m.cppname}(#{m.signature.join(",\n ")})\n\n"; - end - - def inner_class_defn(c) - cname=c.cppname - gen "// ==================== class #{cname} ====================\n" - c.methods_on(@chassis).each { |m| inner_method_defn(m, cname) } - end - - def inner_method_defn(m,cname) - if m.response? - rettype="void" - ret="" - sigadd=["RequestId responseTo"] - paramadd=["channel.getVersion(), responseTo"] - else - rettype="RequestId" - ret="return " - sigadd=[] - paramadd=["channel.getVersion()"] - end - sig=(m.signature+sigadd).join(", ") - params=(paramadd+m.param_names).join(",\n ") - gen <<EOS -#{rettype} #{@classname}::#{cname}::#{m.cppname}(#{sig}) { - #{ret}channel.send(new #{m.body_name}(#{params})); -} - -EOS - end - - def get_decl(c) - cname=c.name.caps - gen " #{cname}& #{@classname}::get#{cname}();\n" - end - - def get_defn(c) - cname=c.name.caps - gen <<EOS -#{@classname}::#{c.name.caps}& #{@classname}::get#{c.name.caps}() -{ - return #{proxy_member(c)}; -} -EOS - end - - def generate - # .h file - h_file(@classname+".h") { - gen <<EOS -#include "qpid/framing/Proxy.h" - -namespace qpid { -namespace framing { - -class #{@classname} : public Proxy -{ -public: - #{@classname}(ChannelAdapter& ch); - - // Inner class definitions -EOS - @amqp.classes.each{ |c| inner_class_decl(c) } - gen " // Inner class instance get methods\n" - @amqp.classes.each{ |c| get_decl(c) } - gen <<EOS - private: - // Inner class instances -EOS - indent { @amqp.classes.each{ |c| gen c.cppname+" "+proxy_member(c)+";\n" } } - gen <<EOS -}; /* class #{@classname} */ - -} /* namespace framing */ -} /* namespace qpid */ -EOS - } - - # .cpp file - cpp_file(@classname+".cpp") { - gen <<EOS -#include <sstream> -#include "#{@classname}.h" -#include "qpid/framing/ChannelAdapter.h" -#include "qpid/framing/amqp_types_full.h" -EOS - @amqp.methods_on(@chassis).each { |m| include(m) } - gen <<EOS -namespace qpid { -namespace framing { - -#{@classname}::#{@classname}(ChannelAdapter& ch) : -EOS - gen " Proxy(ch)" - @amqp.classes.each { |c| gen ",\n "+proxy_member(c)+"(channel)" } - gen <<EOS - {} - - // Inner class instance get methods -EOS - @amqp.classes.each { |c| get_defn(c) } - gen " // Inner class implementation\n\n" - @amqp.classes.each { |c| inner_class_defn(c) } - gen "}} // namespae qpid::framing" - } - end -end - - -ProxyGen.new("client", ARGV[0], Amqp).generate; -ProxyGen.new("server", ARGV[0], Amqp).generate; - |
