Alle mercoledì 11 luglio 2007, Max W. ha scritto:
I’ve been trying to experiment with my own classes with this tactic, but
i’m new to ruby and can’t get an example of the above working.
What is happening here is that you’re calling the method render passing
an
hash as argument. In ruby, when you pass an hash as the last argument to
a
method, you may omit the usual braces, so the line you quoted is the
same as:
render( {:text => “Hello world!” } )
Usually, this is used to fake keyword arguments, which ruby doesn’t
have.
As an example, imagine you want to write a method which takes a string
and
does some of the following things:
- remove whitespace at the left, right or both
- makes the string downcase or upcase
- crypt it
You want the user to decide which of the previous transformation he
wants to
perform (of course, this is only an example; in reality, it might be
better
to create three separate methods). The method can be written this way:
def transform_string(orig, actions = nil ) #1
default = { :remove_whitespace=>:both, :change_case=>nil, :crypt =>
nil} #2
acts = actions || default
temp = orig.dup #3
if acts[:remove_whitespace] then #4
case acts[:remove_whitespace] #5
when :left then temp.lstrip! #6
when :right then temp.rstrip! #7
when :left_right then temp.strip! #8
end #9
end #10
if acts[:change_case] == :downcase then temp.downcase! #11
elsif acts[:change_case] == :upcase then temp.upcase! #12
end #13
temp = temp.crypt(acts[:crypt]) if acts[:crypt] #14
temp #15
end #16
In line 1, we define a method which takes a mandatory argument, the
string
modify, and an optional argument, a hash where the user will specify
which
actions he wants to perform.
In line 2, we create an hash with the default actions (the actions to
perform
if the user didn’t pass the optional argument). This hash contains three
entries, two of which are nil. The only non-nil one is
:remove_whitespace,
with content :both. Since actions whose value is nil won’t be carried
out,
this means that, if the user didn’t specify an action, the method will
remove
the whitespace both the left and the right of the string (the value
corresponding to :remove_whitespace in the hash is :both). In line 3, we
assign to the variable acts the hash containing the action specified by
the
user or, if this is nil (i.e, the user didn’t specify any action), the
hash
with the default actions.
In lines 4-10, depending on the content of the :remove_whitespace entry
of
acts, we remove the whitespace from the left, right, left and right of
the
string, or we leave it unchanged.
Likewise, in lines 11-13, if the action :change_case was specified, the
case
of the string is changed and, in line 14 we crypt the string if it was
requested.
NOTE
In this example, the hash with the default actions wasn’t used if the
user
specified the second parameter to the method. Often, you’ll need to keep
the
default values for the keys the user doesn’t specify. In this case, you
can
do the following:
def my_method( hash = {} )
default_hash = { :opt_a => value_a, :opt_b => value_b }
options = default_hash.merge(hash)
#…
end
Here, the values to be used are obtained by merging the hash with the
default
options with the one passed as argument. This will overwrite the
elements in
default_hash which are also in hash, leaving the others unchanged.
I hope this helps
Stefano