THRIFT-707. Support old-style constructors for Union structs
authorBryan Duxbury <bryanduxbury@apache.org>
Wed, 17 Feb 2010 22:27:27 +0000 (22:27 +0000)
committerBryan Duxbury <bryanduxbury@apache.org>
Wed, 17 Feb 2010 22:27:27 +0000 (22:27 +0000)
git-svn-id: https://svn.apache.org/repos/asf/incubator/thrift/trunk@911199 13f79535-47bb-0310-9956-ffa450edef68

lib/rb/lib/thrift/union.rb
lib/rb/spec/union_spec.rb

index 0b41ed4..e443d42 100644 (file)
@@ -21,6 +21,14 @@ module Thrift
   class Union
     def initialize(name=nil, value=nil)
       if name
+        if name.is_a? Hash
+          if name.size > 1
+            raise "#{self.class} cannot be instantiated with more than one field!"
+          end
+
+          name, value = name.keys.first, name.values.first
+        end
+
         if value.nil?
           raise Exception, "Union #{self.class} cannot be instantiated with setfield and nil value!"
         end
index 4835288..07a3f94 100644 (file)
@@ -141,5 +141,11 @@ class ThriftUnionSpec < Spec::ExampleGroup
       swu2.read(proto)
       swu2.should == swu
     end
+    
+    it "should support old style constructor" do
+      union = My_union.new(:integer32 => 26)
+      union.get_set_field.should == :integer32
+      union.get_value.should == 26
+    end
   end
 end