class Card::Name
The {Cardname} class provides generalized of Card
naming patterns (compound names, key-based variants, etc) and can be used independently of Card
objects.
{Card::Name} adds support for deeper integration with Card
objects
Public Class Methods
[](*cardish)
click to toggle source
# File lib/card/name.rb, line 15 def [] *cardish cardish = cardish.first if cardish.size <= 1 case cardish when Card then cardish.name when Symbol, Integer then Card.fetch_name(cardish) when Array then compose cardish when String, NilClass then new cardish else raise ArgumentError, "#{cardish.class} not supported as name identifier" end end
compose(parts)
click to toggle source
interprets symbols/integers as codenames/ids
# File lib/card/name.rb, line 50 def compose parts new_from_parts(parts) { |part| self[part] } end
new(str, validated_parts=nil)
click to toggle source
Calls superclass method
# File lib/card/name.rb, line 35 def new str, validated_parts=nil return compose str if str.is_a?(Array) str = str.to_s if !validated_parts && str.include?(joint) string_compose Cardname.split_parts(str) elsif (id = Card.id_from_string str) # handles ~[id] and :[codename] Card.name_from_id_from_string id, str else super str end end
params()
click to toggle source
# File lib/card/name.rb, line 31 def params Card::Env.params end
session()
click to toggle source
# File lib/card/name.rb, line 27 def session Card::Auth.current.name # also_yuck end
Private Class Methods
new_from_parts(parts, &block)
click to toggle source
# File lib/card/name.rb, line 60 def new_from_parts parts, &block name_parts = parts.flatten.map(&block) new name_parts.join(joint), true end
string_compose(parts)
click to toggle source
# File lib/card/name.rb, line 56 def string_compose parts new_from_parts(parts) { |part| new part } end
Public Instance Methods
rstar?()
click to toggle source
# File lib/card/name.rb, line 70 def rstar? right && right[0, 1] == "*" end
star?()
click to toggle source
# File lib/card/name.rb, line 66 def star? simple? && s[0, 1] == "*" end