card 1.101.3 → 1.101.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/VERSION +1 -1
- data/config/initializers/02_patches/active_record.rb +1 -1
- data/config/locales/en.yml +155 -378
- data/db/migrate_core_cards/20150202143810_import_bootstrap_layout.rb +1 -1
- data/lib/card.rb +15 -2
- data/lib/card/auth.rb +5 -2
- data/lib/card/auth/current.rb +39 -100
- data/lib/card/auth/proxy.rb +36 -16
- data/lib/card/auth/token.rb +6 -0
- data/lib/card/cache/all.rb +83 -0
- data/lib/card/cache/card_class.rb +41 -0
- data/lib/card/cache/persistent.rb +3 -34
- data/lib/card/cache/persistent_class.rb +28 -0
- data/lib/card/codename.rb +1 -1
- data/lib/card/content.rb +16 -2
- data/lib/card/content/all.rb +59 -0
- data/lib/card/director/act_direction.rb +4 -0
- data/lib/card/director/all.rb +61 -0
- data/lib/card/director/card_class.rb +18 -0
- data/lib/card/director/phases.rb +0 -1
- data/lib/card/dirty.rb +13 -3
- data/lib/card/env/success.rb +14 -14
- data/lib/card/env/success/target.rb +9 -11
- data/lib/card/error.rb +1 -1
- data/lib/card/fetch/all.rb +32 -0
- data/lib/card/fetch/card_class.rb +147 -0
- data/lib/card/format.rb +1 -1
- data/lib/card/format/error.rb +3 -3
- data/lib/card/format/nest.rb +1 -1
- data/lib/card/format/nest/fetch.rb +1 -1
- data/lib/card/lexicon.rb +2 -2
- data/lib/card/name/all.rb +8 -0
- data/lib/card/name/all/descendants.rb +6 -3
- data/lib/card/name/card_class.rb +26 -0
- data/lib/card/reference/all.rb +131 -0
- data/lib/card/rule/all.rb +75 -0
- data/lib/card/set/event/all.rb +95 -0
- data/lib/card/set/event/skip_and_trigger.rb +89 -0
- data/lib/card/set/pattern/all.rb +63 -0
- data/lib/card/subcards/all.rb +103 -0
- data/lib/cardio/migration/import.rb +1 -1
- data/lib/cardio/utils.rb +5 -3
- data/mod/admin/set/self/admin_info.rb +3 -5
- data/mod/admin/set/self/trash.rb +2 -2
- data/mod/core/set/all/autoname.rb +17 -0
- data/mod/core/set/all/codename.rb +2 -2
- data/mod/core/set/all/content.rb +52 -97
- data/mod/core/set/all/name_events.rb +69 -58
- data/mod/core/set/all/reference_events.rb +67 -0
- data/mod/core/set/all/states.rb +2 -2
- data/mod/core/set/all/subcards.rb +0 -100
- data/mod/core/set/all/trash.rb +11 -13
- data/mod/core/set/all/type.rb +7 -9
- data/mod/core/set/all/utils.rb +3 -0
- data/mod/core/set/type/cardtype.rb +3 -3
- data/mod/core/set_pattern/06_rule.rb +1 -1
- data/mod/core/spec/set/all/{rules2_spec.rb → clean_me_spec.rb} +0 -0
- data/mod/core/spec/set/all/name_events_spec.rb +204 -0
- metadata +30 -37
- data/lib/card/mod_inflector.rb +0 -16
- data/lib/card/name/all/class_methods.rb +0 -28
- data/mod/core/set/all/actify.rb +0 -68
- data/mod/core/set/all/cache.rb +0 -109
- data/mod/core/set/all/event_conditions.rb +0 -172
- data/mod/core/set/all/fetch.rb +0 -122
- data/mod/core/set/all/fetch_helper.rb +0 -35
- data/mod/core/set/all/i18n.rb +0 -9
- data/mod/core/set/all/pattern.rb +0 -54
- data/mod/core/set/all/references.rb +0 -191
- data/mod/core/set/all/rename.rb +0 -33
- data/mod/core/set/all/rules.rb +0 -81
- data/mod/core/spec/set/all/actify_spec.rb +0 -58
- data/mod/core/spec/set/all/content_spec.rb +0 -15
- data/mod/core/spec/set/all/event_conditions_spec.rb +0 -217
- data/mod/core/spec/set/all/fetch_helper_spec.rb +0 -65
- data/mod/core/spec/set/all/fetch_spec.rb +0 -338
- data/mod/core/spec/set/all/i18n_spec.rb +0 -17
- data/mod/core/spec/set/all/pattern_spec.rb +0 -101
- data/mod/core/spec/set/all/permissions/reader_rules_spec.rb +0 -166
- data/mod/core/spec/set/all/references_spec.rb +0 -62
- data/mod/core/spec/set/all/rename_spec.rb +0 -189
- data/mod/core/spec/set/all/rules_spec.rb +0 -100
- data/mod/core/spec/set/all/subcards_spec.rb +0 -102
data/lib/card/mod_inflector.rb
DELETED
@@ -1,16 +0,0 @@
|
|
1
|
-
class ModInflector < Zeitwerk::Inflector
|
2
|
-
def camelize basename, abspath
|
3
|
-
ActiveSupport::Dependencies::ZeitwerkIntegration::Inflector.camelize(basename, abspath)
|
4
|
-
|
5
|
-
# if basename =~ /\Ahtml_(.*)/
|
6
|
-
# ActiveSupport::Dependencies::ZeitwerkIntegration::Inflector.camelize(basename, abspath)
|
7
|
-
# # "HTML" + super($1, abspath)
|
8
|
-
# else
|
9
|
-
# super
|
10
|
-
# end
|
11
|
-
end
|
12
|
-
|
13
|
-
def inflect overrides
|
14
|
-
ActiveSupport::Dependencies::ZeitwerkIntegration::Inflector.inflect(overrides)
|
15
|
-
end
|
16
|
-
end
|
@@ -1,28 +0,0 @@
|
|
1
|
-
class Card
|
2
|
-
class Name
|
3
|
-
module All
|
4
|
-
# Name-related Card class methods
|
5
|
-
module ClassMethods
|
6
|
-
def rename! oldname, newname
|
7
|
-
Card[oldname].update! name: newname, update_referers: true
|
8
|
-
end
|
9
|
-
|
10
|
-
def uniquify_name name, rename=:new
|
11
|
-
return name unless Card.exists? name
|
12
|
-
uniq_name = generate_alternative_name name
|
13
|
-
return uniq_name unless rename == :old
|
14
|
-
rename!(name, uniq_name)
|
15
|
-
name
|
16
|
-
end
|
17
|
-
|
18
|
-
private
|
19
|
-
|
20
|
-
def generate_alternative_name name
|
21
|
-
uniq_name = "#{name} 1"
|
22
|
-
uniq_name.next! while Card.exists?(uniq_name)
|
23
|
-
uniq_name
|
24
|
-
end
|
25
|
-
end
|
26
|
-
end
|
27
|
-
end
|
28
|
-
end
|
data/mod/core/set/all/actify.rb
DELETED
@@ -1,68 +0,0 @@
|
|
1
|
-
def act options={}, &block
|
2
|
-
if act_card
|
3
|
-
add_to_act options, &block
|
4
|
-
else
|
5
|
-
start_new_act &block
|
6
|
-
end
|
7
|
-
end
|
8
|
-
|
9
|
-
def act_card
|
10
|
-
Card::Director.act_card
|
11
|
-
end
|
12
|
-
|
13
|
-
def act_card?
|
14
|
-
self == act_card
|
15
|
-
end
|
16
|
-
|
17
|
-
module ClassMethods
|
18
|
-
def create! opts
|
19
|
-
card = Card.new opts
|
20
|
-
card.save!
|
21
|
-
card
|
22
|
-
end
|
23
|
-
|
24
|
-
def create opts
|
25
|
-
card = Card.new opts
|
26
|
-
card.save
|
27
|
-
card
|
28
|
-
end
|
29
|
-
end
|
30
|
-
|
31
|
-
def save! *args
|
32
|
-
as_subcard = args.first&.delete :as_subcard
|
33
|
-
act(as_subcard: as_subcard) { super }
|
34
|
-
end
|
35
|
-
|
36
|
-
def save(*)
|
37
|
-
act { super }
|
38
|
-
end
|
39
|
-
|
40
|
-
def valid?(*)
|
41
|
-
act(validating: true) { super }
|
42
|
-
end
|
43
|
-
|
44
|
-
def update *args
|
45
|
-
act { super }
|
46
|
-
end
|
47
|
-
|
48
|
-
def update! *args
|
49
|
-
act { super }
|
50
|
-
end
|
51
|
-
|
52
|
-
alias_method :update_attributes, :update
|
53
|
-
alias_method :update_attributes!, :update!
|
54
|
-
|
55
|
-
private
|
56
|
-
|
57
|
-
def start_new_act
|
58
|
-
self.director = nil
|
59
|
-
Director.run_act(self) do
|
60
|
-
run_callbacks(:act) { yield }
|
61
|
-
end
|
62
|
-
end
|
63
|
-
|
64
|
-
def add_to_act options={}
|
65
|
-
director.appoint self unless @director
|
66
|
-
director.head = true unless options[:validating] || options[:as_subcard]
|
67
|
-
yield
|
68
|
-
end
|
data/mod/core/set/all/cache.rb
DELETED
@@ -1,109 +0,0 @@
|
|
1
|
-
module ClassMethods
|
2
|
-
def retrieve_from_cache cache_key, local_only=false
|
3
|
-
return unless cache
|
4
|
-
local_only ? cache.soft.read(cache_key) : cache.read(cache_key)
|
5
|
-
end
|
6
|
-
|
7
|
-
def retrieve_from_cache_by_id id, local_only=false
|
8
|
-
key = Card::Lexicon.name(id)&.key
|
9
|
-
return unless key.present?
|
10
|
-
|
11
|
-
retrieve_from_cache key, local_only if key
|
12
|
-
end
|
13
|
-
|
14
|
-
def retrieve_from_cache_by_key key, local_only=false
|
15
|
-
retrieve_from_cache key, local_only
|
16
|
-
end
|
17
|
-
|
18
|
-
def write_to_cache card, local_only=false
|
19
|
-
if local_only
|
20
|
-
write_to_soft_cache card
|
21
|
-
elsif cache
|
22
|
-
cache.write card.key, card
|
23
|
-
end
|
24
|
-
end
|
25
|
-
|
26
|
-
def write_to_soft_cache card
|
27
|
-
return unless cache
|
28
|
-
cache.soft.write card.key, card
|
29
|
-
end
|
30
|
-
|
31
|
-
def expire name
|
32
|
-
key = name.to_name.key
|
33
|
-
return unless (card = Card.cache.read key)
|
34
|
-
card.expire
|
35
|
-
end
|
36
|
-
end
|
37
|
-
|
38
|
-
def update_soft_cache
|
39
|
-
Card.write_to_soft_cache self
|
40
|
-
end
|
41
|
-
|
42
|
-
def expire_pieces
|
43
|
-
name.piece_names.each do |piece|
|
44
|
-
Card.expire piece
|
45
|
-
end
|
46
|
-
end
|
47
|
-
|
48
|
-
def expire cache_type=nil
|
49
|
-
return unless (cache_class = cache_class_from_type cache_type)
|
50
|
-
expire_views
|
51
|
-
expire_names cache_class
|
52
|
-
expire_id cache_class
|
53
|
-
end
|
54
|
-
|
55
|
-
def cache_class_from_type cache_type
|
56
|
-
cache_type ? Card.cache.send(cache_type) : Card.cache
|
57
|
-
end
|
58
|
-
|
59
|
-
def view_cache_clean?
|
60
|
-
!db_content_changed?
|
61
|
-
end
|
62
|
-
|
63
|
-
def view_cache_keys
|
64
|
-
@view_cache_keys ||= hard_read_view_cache_keys || []
|
65
|
-
end
|
66
|
-
|
67
|
-
def ensure_view_cache_key cache_key
|
68
|
-
return if view_cache_keys.include? cache_key
|
69
|
-
|
70
|
-
@view_cache_keys << cache_key
|
71
|
-
hard_write_view_cache_keys
|
72
|
-
end
|
73
|
-
|
74
|
-
def hard_read_view_cache_keys
|
75
|
-
Card.cache.hard&.read_attribute key, :view_cache_keys
|
76
|
-
end
|
77
|
-
|
78
|
-
def hard_write_view_cache_keys
|
79
|
-
# puts "WRITE VIEW CACHE KEYS (#{name}): #{view_cache_keys}"
|
80
|
-
Card.cache.hard&.write_attribute key, :view_cache_keys, view_cache_keys
|
81
|
-
end
|
82
|
-
|
83
|
-
def expire_views
|
84
|
-
# puts "EXPIRE VIEW CACHE (#{name}): #{view_cache_keys}"
|
85
|
-
return unless view_cache_keys.present?
|
86
|
-
Array.wrap(view_cache_keys).each do |view_cache_key|
|
87
|
-
Card::View.cache.delete view_cache_key
|
88
|
-
end
|
89
|
-
@view_cache_keys = []
|
90
|
-
hard_write_view_cache_keys
|
91
|
-
end
|
92
|
-
|
93
|
-
def expire_names cache
|
94
|
-
[name, name_before_act].uniq.each do |name_version|
|
95
|
-
expire_name name_version, cache
|
96
|
-
end
|
97
|
-
end
|
98
|
-
|
99
|
-
def expire_name name_version, cache
|
100
|
-
return unless name_version.present?
|
101
|
-
key_version = name_version.to_name.key
|
102
|
-
return unless key_version.present?
|
103
|
-
cache.delete key_version
|
104
|
-
end
|
105
|
-
|
106
|
-
def expire_id cache
|
107
|
-
return unless id.present?
|
108
|
-
cache.delete "~#{id}"
|
109
|
-
end
|
@@ -1,172 +0,0 @@
|
|
1
|
-
Card.action_specific_attributes +=
|
2
|
-
%i[skip_hash full_skip_hash trigger_hash full_trigger_hash]
|
3
|
-
|
4
|
-
def event_applies? event
|
5
|
-
return unless set_condition_applies? event.set_module, event.opts[:changing]
|
6
|
-
|
7
|
-
Card::Set::Event::CONDITIONS.all? do |key|
|
8
|
-
send "#{key}_condition_applies?", event, event.opts[key]
|
9
|
-
end
|
10
|
-
end
|
11
|
-
|
12
|
-
# force skipping this event for all cards in act
|
13
|
-
def skip_event! *events
|
14
|
-
@full_skip_hash = nil
|
15
|
-
events.each do |event|
|
16
|
-
act_skip_hash[event.to_s] = :force
|
17
|
-
end
|
18
|
-
end
|
19
|
-
|
20
|
-
# force skipping this event for this card only
|
21
|
-
def skip_event_in_action! *events
|
22
|
-
events.each do |event|
|
23
|
-
full_skip_hash[event.to_s] = :force
|
24
|
-
end
|
25
|
-
end
|
26
|
-
|
27
|
-
# force triggering this event (when it comes up) for all cards in act
|
28
|
-
def trigger_event! *events
|
29
|
-
@full_trigger_hash = nil
|
30
|
-
events.each do |event|
|
31
|
-
act_trigger_hash[event.to_s] = :force
|
32
|
-
end
|
33
|
-
end
|
34
|
-
|
35
|
-
# force triggering this event (when it comes up) for this card only
|
36
|
-
def trigger_event_in_action! *events
|
37
|
-
events.each do |event|
|
38
|
-
full_trigger_hash[event.to_s] = :force
|
39
|
-
end
|
40
|
-
end
|
41
|
-
|
42
|
-
# hash form of raw skip setting, eg { "my_event" => true }
|
43
|
-
def skip_hash
|
44
|
-
@skip_hash ||= hash_with_value skip, true
|
45
|
-
end
|
46
|
-
|
47
|
-
def trigger_hash
|
48
|
-
@trigger_hash ||= hash_with_value trigger, true
|
49
|
-
end
|
50
|
-
|
51
|
-
private
|
52
|
-
|
53
|
-
def set_condition_applies? set_module, old_sets
|
54
|
-
return true if set_module == Card
|
55
|
-
|
56
|
-
set_condition_card(old_sets).singleton_class.include? set_module
|
57
|
-
end
|
58
|
-
|
59
|
-
def on_condition_applies? _event, actions
|
60
|
-
actions = Array(actions).compact
|
61
|
-
actions.empty? ? true : actions.include?(action)
|
62
|
-
end
|
63
|
-
|
64
|
-
# if changing name/type, the old card has no-longer-applicable set modules, so we create
|
65
|
-
# a new card to determine whether events apply.
|
66
|
-
# (note: cached condition card would ideally be cleared after all
|
67
|
-
# conditions are reviewed)
|
68
|
-
# @param old_sets [True/False] whether to use the old_sets
|
69
|
-
def set_condition_card old_sets
|
70
|
-
return self if old_sets || no_current_action?
|
71
|
-
@set_condition_card ||=
|
72
|
-
updating_sets? ? set_condition_card_with_new_set_modules : self
|
73
|
-
end
|
74
|
-
|
75
|
-
# existing card is being changed in a way that alters its sets
|
76
|
-
def updating_sets?
|
77
|
-
action == :update && real? && (type_id_is_changing? || name_is_changing?)
|
78
|
-
end
|
79
|
-
|
80
|
-
# prevents locking in set_condition_card
|
81
|
-
def no_current_action?
|
82
|
-
return false if @current_action
|
83
|
-
|
84
|
-
@set_condition_card = nil
|
85
|
-
true
|
86
|
-
end
|
87
|
-
|
88
|
-
def set_condition_card_with_new_set_modules
|
89
|
-
cc = Card.find id
|
90
|
-
cc.name = name
|
91
|
-
cc.type_id = type_id
|
92
|
-
cc.include_set_modules
|
93
|
-
end
|
94
|
-
|
95
|
-
def changed_condition_applies? _event, db_columns
|
96
|
-
return true unless action == :update
|
97
|
-
db_columns = Array(db_columns).compact
|
98
|
-
return true if db_columns.empty?
|
99
|
-
db_columns.any? { |col| single_changed_condition_applies? col }
|
100
|
-
end
|
101
|
-
alias_method :changing_condition_applies?, :changed_condition_applies?
|
102
|
-
|
103
|
-
def when_condition_applies? _event, block
|
104
|
-
case block
|
105
|
-
when Proc then block.call(self)
|
106
|
-
when Symbol then send block
|
107
|
-
else true
|
108
|
-
end
|
109
|
-
end
|
110
|
-
|
111
|
-
# "applies always means event can run
|
112
|
-
# so if skip_condition_applies?, we do NOT skip
|
113
|
-
def skip_condition_applies? event, allowed
|
114
|
-
return true unless (val = full_skip_hash[event.name.to_s])
|
115
|
-
|
116
|
-
allowed ? val.blank? : (val != :force)
|
117
|
-
end
|
118
|
-
|
119
|
-
def trigger_condition_applies? event, required
|
120
|
-
return true unless required
|
121
|
-
|
122
|
-
full_trigger_hash[event.name.to_s].present?
|
123
|
-
end
|
124
|
-
|
125
|
-
def single_changed_condition_applies? db_column
|
126
|
-
return true unless db_column
|
127
|
-
send "#{db_column}_is_changing?"
|
128
|
-
end
|
129
|
-
|
130
|
-
def wrong_stage opts
|
131
|
-
return false if director.stage_ok? opts
|
132
|
-
if !stage
|
133
|
-
"phase method #{method} called outside of event phases"
|
134
|
-
else
|
135
|
-
"#{opts.inspect} method #{method} called in stage #{stage}"
|
136
|
-
end
|
137
|
-
end
|
138
|
-
|
139
|
-
def wrong_action actn
|
140
|
-
return false if on_condition_applies?(nil, actn)
|
141
|
-
"on: #{actn} method #{method} called on #{action}"
|
142
|
-
end
|
143
|
-
|
144
|
-
def full_skip_hash
|
145
|
-
@full_skip_hash ||= act_skip_hash.merge skip_in_action_hash
|
146
|
-
end
|
147
|
-
|
148
|
-
def act_skip_hash
|
149
|
-
(act_card || self).skip_hash
|
150
|
-
end
|
151
|
-
|
152
|
-
def skip_in_action_hash
|
153
|
-
hash_with_value skip_in_action, true
|
154
|
-
end
|
155
|
-
|
156
|
-
def full_trigger_hash
|
157
|
-
@full_trigger_hash ||= act_trigger_hash.merge trigger_in_action_hash
|
158
|
-
end
|
159
|
-
|
160
|
-
def trigger_in_action_hash
|
161
|
-
hash_with_value trigger_in_action, true
|
162
|
-
end
|
163
|
-
|
164
|
-
def act_trigger_hash
|
165
|
-
(act_card || self).trigger_hash
|
166
|
-
end
|
167
|
-
|
168
|
-
def hash_with_value array, value
|
169
|
-
Array.wrap(array).each_with_object({}) do |event, hash|
|
170
|
-
hash[event.to_s] = value
|
171
|
-
end
|
172
|
-
end
|
data/mod/core/set/all/fetch.rb
DELETED
@@ -1,122 +0,0 @@
|
|
1
|
-
# = Card#fetch
|
2
|
-
#
|
3
|
-
# A multipurpose retrieval operator that integrates caching, database lookups,
|
4
|
-
# and "virtual" card construction
|
5
|
-
module ClassMethods
|
6
|
-
# Look for cards in
|
7
|
-
# * cache
|
8
|
-
# * database
|
9
|
-
# * virtual cards
|
10
|
-
#
|
11
|
-
# @param args [Integer, String, Card::Name, Symbol, Array]
|
12
|
-
# one or more of the three unique identifiers
|
13
|
-
# 1. a numeric id (Integer)
|
14
|
-
# 2. a name/key (String or Card::Name)
|
15
|
-
# 3. a codename (Symbol)
|
16
|
-
# If you pass more then one mark or an array of marks they get joined with a '+'.
|
17
|
-
# The final argument can be a hash to set the following options
|
18
|
-
# :skip_virtual Real cards only
|
19
|
-
# :skip_modules Don't load Set modules
|
20
|
-
# :look_in_trash Return trashed card objects
|
21
|
-
# :local_only Use only local cache for lookup and storing
|
22
|
-
# new: { opts for Card#new } Return a new card when not found
|
23
|
-
# @return [Card]
|
24
|
-
def fetch *args
|
25
|
-
Card::Fetch.new(*args)&.retrieve_or_new
|
26
|
-
rescue ActiveModel::RangeError => _e
|
27
|
-
return Card.new name: "card id out of range: #{f.mark}"
|
28
|
-
end
|
29
|
-
|
30
|
-
# fetch only real (no virtual) cards
|
31
|
-
#
|
32
|
-
# @param mark - see #fetch
|
33
|
-
# @return [Card]
|
34
|
-
def [] *mark
|
35
|
-
fetch(*mark, skip_virtual: true)
|
36
|
-
end
|
37
|
-
|
38
|
-
# fetch real cards without set modules loaded. Should only be used for simple attributes
|
39
|
-
# @example
|
40
|
-
# quick_fetch "A", :self, :structure
|
41
|
-
#
|
42
|
-
# @param mark - see #fetch
|
43
|
-
# @return [Card]
|
44
|
-
def quick_fetch *mark
|
45
|
-
fetch(*mark, skip_virtual: true, skip_modules: true)
|
46
|
-
end
|
47
|
-
|
48
|
-
# @return [Card]
|
49
|
-
def fetch_from_cast cast
|
50
|
-
fetch_args = cast[:id] ? [cast[:id].to_i] : [cast[:name], { new: cast }]
|
51
|
-
fetch *fetch_args
|
52
|
-
end
|
53
|
-
|
54
|
-
#----------------------------------------------------------------------
|
55
|
-
# ATTRIBUTE FETCHING
|
56
|
-
# The following methods optimize fetching of specific attributes
|
57
|
-
|
58
|
-
def id cardish
|
59
|
-
case cardish
|
60
|
-
when Integer then cardish
|
61
|
-
when Card then cardish.id
|
62
|
-
when Symbol then Card::Codename.id cardish
|
63
|
-
else fetch_id cardish
|
64
|
-
end
|
65
|
-
end
|
66
|
-
|
67
|
-
# @param mark_parts - see #fetch
|
68
|
-
# @return [Integer]
|
69
|
-
def fetch_id *mark_parts
|
70
|
-
mark = Card::Fetch.new(*mark_parts)&.mark
|
71
|
-
mark.is_a?(Integer) ? mark : quick_fetch(mark.to_s)&.id
|
72
|
-
end
|
73
|
-
|
74
|
-
# @param mark - see #fetch
|
75
|
-
# @return [Card::Name]
|
76
|
-
def fetch_name *mark
|
77
|
-
if (card = quick_fetch(*mark))
|
78
|
-
card.name
|
79
|
-
elsif block_given?
|
80
|
-
yield.to_name
|
81
|
-
end
|
82
|
-
rescue ActiveModel::RangeError => _e
|
83
|
-
block_given? ? yield.to_name : nil
|
84
|
-
rescue Card::Error::CodenameNotFound => e
|
85
|
-
block_given? ? yield.to_name : raise(e)
|
86
|
-
end
|
87
|
-
|
88
|
-
# @param mark - see #fetch
|
89
|
-
# @return [Integer]
|
90
|
-
def fetch_type_id mark
|
91
|
-
quick_fetch(mark)&.type_id
|
92
|
-
end
|
93
|
-
end
|
94
|
-
|
95
|
-
#----------------------------------------------------------------------
|
96
|
-
# INSTANCE METHODS
|
97
|
-
# fetching from the context of a card
|
98
|
-
|
99
|
-
def fetch traits, opts={}
|
100
|
-
opts[:new][:supercard] = self if opts[:new]
|
101
|
-
Array.wrap(traits).inject(self) do |card, trait|
|
102
|
-
Card.fetch card.name.trait(trait), opts
|
103
|
-
end
|
104
|
-
end
|
105
|
-
|
106
|
-
def newish opts
|
107
|
-
reset_patterns
|
108
|
-
Card.with_normalized_new_args opts do |norm_opts|
|
109
|
-
handle_type norm_opts do
|
110
|
-
assign_attributes norm_opts
|
111
|
-
self.name = name # trigger superize_name
|
112
|
-
end
|
113
|
-
end
|
114
|
-
end
|
115
|
-
|
116
|
-
def refresh force=false
|
117
|
-
return self unless force || frozen? || readonly?
|
118
|
-
return unless id
|
119
|
-
fresh_card = self.class.find id
|
120
|
-
fresh_card.include_set_modules
|
121
|
-
fresh_card
|
122
|
-
end
|