Recentemente eu encontrei uma maneira de contornar isso. Eu queria criar um método na classe array com um parâmetro opcional, para manter ou descartar elementos no array.
A maneira como simulei isso foi passando uma matriz como parâmetro e depois verificando se o valor naquele índice era nulo ou não.
class Array
def ascii_to_text(params)
param_len = params.length
if param_len > 3 or param_len < 2 then raise "Invalid number of arguments #{param_len} for 2 || 3." end
bottom = params[0]
top = params[1]
keep = params[2]
if keep.nil? == false
if keep == 1
self.map{|x| if x >= bottom and x <= top then x = x.chr else x = x.to_s end}
else
raise "Invalid option #{keep} at argument position 3 in #{p params}, must be 1 or nil"
end
else
self.map{|x| if x >= bottom and x <= top then x = x.chr end}.compact
end
end
end
Experimentando nosso método de classe com diferentes parâmetros:
array = [1, 2, 97, 98, 99]
p array.ascii_to_text([32, 126, 1]) # Convert all ASCII values of 32-126 to their chr value otherwise keep it the same (That's what the optional 1 is for)
resultado: ["1", "2", "a", "b", "c"]
Ok, legal, que funciona como planejado. Agora vamos verificar e ver o que acontece se não passarmos a terceira opção de parâmetro (1) na matriz.
array = [1, 2, 97, 98, 99]
p array.ascii_to_text([32, 126]) # Convert all ASCII values of 32-126 to their chr value else remove it (1 isn't a parameter option)
resultado: ["a", "b", "c"]
Como você pode ver, a terceira opção na matriz foi removida, iniciando uma seção diferente no método e removendo todos os valores ASCII que não estão em nosso intervalo (32-126)
Como alternativa, poderíamos ter emitido o valor nulo nos parâmetros. O que seria semelhante ao seguinte bloco de código:
def ascii_to_text(top, bottom, keep = nil)
if keep.nil?
self.map{|x| if x >= bottom and x <= top then x = x.chr end}.compact
else
self.map{|x| if x >= bottom and x <= top then x = x.chr else x = x.to_s end}
end
scope
verdadeiro e passafalse
,scope ||= true
não funcionará. Ele avalia o mesmonil
e o definirá comotrue