card 1.101.4 → 1.101.5
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/i18n-tasks.yml +0 -5
- data/config/initializers/01_core_extensions/array.rb +2 -1
- data/config/initializers/01_core_extensions/hash.rb +1 -0
- data/config/initializers/01_core_extensions/object.rb +15 -11
- data/config/initializers/02_patches/active_job.rb +1 -1
- data/config/initializers/02_patches/active_record.rb +1 -3
- data/config/initializers/02_patches/better_errors.rb +1 -3
- data/config/initializers/02_patches/kaminari.rb +2 -2
- data/config/initializers/deck_config.rb +1 -1
- data/config/initializers/inflections.rb +1 -0
- data/config/initializers/internationalization.rb +23 -21
- data/config/initializers/mime_types.rb +1 -0
- data/config/initializers/notification.rb +1 -0
- data/config/initializers/patches.rb +6 -5
- data/config/locales/en.yml +10 -16
- data/db/migrate/20110511221913_require_earlier_migrations.rb +1 -0
- data/db/migrate/20121111025347_require_1_10_migrations.rb +1 -0
- data/db/migrate/20121118114000_split_link_type.rb +1 -0
- data/db/migrate/20121118115000_update_link_type.rb +1 -0
- data/db/migrate/20130106052640_table_cleanup.rb +2 -2
- data/db/migrate/20130109015336_trunk_left.rb +1 -0
- data/db/migrate/20130411210957_update_codenames.rb +1 -0
- data/db/migrate/20140822073704_create_new_revision_tables.rb +1 -0
- data/db/migrate/20141001105348_move_revisions_to_actions.rb +9 -3
- data/db/migrate/20141216053032_better_index_names.rb +9 -6
- data/db/migrate/20170908114442_create_delayed_jobs.rb +1 -1
- data/db/migrate/20170908114452_increase_text_size_for_delayed_jobs.rb +1 -1
- data/db/migrate/20180514152037_add_card_virtuals_table.rb +1 -1
- data/db/migrate_core_cards/20120611203506_rails_inflection_updates.rb +2 -1
- data/db/migrate_core_cards/20130411191151_renaming_for_menu.rb +9 -9
- data/db/migrate_core_cards/20130419215612_import_help_text.rb +3 -2
- data/db/migrate_core_cards/20130823192433_add_style_cards.rb +5 -5
- data/db/migrate_core_cards/20130910183318_move_styles_to_content.rb +3 -2
- data/db/migrate_core_cards/20130920291703_update_stylesheets.rb +2 -4
- data/db/migrate_core_cards/20131016172445_common_css_patch.rb +1 -3
- data/db/migrate_core_cards/20140110193325_reset_account_request_type.rb +1 -3
- data/db/migrate_core_cards/20140307231621_user_data_to_cards.rb +12 -8
- data/db/migrate_core_cards/20140317035504_account_requests_to_signups.rb +2 -4
- data/db/migrate_core_cards/20140512155840_add_script_cards.rb +16 -9
- data/db/migrate_core_cards/20140629222005_add_email_cards.rb +19 -11
- data/db/migrate_core_cards/20140725180118_config_card_updates.rb +1 -1
- data/db/migrate_core_cards/20141115034214_config_descriptions_etc.rb +1 -1
- data/db/migrate_core_cards/20141119001955_make_symlinks_relative.rb +1 -1
- data/db/migrate_core_cards/20141204061304_watchers_to_following.rb +2 -0
- data/db/migrate_core_cards/20141216155251_add_more_following_cards.rb +4 -2
- data/db/migrate_core_cards/20150202143810_import_bootstrap_layout.rb +1 -1
- data/db/migrate_core_cards/20150220134731_following_to_follow_rule.rb +3 -4
- data/db/migrate_core_cards/20150317162412_bootstrap_themes.rb +8 -4
- data/db/migrate_core_cards/20150326205655_bootswatch_themes.rb +14 -7
- data/db/migrate_core_cards/20150429090551_search_card_context.rb +6 -4
- data/db/migrate_core_cards/20150508212032_menu_compatibility.rb +4 -2
- data/db/migrate_core_cards/20150510031118_fix_skin_codenames.rb +2 -1
- data/db/migrate_core_cards/20150601133433_add_recent_setting_session_card.rb +3 -3
- data/db/migrate_core_cards/20150610171702_add_debugger_session_card.rb +2 -1
- data/db/migrate_core_cards/20150610180019_add_recaptcha_key_and_admin_info_cards.rb +4 -3
- data/db/migrate_core_cards/20150724123438_update_file_and_image_cards.rb +6 -2
- data/db/migrate_core_cards/20150807205221_create_references_for_search_cards.rb +1 -1
- data/db/migrate_core_cards/20150824135418_update_file_history.rb +2 -0
- data/db/migrate_core_cards/20160804112510_reorganize_scripts.rb +1 -1
- data/db/migrate_core_cards/20160811115836_rename_stats_to_admin.rb +1 -0
- data/db/migrate_core_cards/20160914132636_fix_mod_files.rb +2 -0
- data/db/migrate_core_cards/20161102202156_tweak_recaptcha_setting_cards.rb +6 -6
- data/db/migrate_core_cards/20161103154836_update_keys.rb +2 -1
- data/db/migrate_core_cards/20170209132834_email_test_context.rb +2 -0
- data/db/migrate_core_cards/20170314175313_add_notification_event_card.rb +3 -3
- data/db/migrate_core_cards/20170515101262_add_advanced_edit_cards.rb +1 -1
- data/db/migrate_core_cards/20170608200649_add_input_options_codename.rb +1 -1
- data/db/migrate_core_cards/20180712042655_head_rule.rb +3 -4
- data/db/migrate_core_cards/20180905061537_migrate_layouts.rb +4 -4
- data/db/migrate_core_cards/20181120200937_update_layout.rb +1 -1
- data/db/migrate_core_cards/20190320091257_upgrade_recaptcha_to_v3.rb +7 -7
- data/db/migrate_core_cards/20190424100531_update_credit_image.rb +1 -0
- data/db/migrate_core_cards/20190502130029_add_shark_and_help_desk_role.rb +15 -14
- data/db/migrate_core_cards/20190503122739_update_pristine_data.rb +1 -1
- data/db/migrate_core_cards/20190625153616_pointer_overhaul.rb +9 -5
- data/db/migrate_core_cards/20190718140126_add_guides.rb +3 -3
- data/db/migrate_core_cards/20190822093633_move_help_text_to_code.rb +1 -2
- data/db/migrate_core_cards/20190823220018_cleanup_for_decko_1_0.rb +1 -1
- data/db/migrate_core_cards/20190829093961_cardtype_grouping.rb +7 -7
- data/db/migrate_core_cards/20190902193208_input_type.rb +1 -3
- data/db/migrate_core_cards/20190909104250_add_cardtype_input_types.rb +2 -2
- data/db/migrate_core_cards/20191028135243_add_link_editor_to_tiny_mce_config.rb +1 -0
- data/db/migrate_core_cards/20191115160748_history_cleanup.rb +0 -1
- data/db/migrate_core_cards/20191118145629_codename_fixes.rb +1 -2
- data/db/migrate_core_cards/20200821231558_add_nest_list_type.rb +1 -1
- data/db/seed/new/card_actions.yml +2153 -2145
- data/db/seed/new/card_acts.yml +3 -3
- data/db/seed/new/card_references.yml +900 -858
- data/db/seed/new/cards.yml +4869 -4848
- data/db/seed/new/schema_migrations_deck_cards.yml +2 -0
- data/db/seed/test/fixtures/card_actions.yml +3563 -3547
- data/db/seed/test/fixtures/card_acts.yml +675 -675
- data/db/seed/test/fixtures/card_changes.yml +103 -103
- data/db/seed/test/fixtures/card_references.yml +2165 -2123
- data/db/seed/test/fixtures/cards.yml +7862 -7751
- data/db/seed/test/fixtures/schema_migrations_deck_cards.yml +2 -0
- data/db/test_seed.rb +33 -34
- data/lib/card.rb +1 -0
- data/lib/card/auth/token.rb +2 -2
- data/lib/card/cache.rb +2 -1
- data/lib/card/cache/all.rb +5 -0
- data/lib/card/cache/card_class.rb +3 -0
- data/lib/card/codename.rb +1 -1
- data/lib/card/content.rb +4 -8
- data/lib/card/content/chunk.rb +1 -1
- data/lib/card/content/clean.rb +4 -3
- data/lib/card/content/diff.rb +3 -2
- data/lib/card/content/diff/l_c_s/processor.rb +1 -1
- data/lib/card/content/diff/result.rb +1 -0
- data/lib/card/content/parser.rb +2 -2
- data/lib/card/content/truncate.rb +6 -6
- data/lib/card/director.rb +1 -1
- data/lib/card/director/all.rb +2 -2
- data/lib/card/director/card_methods.rb +1 -0
- data/lib/card/director/event_delay.rb +4 -6
- data/lib/card/director/run.rb +2 -0
- data/lib/card/director/stages.rb +3 -2
- data/lib/card/env/location.rb +4 -3
- data/lib/card/fetch.rb +7 -4
- data/lib/card/fetch/all.rb +1 -0
- data/lib/card/fetch/card_class.rb +35 -27
- data/lib/card/fetch/results.rb +9 -0
- data/lib/card/fetch/retrieve.rb +2 -0
- data/lib/card/fetch/store.rb +1 -0
- data/lib/card/format/content.rb +1 -3
- data/lib/card/format/error.rb +6 -1
- data/lib/card/format/method_delegation.rb +10 -2
- data/lib/card/format/nest.rb +2 -1
- data/lib/card/format/nest/fetch.rb +2 -0
- data/lib/card/format/nesting/mode.rb +1 -1
- data/lib/card/format/nesting/subformat.rb +2 -1
- data/lib/card/format/render.rb +2 -2
- data/lib/card/format/wrapper.rb +1 -1
- data/lib/card/lexicon.rb +3 -2
- data/lib/card/mark.rb +17 -15
- data/lib/card/model/save_helper.rb +3 -3
- data/lib/card/name.rb +10 -9
- data/lib/card/name/all.rb +3 -0
- data/lib/card/name/all/descendants.rb +3 -4
- data/lib/card/name/card_class.rb +2 -0
- data/lib/card/name/fields_and_traits.rb +4 -2
- data/lib/card/name/name_variants.rb +0 -1
- data/lib/card/query.rb +17 -17
- data/lib/card/query/card_query/interpretation.rb +1 -0
- data/lib/card/query/card_query/match_attributes.rb +2 -1
- data/lib/card/query/card_query/normalization.rb +1 -0
- data/lib/card/query/card_query/reference_attributes.rb +1 -1
- data/lib/card/query/join.rb +1 -1
- data/lib/card/query/value/match_value.rb +1 -0
- data/lib/card/reference/all.rb +7 -2
- data/lib/card/rule/all.rb +1 -0
- data/lib/card/rule/cache.rb +2 -0
- data/lib/card/set/advanced_api.rb +3 -2
- data/lib/card/set/event.rb +2 -2
- data/lib/card/set/event/all.rb +6 -0
- data/lib/card/set/event/delayed_event.rb +6 -6
- data/lib/card/set/event/options.rb +1 -0
- data/lib/card/set/format/abstract_format/view_definition.rb +1 -0
- data/lib/card/set/format/abstract_format/view_opts.rb +1 -0
- data/lib/card/set/i18n_scope.rb +4 -2
- data/lib/card/set/inheritance.rb +0 -1
- data/lib/card/set/loader.rb +0 -2
- data/lib/card/set/pattern/base.rb +3 -2
- data/lib/card/set/pattern/class_methods.rb +2 -2
- data/lib/card/set/required_field.rb +4 -1
- data/lib/card/setting.rb +3 -0
- data/lib/card/subcards.rb +3 -4
- data/lib/card/tasks/card/file_card_creator/abstract_file_card/ruby_file.rb +1 -1
- data/lib/card/tasks/card/file_card_creator/output_helper.rb +2 -4
- data/lib/card/tasks/card/migrate.rake +2 -2
- data/lib/card/view/cache.rb +6 -8
- data/lib/card/view/cache/cache_action.rb +1 -2
- data/lib/card/view/cache/stub.rb +1 -1
- data/lib/card/view/options.rb +3 -3
- data/lib/card/view/permission.rb +1 -0
- data/lib/cardio.rb +1 -1
- data/lib/cardio/migration.rb +1 -1
- data/lib/cardio/migration/deck_structure.rb +2 -4
- data/lib/cardio/migration/import.rb +2 -2
- data/lib/cardio/migration/import/import_data.rb +1 -0
- data/lib/cardio/mod.rb +1 -0
- data/lib/cardio/mod/load_strategy.rb +2 -4
- data/lib/cardio/mod/loader/set_loader.rb +2 -1
- data/lib/cardio/mod/module_template.rb +1 -0
- data/lib/cardio/modfiles.rb +2 -4
- data/lib/cardio/schema.rb +2 -4
- data/lib/cardio/utils.rb +1 -0
- data/lib/generators/card/format/format_generator.rb +1 -1
- data/lib/generators/card/migration/migration_generator.rb +2 -1
- data/lib/generators/card/mod/mod_generator.rb +3 -2
- data/lib/generators/card/set/set_generator.rb +3 -3
- data/lib/generators/card/template/template_generator.rb +1 -1
- data/mod/admin/set/self/admin.rb +6 -3
- data/mod/admin/set/self/trash.rb +1 -0
- data/mod/admin/spec/set/self/admin_spec.rb +4 -4
- data/mod/core/set/all/abort.rb +5 -5
- data/mod/core/set/all/assign_attributes.rb +5 -8
- data/mod/core/set/all/codename.rb +1 -0
- data/mod/core/set/all/collection.rb +4 -6
- data/mod/core/set/all/content.rb +3 -2
- data/mod/core/set/all/contextual_content.rb +2 -4
- data/mod/core/set/all/name_events.rb +13 -6
- data/mod/core/set/all/reference_events.rb +2 -0
- data/mod/core/set/all/states.rb +3 -3
- data/mod/core/set/all/subcards.rb +1 -1
- data/mod/core/set/all/trash.rb +5 -1
- data/mod/core/set/all/type.rb +4 -2
- data/mod/core/set/all/utils.rb +1 -1
- data/mod/core/spec/set/all/assign_attributes_spec.rb +10 -9
- data/mod/core/spec/set/all/clean_me_spec.rb +19 -4
- data/mod/core/spec/set/all/collection_spec.rb +1 -1
- data/mod/core/spec/set/all/export_spec.rb +1 -0
- data/mod/core/spec/set/all/initialize_spec.rb +11 -11
- metadata +4 -4
data/db/test_seed.rb
CHANGED
@@ -12,10 +12,9 @@ class SharedData
|
|
12
12
|
"Big Brother", "Optic fan", "Sunglasses fan", "Narcissist"
|
13
13
|
].freeze
|
14
14
|
|
15
|
-
CARDTYPE_COUNT =
|
15
|
+
CARDTYPE_COUNT = 44
|
16
16
|
|
17
17
|
class << self
|
18
|
-
|
19
18
|
def create_user name, args
|
20
19
|
args[:subcards] = account_args args if args[:email]
|
21
20
|
|
@@ -46,9 +45,10 @@ class SharedData
|
|
46
45
|
# CREATE A CARD OF EACH TYPE
|
47
46
|
|
48
47
|
no_samples = %w[user sign_up set number mirror_list mirrored_list file image
|
49
|
-
customized_bootswatch_skin]
|
48
|
+
customized_bootswatch_skin alias]
|
50
49
|
Card::Auth.createable_types.each do |type|
|
51
50
|
next if no_samples.include? type.to_name.key
|
51
|
+
|
52
52
|
create type: type, name: "Sample #{type}"
|
53
53
|
end
|
54
54
|
|
@@ -57,7 +57,7 @@ class SharedData
|
|
57
57
|
end
|
58
58
|
|
59
59
|
create_layout_type "lay out", "Greatest {{_main|title: Callahan!; view: labeled}}"
|
60
|
-
create_pointer "stacks", [
|
60
|
+
create_pointer "stacks", %w[horizontal vertical]
|
61
61
|
create_pointer "stacks+*self+*layout", "lay out"
|
62
62
|
create "horizontal"
|
63
63
|
create_pointer "vertical"
|
@@ -75,7 +75,7 @@ class SharedData
|
|
75
75
|
["Z", "I'm here to be referenced to"],
|
76
76
|
["A", "Alpha [[Z]]"],
|
77
77
|
["B", "Beta {{Z}}"],
|
78
|
-
[
|
78
|
+
%w[T Theta],
|
79
79
|
["X", "[[A]] [[A+B]] [[T]]"],
|
80
80
|
["Y", "{{B}} {{A+B}} {{A}} {{T}}"],
|
81
81
|
["A+B", "AlphaBeta"],
|
@@ -114,7 +114,8 @@ class SharedData
|
|
114
114
|
## --------- Fruit: creatable by anyone but not readable ---
|
115
115
|
Card.create! type: "Cardtype", name: "Fruit"
|
116
116
|
Card.create! name: "Fruit+*type+*create", type: "Pointer", content: "[[Anyone]]"
|
117
|
-
Card.create! name: "Fruit+*type+*read", type: "Pointer",
|
117
|
+
Card.create! name: "Fruit+*type+*read", type: "Pointer",
|
118
|
+
content: "[[Administrator]]"
|
118
119
|
|
119
120
|
# codenames for card_accessor tests
|
120
121
|
Card.create! name: "*write", codename: :write
|
@@ -158,7 +159,7 @@ class SharedData
|
|
158
159
|
|
159
160
|
def user_and_role_cards
|
160
161
|
# Card::Auth.instant_account_activation do
|
161
|
-
|
162
|
+
create_user "Joe Admin", content: "I'm number one", email: "joe@admin.com"
|
162
163
|
create_user "Joe User", content: "I'm number two", email: "joe@user.com"
|
163
164
|
create_user "Joe Camel", content: "Mr. Buttz", email: "joe@camel.com"
|
164
165
|
|
@@ -169,10 +170,10 @@ class SharedData
|
|
169
170
|
|
170
171
|
# noinspection RubyResolve
|
171
172
|
Card["Joe Admin"].fetch(:roles, new: { type_code: "pointer" })
|
172
|
-
|
173
|
+
.items = [Card::AdministratorID, Card::SharkID, Card::HelpDeskID]
|
173
174
|
|
174
175
|
Card["Joe User"].fetch(:roles, new: { type_code: "pointer" })
|
175
|
-
|
176
|
+
.items = [Card::SharkID]
|
176
177
|
|
177
178
|
create_user "u1", email: "u1@user.com", password: "u1_pass"
|
178
179
|
create_user "u2", email: "u2@user.com", password: "u2_pass"
|
@@ -188,19 +189,18 @@ class SharedData
|
|
188
189
|
Card["u3"].fetch(:roles, new: {}).items = [r1, r4, Card::AdministratorID]
|
189
190
|
end
|
190
191
|
|
191
|
-
|
192
192
|
def cardtype_cards
|
193
193
|
# for cql & permissions
|
194
|
-
%w[A+C A+D A+E C+A D+A F+A A+B+C].each {|name| create name}
|
194
|
+
%w[A+C A+D A+E C+A D+A F+A A+B+C].each { |name| create name }
|
195
195
|
("A".."F").each do |ch|
|
196
196
|
create "Cardtype #{ch}", type_code: "cardtype",
|
197
|
-
|
197
|
+
codename: "cardtype_#{ch.downcase}"
|
198
198
|
end
|
199
199
|
Card::Codename.reset_cache
|
200
200
|
|
201
201
|
("a".."f").each do |ch|
|
202
202
|
create "type-#{ch}-card", type_code: "cardtype_#{ch}",
|
203
|
-
|
203
|
+
content: "type_#{ch}_content"
|
204
204
|
end
|
205
205
|
|
206
206
|
create_pointer "Cardtype B+*type+*create", "[[r3]]"
|
@@ -210,7 +210,6 @@ class SharedData
|
|
210
210
|
create "Cardtype E+*type+*default"
|
211
211
|
end
|
212
212
|
|
213
|
-
|
214
213
|
def notification_cards
|
215
214
|
Timecop.freeze(Cardio.future_stamp - 1.day) do
|
216
215
|
# fwiw Timecop is apparently limited by ruby Time object,
|
@@ -231,7 +230,7 @@ class SharedData
|
|
231
230
|
|
232
231
|
followers.each do |name, _follow|
|
233
232
|
create_user name, email: "#{name.parameterize}@user.com",
|
234
|
-
|
233
|
+
password: "#{name.parameterize}_pass"
|
235
234
|
end
|
236
235
|
|
237
236
|
create "All Eyes On Me"
|
@@ -252,7 +251,8 @@ class SharedData
|
|
252
251
|
|
253
252
|
Card::Auth.signin Card::WagnBotID
|
254
253
|
create "Google glass+*self+*follow_fields", ""
|
255
|
-
create "Sunglasses+*self+*follow_fields",
|
254
|
+
create "Sunglasses+*self+*follow_fields",
|
255
|
+
"[[#{:nests.cardname}]]\n[[_self+price]]\n[[_self+producer]]"
|
256
256
|
create "Sunglasses+tint"
|
257
257
|
create "Sunglasses+price"
|
258
258
|
|
@@ -277,7 +277,7 @@ class SharedData
|
|
277
277
|
["card with fields", "field 1", "field 2"],
|
278
278
|
["card with fields and admin fields", "field 1", "admin field 1"],
|
279
279
|
["admin card with fields and admin fields", "field 1", "admin field 1"],
|
280
|
-
["admin card with admin fields", "admin field 1", "admin field 2"]
|
280
|
+
["admin card with admin fields", "admin field 1", "admin field 2"]
|
281
281
|
].each do |name, f1, f2|
|
282
282
|
create name,
|
283
283
|
content: "main content {{+#{f1}}} {{+#{f2}}}",
|
@@ -297,25 +297,24 @@ class SharedData
|
|
297
297
|
end
|
298
298
|
create ["field 1", :right, :read], type: "Pointer", content: "[[Anyone]]"
|
299
299
|
end
|
300
|
-
|
301
300
|
end
|
302
301
|
end
|
303
302
|
|
304
|
-
TEXT =
|
305
|
-
|
306
|
-
|
307
|
-
|
308
|
-
|
309
|
-
|
310
|
-
|
311
|
-
|
312
|
-
|
313
|
-
|
314
|
-
|
315
|
-
|
316
|
-
|
317
|
-
|
318
|
-
|
319
|
-
|
303
|
+
TEXT = <<~TXT.strip_heredoc.freeze
|
304
|
+
Far out in the uncharted backwaters of the unfashionable end of
|
305
|
+
the western spiral arm of the Galaxy lies a small unregarded
|
306
|
+
yellow sun.
|
307
|
+
#{' '}
|
308
|
+
Orbiting this at a distance of roughly ninety-two million miles
|
309
|
+
is an utterly insignificant little blue green planet whose ape-
|
310
|
+
descended life forms are so amazingly primitive that they still
|
311
|
+
think digital watches are a pretty neat idea.
|
312
|
+
#{' '}
|
313
|
+
This planet has - or rather had - a problem, which was this: most
|
314
|
+
of the people living on it were unhappy for pretty much of the time.
|
315
|
+
Many solutions were suggested for this problem, but most of these
|
316
|
+
were largely concerned with the movements of small green pieces
|
317
|
+
of paper, which is odd because on the whole it wasn't the small
|
318
|
+
green pieces of paper that were unhappy.
|
320
319
|
TXT
|
321
320
|
end
|
data/lib/card.rb
CHANGED
data/lib/card/auth/token.rb
CHANGED
data/lib/card/cache.rb
CHANGED
@@ -53,6 +53,7 @@ class Card
|
|
53
53
|
# on the persistent caches.
|
54
54
|
def renew
|
55
55
|
return if no_renewal
|
56
|
+
|
56
57
|
renew_persistent
|
57
58
|
cache_by_class.each_value do |cache|
|
58
59
|
cache.soft.reset
|
@@ -175,7 +176,7 @@ class Card
|
|
175
176
|
# test for the existence of the key in either cache
|
176
177
|
# @return [true/false]
|
177
178
|
def exist? key
|
178
|
-
@soft.exist?(key) ||
|
179
|
+
@soft.exist?(key) || @hard&.exist?(key)
|
179
180
|
end
|
180
181
|
end
|
181
182
|
end
|
data/lib/card/cache/all.rb
CHANGED
@@ -4,6 +4,7 @@ class Card
|
|
4
4
|
module All
|
5
5
|
def expire cache_type=nil
|
6
6
|
return unless (cache_class = cache_class_from_type cache_type)
|
7
|
+
|
7
8
|
expire_views
|
8
9
|
expire_names cache_class
|
9
10
|
expire_id cache_class
|
@@ -47,8 +48,10 @@ class Card
|
|
47
48
|
|
48
49
|
def expire_name name_version, cache
|
49
50
|
return unless name_version.present?
|
51
|
+
|
50
52
|
key_version = name_version.to_name.key
|
51
53
|
return unless key_version.present?
|
54
|
+
|
52
55
|
cache.delete key_version
|
53
56
|
end
|
54
57
|
|
@@ -57,6 +60,7 @@ class Card
|
|
57
60
|
# puts "EXPIRE VIEW CACHE (#{name}): #{view_cache_keys}"
|
58
61
|
view_keys = hard_read_view_cache_keys key
|
59
62
|
next unless view_keys.present?
|
63
|
+
|
60
64
|
expire_view_cache_keys view_keys
|
61
65
|
end
|
62
66
|
@view_cache_keys = []
|
@@ -64,6 +68,7 @@ class Card
|
|
64
68
|
|
65
69
|
def expire_id cache
|
66
70
|
return unless id.present?
|
71
|
+
|
67
72
|
cache.delete "~#{id}"
|
68
73
|
end
|
69
74
|
|
@@ -4,6 +4,7 @@ class Card
|
|
4
4
|
module CardClass
|
5
5
|
def retrieve_from_cache cache_key, local_only=false
|
6
6
|
return unless cache
|
7
|
+
|
7
8
|
local_only ? cache.soft.read(cache_key) : cache.read(cache_key)
|
8
9
|
end
|
9
10
|
|
@@ -28,12 +29,14 @@ class Card
|
|
28
29
|
|
29
30
|
def write_to_soft_cache card
|
30
31
|
return unless cache
|
32
|
+
|
31
33
|
cache.soft.write card.key, card
|
32
34
|
end
|
33
35
|
|
34
36
|
def expire name
|
35
37
|
key = name.to_name.key
|
36
38
|
return unless (card = Card.cache.read key)
|
39
|
+
|
37
40
|
card.expire
|
38
41
|
end
|
39
42
|
end
|
data/lib/card/codename.rb
CHANGED
data/lib/card/content.rb
CHANGED
@@ -99,16 +99,12 @@ class Card
|
|
99
99
|
"<#{__getobj__.class}:#{card}:#{self}>"
|
100
100
|
end
|
101
101
|
|
102
|
-
def without_nests
|
103
|
-
without_chunks Chunk::Nest
|
104
|
-
yield content
|
105
|
-
end
|
102
|
+
def without_nests &block
|
103
|
+
without_chunks Chunk::Nest, &block
|
106
104
|
end
|
107
105
|
|
108
|
-
def without_references
|
109
|
-
without_chunks Chunk::Nest, Chunk::Link
|
110
|
-
yield content
|
111
|
-
end
|
106
|
+
def without_references &block
|
107
|
+
without_chunks Chunk::Nest, Chunk::Link, &block
|
112
108
|
end
|
113
109
|
|
114
110
|
def without_chunks *chunk_classes
|
data/lib/card/content/chunk.rb
CHANGED
data/lib/card/content/clean.rb
CHANGED
@@ -46,7 +46,7 @@ class Card
|
|
46
46
|
# $LAST_MATCH_INFO is nil if string is a SafeBuffer
|
47
47
|
string.to_str.gsub(%r{<(/*)(\w+)([^>]*)>}) do |_raw|
|
48
48
|
clean_tag $LAST_MATCH_INFO, ok_tags
|
49
|
-
end.gsub(
|
49
|
+
end.gsub(/<!--.*?-->/, "")
|
50
50
|
end
|
51
51
|
|
52
52
|
def clean_spaces string
|
@@ -56,6 +56,7 @@ class Card
|
|
56
56
|
def clean_tag match, ok_tags
|
57
57
|
tag = match[2].downcase
|
58
58
|
return " " unless (ok_attrs = ok_tags[tag])
|
59
|
+
|
59
60
|
"<#{match[1]}#{html_attribs tag, match[3], ok_attrs}>"
|
60
61
|
end
|
61
62
|
|
@@ -70,7 +71,7 @@ class Card
|
|
70
71
|
return ['"', nil] unless all_attributes =~ /\b#{attrib}\s*=\s*(?=(.))/i
|
71
72
|
|
72
73
|
q = '"'
|
73
|
-
rest_value =
|
74
|
+
rest_value = Regexp.last_match.post_match
|
74
75
|
if (idx = %w[' "].index Regexp.last_match(1))
|
75
76
|
q = Regexp.last_match(1)
|
76
77
|
end
|
@@ -79,7 +80,7 @@ class Card
|
|
79
80
|
[q, rest_value]
|
80
81
|
end
|
81
82
|
|
82
|
-
# NOTE allows classes beginning with "w-" (deprecated)
|
83
|
+
# NOTE: allows classes beginning with "w-" (deprecated)
|
83
84
|
def process_attribute_match rest_value, reg_exp, attrib
|
84
85
|
return rest_value unless (match = rest_value.match reg_exp)
|
85
86
|
|
data/lib/card/content/diff.rb
CHANGED
@@ -22,6 +22,7 @@ class Card
|
|
22
22
|
end
|
23
23
|
|
24
24
|
attr_reader :result
|
25
|
+
|
25
26
|
delegate :summary, :complete, :summary_omits_content?, to: :result
|
26
27
|
|
27
28
|
# diff options
|
@@ -41,11 +42,11 @@ class Card
|
|
41
42
|
end
|
42
43
|
|
43
44
|
def red?
|
44
|
-
@result.dels_cnt
|
45
|
+
@result.dels_cnt.positive?
|
45
46
|
end
|
46
47
|
|
47
48
|
def green?
|
48
|
-
@result.adds_cnt
|
49
|
+
@result.adds_cnt.positive?
|
49
50
|
end
|
50
51
|
|
51
52
|
private
|
data/lib/card/content/parser.rb
CHANGED
@@ -62,7 +62,7 @@ class Card
|
|
62
62
|
# prefix of matched chunk
|
63
63
|
@chunk_start = prefix_match.begin(0) + @position
|
64
64
|
# content index of beginning of chunk
|
65
|
-
if prefix_match.begin(0)
|
65
|
+
if prefix_match.begin(0).positive?
|
66
66
|
# if matched chunk is not beginning of test string
|
67
67
|
@interval_string += @content[@position..@chunk_start - 1]
|
68
68
|
# hold onto the non-chunk part of the string
|
@@ -87,7 +87,7 @@ class Card
|
|
87
87
|
@chunks << @chunk_class.new(@match, @content_object)
|
88
88
|
# add the chunk to the chunk list
|
89
89
|
@last_position = @position
|
90
|
-
#
|
90
|
+
# NOTE: that the end of the chunk was the last place where a
|
91
91
|
# chunk was found (so far)
|
92
92
|
true
|
93
93
|
end
|
@@ -9,7 +9,7 @@ class Card
|
|
9
9
|
|
10
10
|
truncated, wordstring = truncate input, words
|
11
11
|
# nuke partial tags at end of snippet
|
12
|
-
wordstring.gsub!(/(<[
|
12
|
+
wordstring.gsub!(/(<[^>]+)$/, "")
|
13
13
|
wordstring = close_tags wordstring
|
14
14
|
wordstring += ELLIPSES_HTML if truncated
|
15
15
|
# wordstring += '...' if wordlist.length > l
|
@@ -34,9 +34,9 @@ class Card
|
|
34
34
|
end
|
35
35
|
|
36
36
|
def polish wordstring
|
37
|
-
wordstring.gsub! %r{
|
37
|
+
wordstring.gsub! %r{</?br[\s/]*>}, " "
|
38
38
|
# Also a hack -- get rid of <br>'s -- they make line view ugly.
|
39
|
-
wordstring.gsub! %r{
|
39
|
+
wordstring.gsub! %r{</?p[^>]*>}, " "
|
40
40
|
## Also a hack -- get rid of <br>'s -- they make line view ugly.
|
41
41
|
wordstring
|
42
42
|
end
|
@@ -45,17 +45,17 @@ class Card
|
|
45
45
|
tags = []
|
46
46
|
|
47
47
|
# match tags with or without self closing (ie. <foo />)
|
48
|
-
wordstring.scan(%r{
|
48
|
+
wordstring.scan(%r{<([^>\s/]+)[^>]*?>}).each do |t|
|
49
49
|
tags.unshift(t[0])
|
50
50
|
end
|
51
51
|
# match tags with self closing and mark them as closed
|
52
|
-
wordstring.scan(%r{
|
52
|
+
wordstring.scan(%r{<([^>\s/]+)[^>]*?/>}).each do |t|
|
53
53
|
next unless (x = tags.index(t[0]))
|
54
54
|
|
55
55
|
tags.slice!(x)
|
56
56
|
end
|
57
57
|
# match close tags
|
58
|
-
wordstring.scan(%r{
|
58
|
+
wordstring.scan(%r{</([^>\s/]+)[^>]*?>}).each do |t|
|
59
59
|
next unless (x = tags.rindex(t[0]))
|
60
60
|
|
61
61
|
tags.slice!(x)
|