aboutsummaryrefslogtreecommitdiffstats
path: root/lib/active_job/parameters.rb
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2014-05-20 19:14:02 +0200
committerDavid Heinemeier Hansson <david@loudthinking.com>2014-05-20 19:14:02 +0200
commitb367830af7fb75cd59863b3a1311d4a5bc4b37a8 (patch)
tree504082a2165a046bbd78213a5d111227e59887d8 /lib/active_job/parameters.rb
parentfd372e66f0934617bef3b840cd0ea75429a24544 (diff)
downloadrails-b367830af7fb75cd59863b3a1311d4a5bc4b37a8.tar.gz
rails-b367830af7fb75cd59863b3a1311d4a5bc4b37a8.tar.bz2
rails-b367830af7fb75cd59863b3a1311d4a5bc4b37a8.zip
Clarify control flow
Diffstat (limited to 'lib/active_job/parameters.rb')
-rw-r--r--lib/active_job/parameters.rb11
1 files changed, 8 insertions, 3 deletions
diff --git a/lib/active_job/parameters.rb b/lib/active_job/parameters.rb
index 5f814f846d..955fd887d7 100644
--- a/lib/active_job/parameters.rb
+++ b/lib/active_job/parameters.rb
@@ -3,12 +3,17 @@ require 'active_support/core_ext/object/try'
module ActiveJob
class Parameters
- TYPE_WHITELIST = [NilClass, Fixnum, Float, String, TrueClass, FalseClass, Hash, Array, Bignum]
+ TYPE_WHITELIST = [ NilClass, Fixnum, Float, String, TrueClass, FalseClass, Hash, Array, Bignum ]
def self.serialize(params)
params.collect do |param|
- raise "Unsupported parameter type: #{param.class.name}" unless param.respond_to?(:global_id) || TYPE_WHITELIST.include?(param.class)
- param.try(:global_id) || param
+ if param.respond_to?(:global_id)
+ param.global_id
+ elsif TYPE_WHITELIST.include?(param.class)
+ param
+ else
+ raise "Unsupported parameter type: #{param.class.name}"
+ end
end
end