aboutsummaryrefslogtreecommitdiffstats
path: root/actionwebservice/lib/action_web_service
diff options
context:
space:
mode:
Diffstat (limited to 'actionwebservice/lib/action_web_service')
-rw-r--r--actionwebservice/lib/action_web_service/api.rb22
-rw-r--r--actionwebservice/lib/action_web_service/support/signature_types.rb15
2 files changed, 31 insertions, 6 deletions
diff --git a/actionwebservice/lib/action_web_service/api.rb b/actionwebservice/lib/action_web_service/api.rb
index 87ac1b164e..d4a42f99ef 100644
--- a/actionwebservice/lib/action_web_service/api.rb
+++ b/actionwebservice/lib/action_web_service/api.rb
@@ -204,6 +204,16 @@ module ActionWebService # :nodoc:
h
end
+ # Backwards compatibility with previous API
+ def [](sig_type)
+ case sig_type
+ when :expects
+ @expects.map{|x| compat_signature_entry(x)}
+ when :returns
+ @returns.map{|x| compat_signature_entry(x)}
+ end
+ end
+
# String representation of this method
def to_s
fqn = ""
@@ -215,6 +225,18 @@ module ActionWebService # :nodoc:
end
private
+ def compat_signature_entry(entry)
+ if entry.array?
+ [compat_signature_entry(entry.element_type)]
+ else
+ if entry.spec.is_a?(Hash)
+ {entry.spec.keys.first => entry.type_class}
+ else
+ entry.type_class
+ end
+ end
+ end
+
def friendly_param(type, show_name=true)
name = type.name.to_s
type_type = type.array?? type.element_type.type.to_s : type.type.to_s
diff --git a/actionwebservice/lib/action_web_service/support/signature_types.rb b/actionwebservice/lib/action_web_service/support/signature_types.rb
index 65f63d16e1..4ab4a08d9b 100644
--- a/actionwebservice/lib/action_web_service/support/signature_types.rb
+++ b/actionwebservice/lib/action_web_service/support/signature_types.rb
@@ -10,19 +10,20 @@ module ActionWebService # :nodoc:
end
def canonical_signature_entry(spec, i)
+ orig_spec = spec
name = "param#{i}"
if spec.is_a?(Hash)
name, spec = spec.keys.first, spec.values.first
end
type = spec
if spec.is_a?(Array)
- ArrayType.new(canonical_signature_entry(spec[0], 0), name)
+ ArrayType.new(orig_spec, canonical_signature_entry(spec[0], 0), name)
else
type = canonical_type(type)
if type.is_a?(Symbol)
- BaseType.new(type, name)
+ BaseType.new(orig_spec, type, name)
else
- StructuredType.new(type, name)
+ StructuredType.new(orig_spec, type, name)
end
end
end
@@ -126,11 +127,13 @@ module ActionWebService # :nodoc:
class BaseType # :nodoc:
include SignatureTypes
+ attr :spec
attr :type
attr :type_class
attr :name
- def initialize(type, name)
+ def initialize(spec, type, name)
+ @spec = spec
@type = canonical_type(type)
@type_class = canonical_type_class(@type)
@name = name
@@ -152,8 +155,8 @@ module ActionWebService # :nodoc:
class ArrayType < BaseType # :nodoc:
attr :element_type
- def initialize(element_type, name)
- super(Array, name)
+ def initialize(spec, element_type, name)
+ super(spec, Array, name)
@element_type = element_type
end