Class: Card::Set::Pattern::Abstract

Inherits:
Object
  • Object
show all
Defined in:
lib/card/set_pattern.rb

Direct Known Subclasses

All, AllPlus, Right, Rstar, Rule, Self, Star, Type, TypePlusRight

Class Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(card) ⇒ Abstract

Instance methods



84
85
86
87
88
89
90
# File 'lib/card/set_pattern.rb', line 84

def initialize card
  unless self.class.anchorless?
    @anchor_name = self.class.anchor_name(card).to_name
    @anchor_id = find_anchor_id card
  end
  self
end

Class Attribute Details

.anchor_parts_countObject



65
66
67
# File 'lib/card/set_pattern.rb', line 65

def anchor_parts_count
  @anchor_parts_count ||= (anchorless? ? 0 : 1)
end

.anchorlessObject

Returns the value of attribute anchorless.



30
31
32
# File 'lib/card/set_pattern.rb', line 30

def anchorless
  @anchorless
end

.assigns_typeObject

Returns the value of attribute assigns_type.



30
31
32
# File 'lib/card/set_pattern.rb', line 30

def assigns_type
  @assigns_type
end

.junction_onlyObject

Returns the value of attribute junction_only.



30
31
32
# File 'lib/card/set_pattern.rb', line 30

def junction_only
  @junction_only
end

.pattern_codeObject

Returns the value of attribute pattern_code.



30
31
32
# File 'lib/card/set_pattern.rb', line 30

def pattern_code
  @pattern_code
end

.pattern_idObject

Returns the value of attribute pattern_id.



30
31
32
# File 'lib/card/set_pattern.rb', line 30

def pattern_id
  @pattern_id
end

Class Method Details

.anchorless?Boolean

Returns:

  • (Boolean)


53
54
55
# File 'lib/card/set_pattern.rb', line 53

def anchorless?
  !!anchorless
end

.generic_labelObject

label for set pattern if no anchor is given



77
78
79
# File 'lib/card/set_pattern.rb', line 77

def generic_label
  label nil
end

.junction_only?Boolean

Returns:

  • (Boolean)


49
50
51
# File 'lib/card/set_pattern.rb', line 49

def junction_only?
  junction_only == true
end

.module_key(anchor_codes) ⇒ Object



69
70
71
72
73
74
# File 'lib/card/set_pattern.rb', line 69

def module_key anchor_codes
  return pattern_code.to_s.camelize if anchorless?
  return unless anchor_codes # is this not an error?

  ([pattern_code] + anchor_codes).map { |code| code.to_s.camelize }.join "::"
end

.new(card) ⇒ Object



34
35
36
# File 'lib/card/set_pattern.rb', line 34

def new card
  super if pattern_applies? card
end

.patternObject



57
58
59
# File 'lib/card/set_pattern.rb', line 57

def pattern
  Card.fetch(pattern_id, skip_modules: true).name
end

.pattern_applies?(card) ⇒ Boolean

Returns:

  • (Boolean)


61
62
63
# File 'lib/card/set_pattern.rb', line 61

def pattern_applies? card
  junction_only? ? card.name.junction? : true
end

.register(pattern_code, opts = {}) ⇒ Object



38
39
40
41
42
43
44
45
46
47
# File 'lib/card/set_pattern.rb', line 38

def register pattern_code, opts={}
  if (self.pattern_id = Card::Codename.id(pattern_code))
    self.pattern_code = pattern_code
    Card.set_patterns.insert opts.delete(:index).to_i, self
    self.anchorless = !respond_to?(:anchor_name)
    opts.each { |key, val| send "#{key}=", val }
  else
    warn "no codename for pattern_code #{pattern_code}"
  end
end

Instance Method Details

#anchor_codenamesObject



121
122
123
124
125
126
# File 'lib/card/set_pattern.rb', line 121

def anchor_codenames
  anchor_parts.map do |part|
    part_id = Card.fetch_id part
    Card::Codename[part_id] || return
  end
end

#anchor_partsObject



128
129
130
131
132
133
134
135
136
137
138
# File 'lib/card/set_pattern.rb', line 128

def anchor_parts
  return [@anchor_name] unless anchor_parts_count > 1

  parts = @anchor_name.parts
  if parts.size <= anchor_parts_count
    parts
  else
    # handles cases where anchor is a compound card, eg A+B+*self
    [@anchor_name[0..-anchor_parts_count]] + parts[(-anchor_parts_count + 1)..-1]
  end
end

#anchor_parts_countObject



140
141
142
# File 'lib/card/set_pattern.rb', line 140

def anchor_parts_count
  self.class.anchor_parts_count
end

#find_anchor_id(card) ⇒ Object



92
93
94
95
96
97
98
# File 'lib/card/set_pattern.rb', line 92

def find_anchor_id card
  if self.class.respond_to? :anchor_id
    self.class.anchor_id card
  else
    Card.fetch_id @anchor_name
  end
end

#format_module_list(klass) ⇒ Object



116
117
118
119
# File 'lib/card/set_pattern.rb', line 116

def format_module_list klass
  hash = Card::Set.modules[:nonbase_format][klass]
  hash && lookup_module_list(hash)
end

#inspectObject



152
153
154
# File 'lib/card/set_pattern.rb', line 152

def inspect
  "<#{self.class} #{to_s.to_name.inspect}>"
end

#lookup_module_list(modules_hash) ⇒ Object



108
109
110
# File 'lib/card/set_pattern.rb', line 108

def lookup_module_list modules_hash
  module_key && modules_hash[module_key]
end

#module_keyObject



100
101
102
103
104
105
106
# File 'lib/card/set_pattern.rb', line 100

def module_key
  if defined? @module_key
    @module_key
  else
    @module_key = self.class.module_key(anchor_codenames)
  end
end

#module_listObject



112
113
114
# File 'lib/card/set_pattern.rb', line 112

def module_list
  lookup_module_list Card::Set.modules[:nonbase]
end

#patternObject



144
145
146
# File 'lib/card/set_pattern.rb', line 144

def pattern
  @pattern ||= self.class.pattern
end

#rule_set_keyObject



165
166
167
168
169
170
171
# File 'lib/card/set_pattern.rb', line 165

def rule_set_key
  if self.class.anchorless?
    self.class.pattern_code.to_s
  elsif @anchor_id
    "#{@anchor_id}+#{self.class.pattern_code}"
  end
end

#safe_keyObject



156
157
158
159
160
161
162
163
# File 'lib/card/set_pattern.rb', line 156

def safe_key
  caps_part = self.class.pattern_code.to_s.tr(" ", "_").upcase
  if self.class.anchorless?
    caps_part
  else
    "#{caps_part}-#{@anchor_name.safe_key}"
  end
end

#to_sObject



148
149
150
# File 'lib/card/set_pattern.rb', line 148

def to_s
  self.class.anchorless? ? pattern.s : "#{@anchor_name}+#{pattern}"
end