card 1.104.2 → 1.105.1
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/README.md +5 -6
- data/VERSION +1 -1
- data/config/environments/development.rb +1 -1
- data/config/environments/test.rb +1 -0
- data/config/initializers/01_core_extensions/object.rb +10 -0
- data/config/initializers/01_core_extensions/string.rb +9 -0
- data/config/initializers/core_extensions.rb +1 -0
- data/db/migrate/{20160122153608_new_indeces.rb → 20160122153608_new_indices.rb} +2 -2
- data/db/migrate/{20200805200729_add_unique_pair_indeces.rb → 20200805200729_add_unique_pair_indices.rb} +1 -1
- data/db/migrate/20221031182227_remove_referee_key_requirement.rb +11 -0
- data/db/migrate_core_cards/20130920291703_update_stylesheets.rb +1 -9
- data/db/migrate_core_cards/20140307231621_user_data_to_cards.rb +1 -38
- data/db/migrate_core_cards/20161103154836_update_keys.rb +1 -1
- data/db/migrate_core_cards/20180905061537_migrate_layouts.rb +1 -1
- data/db/migrate_core_cards/20190125125150_add_script_rules_card.rb +1 -1
- data/db/migrate_core_cards/20190320091257_upgrade_recaptcha_to_v3.rb +1 -1
- data/db/migrate_core_cards/20190502130029_add_shark_and_help_desk_role.rb +2 -20
- data/db/migrate_core_cards/20190528131330_enabled_roles.rb +0 -3
- data/db/migrate_core_cards/20190625153616_pointer_overhaul.rb +0 -2
- data/db/migrate_core_cards/20190718140126_add_guides.rb +1 -1
- data/db/migrate_core_cards/20190822093633_move_help_text_to_code.rb +1 -1
- data/db/migrate_core_cards/20190829205148_remove_add_help.rb +1 -1
- data/db/migrate_core_cards/20190902193208_input_type.rb +1 -1
- data/db/migrate_core_cards/20190909104250_add_cardtype_input_types.rb +2 -2
- data/db/schema.rb +2 -2
- data/db/seeds.rb +14 -1
- data/db/version.txt +1 -1
- data/lib/card/auth/current.rb +4 -2
- data/lib/card/auth/permissions.rb +1 -1
- data/lib/card/auth/setup.rb +1 -1
- data/lib/card/auth/token.rb +1 -1
- data/lib/card/cache/persistent.rb +4 -1
- data/lib/card/codename.rb +2 -6
- data/lib/card/content/all.rb +2 -2
- data/lib/card/content/clean.rb +1 -1
- data/lib/card/content/parser.rb +0 -2
- data/lib/card/content.rb +1 -8
- data/lib/card/director/all.rb +67 -0
- data/lib/card/director/card_class.rb +161 -2
- data/lib/card/director/{act_direction.rb → class_methods.rb} +13 -3
- data/lib/card/director/phases.rb +7 -4
- data/lib/card/director/run.rb +51 -50
- data/lib/card/director/stages.rb +18 -16
- data/lib/card/director/store.rb +1 -1
- data/lib/card/director.rb +6 -7
- data/lib/card/env/location.rb +1 -1
- data/lib/card/env/serializable.rb +2 -0
- data/lib/card/env/serialization.rb +2 -3
- data/lib/card/env.rb +2 -2
- data/lib/card/error.rb +9 -5
- data/lib/card/fetch/card_class.rb +19 -13
- data/lib/card/format/error.rb +6 -12
- data/lib/card/format/nest.rb +1 -1
- data/lib/card/format/wrapper.rb +1 -1
- data/lib/card/format.rb +4 -0
- data/lib/card/model/save_helper/save_arguments.rb +0 -44
- data/lib/card/model/save_helper/save_helper_helper.rb +0 -37
- data/lib/card/model/save_helper.rb +0 -82
- data/lib/card/name/all.rb +1 -4
- data/lib/card/name/card_class.rb +0 -2
- data/lib/card/name/name_variants.rb +4 -0
- data/lib/card/name.rb +3 -8
- data/lib/card/query/abstract_query/query_helper.rb +3 -5
- data/lib/card/query/abstract_query/tie.rb +1 -1
- data/lib/card/query/abstract_query.rb +36 -17
- data/lib/card/query/card_class.rb +36 -0
- data/lib/card/query/card_query/custom.rb +12 -0
- data/lib/card/query/card_query/interpretation.rb +1 -0
- data/lib/card/query/card_query/normalization.rb +11 -3
- data/lib/card/query/card_query/reference_attributes.rb +3 -2
- data/lib/card/query/card_query/sorting.rb +5 -4
- data/lib/card/query/card_query.rb +1 -0
- data/lib/card/query/sql_statement/order.rb +12 -10
- data/lib/card/query/sql_statement/where.rb +2 -2
- data/lib/card/query.rb +13 -6
- data/lib/card/reference/all.rb +10 -10
- data/lib/card/set/abstract.rb +1 -0
- data/lib/card/set/advanced_api.rb +1 -1
- data/lib/card/set/event/all.rb +9 -1
- data/lib/card/set/event/delayed_event.rb +4 -2
- data/lib/card/set/event/options.rb +1 -1
- data/lib/card/set/event/skip_and_trigger.rb +34 -10
- data/lib/card/set/format/abstract_format/haml_views.rb +3 -3
- data/lib/card/set/format/abstract_format/wrapper.rb +0 -1
- data/lib/card/set/format/abstract_format.rb +5 -4
- data/lib/card/set/format/haml_paths.rb +5 -21
- data/lib/card/set/format.rb +46 -20
- data/lib/card/set/helpers.rb +49 -36
- data/lib/card/set/inheritance.rb +4 -4
- data/lib/card/set/pattern/all.rb +1 -1
- data/lib/card/set/pattern/base.rb +1 -1
- data/lib/card/set/pattern/class_methods.rb +4 -4
- data/lib/card/set/registrar.rb +3 -5
- data/lib/card/set/required_field.rb +3 -2
- data/lib/card/set/trait.rb +1 -1
- data/lib/card/set/type.rb +1 -41
- data/lib/card/set.rb +67 -21
- data/lib/card/setting.rb +0 -1
- data/lib/card/subcards/all.rb +6 -8
- data/lib/card/subcards/args.rb +9 -9
- data/lib/card/view/cache/cache_action.rb +1 -1
- data/lib/card/view/options/visibility.rb +4 -0
- data/lib/card/view/options.rb +1 -0
- data/lib/card/view/permission.rb +12 -4
- data/lib/card/view.rb +4 -0
- data/lib/card.rb +48 -39
- data/lib/cardio/cli.rb +3 -1
- data/lib/cardio/command/application.rb +5 -0
- data/lib/cardio/{commands/command.rb → command/command_base.rb} +2 -2
- data/lib/cardio/{commands → command}/custom.rb +17 -13
- data/lib/cardio/{commands → command}/rake_command/parser.rb +3 -3
- data/lib/cardio/{commands → command}/rake_command.rb +5 -5
- data/lib/cardio/{commands → command}/rspec_command/parser.rb +9 -6
- data/lib/cardio/{commands → command}/rspec_command.rb +7 -9
- data/lib/cardio/command.rb +129 -0
- data/lib/cardio/commands.rb +17 -116
- data/lib/cardio/generators/deck_generator_loader.rb +1 -0
- data/lib/cardio/generators.rb +2 -2
- data/lib/cardio/migration.rb +3 -53
- data/lib/cardio/mod/class_methods.rb +28 -24
- data/lib/cardio/mod/dirs.rb +30 -23
- data/lib/cardio/mod/eat/edibles.rb +43 -16
- data/lib/cardio/mod/eat.rb +20 -14
- data/lib/cardio/mod/load_strategy/set_tmp_files.rb +1 -1
- data/lib/cardio/mod/load_strategy.rb +12 -2
- data/lib/cardio/mod/modfile_api.rb +18 -18
- data/lib/cardio/mod/{poop.rb → sow.rb} +25 -33
- data/lib/cardio/mod.rb +46 -73
- data/lib/cardio/railtie.rb +21 -58
- data/lib/cardio/schema.rb +2 -1
- data/lib/cardio/script_loader.rb +3 -1
- data/lib/cardio/seed.rb +101 -8
- data/lib/cardio/utils.rb +39 -1
- data/lib/generators/deck/deck_generator.rb +5 -2
- data/lib/generators/deck/templates/config/puma.rb +1 -1
- data/lib/generators/deck/templates/script/decko_rspec +1 -1
- data/lib/generators/deck/templates/simplecov.rb.erb +10 -8
- data/lib/generators/mod/USAGE +1 -1
- data/lib/generators/mod/mod_generator.rb +5 -5
- data/lib/generators/set/USAGE +2 -2
- data/mod/core/{locales → config/locales}/de.yml +4 -0
- data/mod/core/{locales → config/locales}/en.yml +13 -0
- data/mod/core/data/fixtures/real/card_actions.yml +78 -0
- data/{db/seed/new → mod/core/data/fixtures/real}/card_acts.yml +2 -2
- data/mod/core/data/fixtures/real/card_references.yml +8 -0
- data/mod/core/data/fixtures/real/cards.yml +135 -0
- data/mod/core/data/real.yml +79 -0
- data/mod/core/data/test/cardtype.yml +38 -0
- data/mod/core/data/test/sample.yml +50 -0
- data/mod/core/data/test/user.yml +41 -0
- data/mod/core/data/test.yml +79 -28
- data/{lib → mod/core/lib}/tasks/card/migrate.rake +4 -0
- data/{lib → mod/core/lib}/tasks/card/mod.rake +9 -5
- data/mod/core/lib/tasks/card/seed.rake +60 -0
- data/mod/core/lib/tasks/card.rake +119 -0
- data/mod/core/set/all/admin.rb +14 -0
- data/mod/core/set/all/codename.rb +4 -0
- data/mod/core/set/all/content.rb +8 -4
- data/mod/core/set/all/{abort.rb → result.rb} +11 -15
- data/mod/core/set/all/states.rb +21 -1
- data/mod/core/set/all/trash.rb +25 -73
- data/mod/core/set/all/type.rb +2 -2
- data/mod/core/set/all/utils.rb +3 -87
- data/mod/core/set/right/autoname.rb +2 -0
- data/mod/core/set/self/admin/warning_alert.haml +3 -0
- data/mod/core/set/self/admin.rb +173 -0
- data/mod/core/set/type/cardtype.rb +2 -0
- data/mod/core/set_pattern/02_all_plus.rb +1 -1
- data/mod/core/set_pattern/05_rstar.rb +1 -1
- data/mod/core/set_pattern/06_rule.rb +1 -1
- data/mod/core/set_pattern/07_right.rb +1 -1
- data/mod/core/set_pattern/08_type_plus_right.rb +1 -1
- data/mod/core/spec/set/all/assign_attributes_spec.rb +3 -3
- data/mod/core/spec/set/all/autoname_spec.rb +25 -0
- data/mod/core/spec/set/all/codename_spec.rb +1 -1
- data/mod/core/spec/set/all/name_events_spec.rb +43 -66
- data/mod/core/spec/set/all/trash_spec.rb +149 -68
- data/mod/{admin → core}/spec/set/self/admin_spec.rb +25 -22
- data/mod/core/spec/set/self/trash_spec.rb +5 -0
- metadata +88 -253
- data/db/migrate_core_cards/20130411211600_delete_old_related_tab_cards.rb +0 -18
- data/db/migrate_core_cards/20130419215612_import_help_text.rb +0 -13
- data/db/migrate_core_cards/20130823192433_add_style_cards.rb +0 -100
- data/db/migrate_core_cards/20130910183318_move_styles_to_content.rb +0 -11
- data/db/migrate_core_cards/20130927191728_account_events.rb +0 -20
- data/db/migrate_core_cards/20131016172445_common_css_patch.rb +0 -9
- data/db/migrate_core_cards/20140110193325_reset_account_request_type.rb +0 -8
- data/db/migrate_core_cards/20140512155840_add_script_cards.rb +0 -86
- data/db/migrate_core_cards/20140629222005_add_email_cards.rb +0 -132
- data/db/migrate_core_cards/20140725180118_config_card_updates.rb +0 -9
- data/db/migrate_core_cards/20141111083921_delete_machine_output.rb +0 -7
- data/db/migrate_core_cards/20141115034214_config_descriptions_etc.rb +0 -14
- data/db/migrate_core_cards/20141119001955_make_symlinks_relative.rb +0 -15
- data/db/migrate_core_cards/20141120120605_fix_notification_html_message.rb +0 -10
- data/db/migrate_core_cards/20141216155251_add_more_following_cards.rb +0 -26
- data/db/migrate_core_cards/20141230204340_uri_codename.rb +0 -13
- data/db/migrate_core_cards/20150202143810_import_bootstrap_layout.rb +0 -76
- data/db/migrate_core_cards/20150317162412_bootstrap_themes.rb +0 -41
- data/db/migrate_core_cards/20150326205655_bootswatch_themes.rb +0 -36
- data/db/migrate_core_cards/20150331135745_new_card_menu.rb +0 -8
- data/db/migrate_core_cards/20150501010515_responsive_sidebar.rb +0 -11
- data/db/migrate_core_cards/20150508212032_menu_compatibility.rb +0 -24
- data/db/migrate_core_cards/20150528084659_add_session_cardtype.rb +0 -18
- data/db/migrate_core_cards/20150601133433_add_recent_setting_session_card.rb +0 -18
- data/db/migrate_core_cards/20150610171702_add_debugger_session_card.rb +0 -12
- data/db/migrate_core_cards/20150610180019_add_recaptcha_key_and_admin_info_cards.rb +0 -58
- data/db/migrate_core_cards/20150627205133_fix_script_bootstrap_card_type.rb +0 -7
- data/db/migrate_core_cards/20150702130543_remove_edit_toolbar_pinned.rb +0 -9
- data/db/migrate_core_cards/20150708224756_add_list_cards.rb +0 -29
- data/db/migrate_core_cards/20150903130006_attachment_upload_cards.rb +0 -15
- data/db/migrate_core_cards/20150910085603_remove_performance_log_card.rb +0 -10
- data/db/migrate_core_cards/20151120180631_add_token_expiration.rb +0 -7
- data/db/migrate_core_cards/20160801143221_change_bootstrap_card_type_to_scss.rb +0 -10
- data/db/migrate_core_cards/20160804112510_reorganize_scripts.rb +0 -27
- data/db/migrate_core_cards/20160908154210_add_trash_card.rb +0 -7
- data/db/migrate_core_cards/20161102202156_tweak_recaptcha_setting_cards.rb +0 -17
- data/db/migrate_core_cards/20170209132834_email_test_context.rb +0 -49
- data/db/migrate_core_cards/20170314175313_add_notification_event_card.rb +0 -20
- data/db/migrate_core_cards/20170515101262_add_advanced_edit_cards.rb +0 -20
- data/db/migrate_core_cards/20170608083819_add_full_width_layout_card.rb +0 -23
- data/db/migrate_core_cards/20170608200649_add_input_options_codename.rb +0 -8
- data/db/migrate_core_cards/20180423120222_add_mod_styles_card.rb +0 -20
- data/db/migrate_core_cards/20180508210903_add_json_type.rb +0 -10
- data/db/migrate_core_cards/20180515175726_add_codenames.rb +0 -8
- data/db/migrate_core_cards/20180712042655_head_rule.rb +0 -13
- data/db/migrate_core_cards/20181120200937_update_layout.rb +0 -7
- data/db/migrate_core_cards/20190204195039_add_rule_card.rb +0 -10
- data/db/migrate_core_cards/20190321085735_wagn_to_decko_logo.rb +0 -11
- data/db/migrate_core_cards/20190417142612_reorganize_scripts_2.rb +0 -17
- data/db/migrate_core_cards/20190424100531_update_credit_image.rb +0 -76
- data/db/migrate_core_cards/20190424101004_add_read_anyone_rules.rb +0 -13
- data/db/migrate_core_cards/20190503122739_update_pristine_data.rb +0 -18
- data/db/migrate_core_cards/20190605133556_tweak_config_cards.rb +0 -10
- data/db/migrate_core_cards/20190618110446_add_dropdown_divider.rb +0 -8
- data/db/migrate_core_cards/20190621143156_add_role_assign_permissions.rb +0 -9
- data/db/migrate_core_cards/20190710090209_homepage_tweaks.rb +0 -13
- data/db/migrate_core_cards/20190820155833_update_cardtype_type_structure.rb +0 -7
- data/db/migrate_core_cards/20190823220018_cleanup_for_decko_1_0.rb +0 -19
- data/db/migrate_core_cards/20190826132738_add_more_guides.rb +0 -7
- data/db/migrate_core_cards/20190829093961_cardtype_grouping.rb +0 -16
- data/db/migrate_core_cards/20190830131820_setting_settings_aside.rb +0 -17
- data/db/migrate_core_cards/20190902161223_add_style_media.rb +0 -7
- data/db/migrate_core_cards/20190918200115_ensure_description_card.rb +0 -13
- data/db/migrate_core_cards/20191008201046_fixture_fix.rb +0 -11
- data/db/migrate_core_cards/20191028135243_add_link_editor_to_tiny_mce_config.rb +0 -9
- data/db/migrate_core_cards/20191118145629_codename_fixes.rb +0 -5
- data/db/migrate_core_cards/20200821231558_add_nest_list_type.rb +0 -9
- data/db/migrate_core_cards/data/1.11_help_text.json +0 -410
- data/db/migrate_core_cards/data/1.12_stylesheets/classic_cards.scss +0 -104
- data/db/migrate_core_cards/data/1.12_stylesheets/common.scss +0 -228
- data/db/migrate_core_cards/data/1.12_stylesheets/right_sidebar.scss +0 -27
- data/db/migrate_core_cards/data/1.12_stylesheets/traditional.scss +0 -143
- data/db/migrate_core_cards/data/1.13_config_text.json +0 -32
- data/db/migrate_core_cards/data/1.14_config_descriptions_etc.json +0 -77
- data/db/migrate_core_cards/data/bootstrap_layout.json +0 -96
- data/db/migrate_core_cards/data/cards/Xaccount +0 -22
- data/db/migrate_core_cards/data/cards/Xaccount_setting-Xright-Xstructure +0 -12
- data/db/migrate_core_cards/data/cards/Xall-Xlayout +0 -1
- data/db/migrate_core_cards/data/cards/Xcredit +0 -2
- data/db/migrate_core_cards/data/cards/Xfooter +0 -3
- data/db/migrate_core_cards/data/cards/Xgetting_started +0 -31
- data/db/migrate_core_cards/data/cards/Xgetting_started-shark +0 -66
- data/db/migrate_core_cards/data/cards/Xgetting_started_link +0 -6
- data/db/migrate_core_cards/data/cards/Xheader +0 -19
- data/db/migrate_core_cards/data/cards/Xhome +0 -1
- data/db/migrate_core_cards/data/cards/Xlogo +0 -1
- data/db/migrate_core_cards/data/cards/Xmain_menu +0 -2
- data/db/migrate_core_cards/data/cards/Xrecaptcha_setting-Xself-Xstructure +0 -1
- data/db/migrate_core_cards/data/cards/Xsidebar +0 -7
- data/db/migrate_core_cards/data/cards/Xstructure-Xright-Xguide +0 -12
- data/db/migrate_core_cards/data/cards/Xtitle +0 -1
- data/db/migrate_core_cards/data/cards/administrator-dashboard +0 -23
- data/db/migrate_core_cards/data/cards/administrator-description +0 -1
- data/db/migrate_core_cards/data/cards/anyone_signed_in-dashboard +0 -0
- data/db/migrate_core_cards/data/cards/cardtype-Xtype-Xguide +0 -24
- data/db/migrate_core_cards/data/cards/cardtype-Xtype-Xstructure +0 -3
- data/db/migrate_core_cards/data/cards/default_layout +0 -6
- data/db/migrate_core_cards/data/cards/full_width_layout +0 -5
- data/db/migrate_core_cards/data/cards/help_desk-dashboard +0 -7
- data/db/migrate_core_cards/data/cards/help_desk-description +0 -1
- data/db/migrate_core_cards/data/cards/home +0 -2
- data/db/migrate_core_cards/data/cards/home-Xself-Xlayout +0 -1
- data/db/migrate_core_cards/data/cards/home-original +0 -22
- data/db/migrate_core_cards/data/cards/home_layout +0 -6
- data/db/migrate_core_cards/data/cards/left_sidebar_layout +0 -6
- data/db/migrate_core_cards/data/cards/menu +0 -1
- data/db/migrate_core_cards/data/cards/right_thin_sidebar_layout +0 -8
- data/db/migrate_core_cards/data/cards/role-Xtype-Xstructure +0 -2
- data/db/migrate_core_cards/data/cards/shark-dashboard +0 -19
- data/db/migrate_core_cards/data/cards/shark-description +0 -1
- data/db/migrate_core_cards/data/cards/shark_menu +0 -2
- data/db/migrate_core_cards/data/cards.yml +0 -138
- data/db/migrate_core_cards/data/decko_logo.svg +0 -1
- data/db/migrate_core_cards/data/mailer/follower_notification_email.html +0 -9
- data/db/migrate_core_cards/data/mailer/follower_notification_email.txt +0 -11
- data/db/migrate_core_cards/data/mailer/mail_config.json +0 -22
- data/db/migrate_core_cards/data/mailer/password_reset_email.html +0 -13
- data/db/migrate_core_cards/data/mailer/password_reset_email.txt +0 -11
- data/db/migrate_core_cards/data/mailer/signup_alert_email.html +0 -7
- data/db/migrate_core_cards/data/mailer/signup_alert_email.txt +0 -5
- data/db/migrate_core_cards/data/mailer/verification_email.html +0 -12
- data/db/migrate_core_cards/data/mailer/verification_email.txt +0 -9
- data/db/migrate_core_cards/data/skin_images.json +0 -91
- data/db/migrate_core_cards/data/themes/bootstrap_default/_bootswatch.scss +0 -0
- data/db/migrate_core_cards/data/themes/bootstrap_default/_variables.scss +0 -867
- data/db/migrate_core_cards/data/themes/cerulean/_bootswatch.scss +0 -125
- data/db/migrate_core_cards/data/themes/cerulean/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/cosmo/_bootswatch.scss +0 -237
- data/db/migrate_core_cards/data/themes/cosmo/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/cyborg/_bootswatch.scss +0 -210
- data/db/migrate_core_cards/data/themes/cyborg/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/darkly/_bootswatch.scss +0 -330
- data/db/migrate_core_cards/data/themes/darkly/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/flatly/_bootswatch.scss +0 -313
- data/db/migrate_core_cards/data/themes/flatly/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/journal/_bootswatch.scss +0 -120
- data/db/migrate_core_cards/data/themes/journal/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/lumen/_bootswatch.scss +0 -496
- data/db/migrate_core_cards/data/themes/lumen/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/paper/_bootswatch.scss +0 -607
- data/db/migrate_core_cards/data/themes/paper/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/readable/_bootswatch.scss +0 -174
- data/db/migrate_core_cards/data/themes/readable/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/sandstone/_bootswatch.scss +0 -194
- data/db/migrate_core_cards/data/themes/sandstone/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/simplex/_bootswatch.scss +0 -142
- data/db/migrate_core_cards/data/themes/simplex/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/slate/_bootswatch.scss +0 -417
- data/db/migrate_core_cards/data/themes/slate/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/spacelab/_bootswatch.scss +0 -137
- data/db/migrate_core_cards/data/themes/spacelab/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/superhero/_bootswatch.scss +0 -332
- data/db/migrate_core_cards/data/themes/superhero/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/united/_bootswatch.scss +0 -42
- data/db/migrate_core_cards/data/themes/united/_variables.scss +0 -861
- data/db/migrate_core_cards/data/themes/yeti/_bootswatch.scss +0 -437
- data/db/migrate_core_cards/data/themes/yeti/_variables.scss +0 -861
- data/db/seed/README.md +0 -2
- data/db/seed/new/card_actions.yml +0 -5913
- data/db/seed/new/card_references.yml +0 -6532
- data/db/seed/new/cards.yml +0 -14595
- data/db/seed/test/fixtures/card_actions.yml +0 -8153
- data/db/seed/test/fixtures/card_acts.yml +0 -1039
- data/db/seed/test/fixtures/card_changes.yml +0 -230
- data/db/seed/test/fixtures/card_references.yml +0 -8471
- data/db/seed/test/fixtures/cards.yml +0 -20171
- data/db/seed/test/fixtures/file1.txt +0 -1
- data/db/seed/test/fixtures/file2.txt +0 -1
- data/db/seed/test/fixtures/mao2.jpg +0 -0
- data/db/seed/test/fixtures/rails.gif +0 -0
- data/db/seed/test/fixtures/schema_migrations.yml +0 -67
- data/db/seed/test/fixtures/schema_migrations_core_cards.yml +0 -347
- data/db/seed/test/fixtures/schema_migrations_deck.yml +0 -1
- data/db/seed/test/fixtures/schema_migrations_deck_cards.yml +0 -5
- data/db/test_seed.rb +0 -322
- data/lib/card/content/truncate.rb +0 -67
- data/lib/card/director/card_methods.rb +0 -45
- data/lib/card/file_card_creator/abstract_file_card/migration_file.rb +0 -50
- data/lib/card/file_card_creator/abstract_file_card/ruby_file.rb +0 -30
- data/lib/card/file_card_creator/abstract_file_card/source_file.rb +0 -36
- data/lib/card/file_card_creator/abstract_file_card.rb +0 -44
- data/lib/card/file_card_creator/haml_card.rb +0 -42
- data/lib/card/file_card_creator/output_helper.rb +0 -53
- data/lib/card/file_card_creator/script_card.rb +0 -35
- data/lib/card/file_card_creator/style_card.rb +0 -25
- data/lib/card/file_card_creator.rb +0 -25
- data/lib/card/name/fields_and_traits.rb +0 -42
- data/lib/cardio/commands/application.rb +0 -10
- data/lib/cardio/migration/import/import_data/card_attributes.rb +0 -64
- data/lib/cardio/migration/import/import_data/card_content.rb +0 -30
- data/lib/cardio/migration/import/import_data.rb +0 -119
- data/lib/cardio/migration/import/merger.rb +0 -46
- data/lib/cardio/migration/import.rb +0 -125
- data/lib/tasks/card/create.rake +0 -81
- data/lib/tasks/card.rake +0 -65
- data/mod/admin/locales/de.yml +0 -4
- data/mod/admin/locales/en.yml +0 -4
- data/mod/admin/set/all/admin.rb +0 -16
- data/mod/admin/set/self/admin.rb +0 -144
- data/mod/admin/set/self/admin_info.rb +0 -40
- data/mod/admin/set/self/debugger.rb +0 -3
- data/mod/admin/spec/set/self/admin_info_spec.rb +0 -9
- data/mod/core/data/production.yml +0 -7
- data/mod/core/set/all/collection.rb +0 -53
- data/mod/core/spec/set/all/collection_spec.rb +0 -170
- data/mod/core/spec/set/all/utils_spec.rb +0 -5
- data/mod/standard/data/files/favicon/image-icon.png +0 -0
- data/mod/standard/data/files/favicon/image-large.png +0 -0
- data/mod/standard/data/files/favicon/image-medium.png +0 -0
- data/mod/standard/data/files/favicon/image-original.png +0 -0
- data/mod/standard/data/files/favicon/image-small.png +0 -0
- data/mod/standard/data/files/logo/image-original.svg +0 -1
- /data/{db/seed/new → mod/core/data/fixtures/real}/card_changes.yml +0 -0
- /data/{db/seed/new → mod/core/data/fixtures/real}/schema_migrations.yml +0 -0
- /data/{db/seed/new → mod/core/data/fixtures/real}/schema_migrations_core_cards.yml +0 -0
- /data/{db/seed/new → mod/core/data/fixtures/real}/schema_migrations_deck.yml +0 -0
- /data/{db/seed/new → mod/core/data/fixtures/real}/schema_migrations_deck_cards.yml +0 -0
@@ -3,16 +3,175 @@ class Card
|
|
3
3
|
# director-related Card class methods
|
4
4
|
module CardClass
|
5
5
|
def create! opts
|
6
|
-
card =
|
6
|
+
card = new opts
|
7
7
|
card.save!
|
8
8
|
card
|
9
9
|
end
|
10
10
|
|
11
11
|
def create opts
|
12
|
-
card =
|
12
|
+
card = new opts
|
13
13
|
card.save
|
14
14
|
card
|
15
15
|
end
|
16
|
+
|
17
|
+
# The ensure methods are use to make sure a card exists and can be used when you're
|
18
|
+
# unsure as to whether it already does. It's arguments are largely the same as
|
19
|
+
# those used by {#create Card#create} and {Director::All#update @card.update} with
|
20
|
+
# the important exception of `conflict`.
|
21
|
+
#
|
22
|
+
# The conflict argument takes one of three values:
|
23
|
+
#
|
24
|
+
# - **defer**: let existing card stay as it is
|
25
|
+
# - **default**: update existing card if it is "pristine" (meaning it has not
|
26
|
+
# been edited by anyone other than Decko Bot)
|
27
|
+
# - **override**: update existing card
|
28
|
+
#
|
29
|
+
# If the options specify a codename and the name is already in use, things get a
|
30
|
+
# little more involved. (Note: we MUST ensure that a card with the codename exists!)
|
31
|
+
#
|
32
|
+
# If the conflict setting is "**defer**":
|
33
|
+
#
|
34
|
+
# - if the _codename_ is NOT already in use, we create a new card with an
|
35
|
+
# altered name
|
36
|
+
# - otherwise we do nothing.
|
37
|
+
#
|
38
|
+
# If the conflict setting is "**default**":
|
39
|
+
#
|
40
|
+
# - if the _codename_ is NOT already in use:
|
41
|
+
# - if the card using the name we want is pristine, we update that card
|
42
|
+
# - otherwise we create a new card with an altered name
|
43
|
+
# - if the _codename_ IS already in use
|
44
|
+
# - if the card with the codename is pristine, we update everything but the
|
45
|
+
# name (which is used by another card)
|
46
|
+
# - otherwise we do nothing
|
47
|
+
#
|
48
|
+
# If the conflict setting is "**override**":
|
49
|
+
#
|
50
|
+
# - if the _codename_ is NOT already in use, we update the existing card with the
|
51
|
+
# name.
|
52
|
+
# - otherwise we alter the card withe the conflicting name and update the card
|
53
|
+
# with the codename.
|
54
|
+
def ensure opts
|
55
|
+
ensuring opts, &:save_if_needed
|
56
|
+
end
|
57
|
+
|
58
|
+
def ensure! opts
|
59
|
+
ensuring opts, &:save_if_needed!
|
60
|
+
end
|
61
|
+
|
62
|
+
private
|
63
|
+
|
64
|
+
def ensuring opts
|
65
|
+
opts.symbolize_keys!
|
66
|
+
with_conflict_mode opts.delete(:conflict) do
|
67
|
+
card, other = fetch_for_ensure opts
|
68
|
+
ensuring_purity(card, other, opts) do |ensured_card, attempt|
|
69
|
+
yield ensured_card if attempt
|
70
|
+
ensured_card
|
71
|
+
end
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
def with_conflict_mode mode
|
76
|
+
@conflict_mode = mode&.to_sym || :default
|
77
|
+
yield
|
78
|
+
ensure
|
79
|
+
Card::Director.clear
|
80
|
+
@conflict_mode = nil
|
81
|
+
end
|
82
|
+
|
83
|
+
def fetch_for_ensure opts
|
84
|
+
if opts[:codename] && opts[:name]
|
85
|
+
fetch_for_ensure_with_codename_and_name opts
|
86
|
+
elsif (mark = opts[:codename]&.to_sym || opts[:name])
|
87
|
+
[fetch_and_assign(mark, opts), nil]
|
88
|
+
else
|
89
|
+
raise Card::Error::ServerError, "Card.ensure must have name or codename"
|
90
|
+
end
|
91
|
+
end
|
92
|
+
|
93
|
+
def fetch_for_ensure_with_codename_and_name opts
|
94
|
+
codename = opts[:codename].to_sym
|
95
|
+
codename_id = id codename
|
96
|
+
name_id = id opts[:name]
|
97
|
+
|
98
|
+
other_card = name_id && (codename_id != name_id) ? name_id.card : nil
|
99
|
+
[fetch_and_assign(codename, opts), other_card]
|
100
|
+
end
|
101
|
+
|
102
|
+
def fetch_and_assign mark, opts
|
103
|
+
if id(mark) && (card = fetch mark)
|
104
|
+
card.tap { |c| c.assign_attributes opts }
|
105
|
+
else
|
106
|
+
new opts
|
107
|
+
end
|
108
|
+
end
|
109
|
+
|
110
|
+
def ensuring_purity card, other, opts, &block
|
111
|
+
if opts[:codename] && other
|
112
|
+
ensure_purity_advanced card, other, opts, &block
|
113
|
+
else
|
114
|
+
ensure_purity_simple card, &block
|
115
|
+
end
|
116
|
+
end
|
117
|
+
|
118
|
+
def ensure_purity_advanced card, other, opts
|
119
|
+
attempt_card = send "ensure_advanced_#{@conflict_mode}", card, other, opts
|
120
|
+
attempt_card ? yield(attempt_card, true) : yield(card, false)
|
121
|
+
end
|
122
|
+
|
123
|
+
def ensure_purity_simple card
|
124
|
+
attempt_save =
|
125
|
+
case @conflict_mode
|
126
|
+
when :override then true
|
127
|
+
when :default then card.pristine?
|
128
|
+
when :defer then card.new?
|
129
|
+
else
|
130
|
+
invalid_conflict_mode!
|
131
|
+
end
|
132
|
+
yield card, attempt_save
|
133
|
+
end
|
134
|
+
|
135
|
+
def ensure_advanced_defer card, other, _opts
|
136
|
+
return unless card.new? # codenamed card doesn't exist yet
|
137
|
+
|
138
|
+
card.name = other.name.alternative
|
139
|
+
card
|
140
|
+
end
|
141
|
+
|
142
|
+
def ensure_advanced_default card, other, opts
|
143
|
+
return unless card.pristine?
|
144
|
+
|
145
|
+
if card.new? && other.pristine?
|
146
|
+
other.assign_attributes opts
|
147
|
+
other
|
148
|
+
else
|
149
|
+
ensure_non_conflicting_name card
|
150
|
+
end
|
151
|
+
end
|
152
|
+
|
153
|
+
def ensure_advanced_override card, other, opts
|
154
|
+
if card.new?
|
155
|
+
other.assign_attributes opts
|
156
|
+
other
|
157
|
+
else
|
158
|
+
other.name = other.name.alternative
|
159
|
+
other.save
|
160
|
+
card.skip_event! :validate_renaming # so that type and content can also change
|
161
|
+
card
|
162
|
+
end
|
163
|
+
end
|
164
|
+
|
165
|
+
def ensure_non_conflicting_name card
|
166
|
+
card.name = card.new? ? card.name.alternative : card.name_before_act
|
167
|
+
card
|
168
|
+
end
|
169
|
+
|
170
|
+
# LOCALIZE
|
171
|
+
def invalid_conflict_mode!
|
172
|
+
raise Card::Error::ServerError, "invalid conflict mode: #{@conflict_mode}. " \
|
173
|
+
"Must be defer, default, or override"
|
174
|
+
end
|
16
175
|
end
|
17
176
|
end
|
18
177
|
end
|
@@ -1,6 +1,9 @@
|
|
1
1
|
class Card
|
2
2
|
class Director
|
3
|
-
|
3
|
+
# Card::Director class methods
|
4
|
+
module ClassMethods
|
5
|
+
include EventDelay
|
6
|
+
|
4
7
|
attr_accessor :act, :act_card
|
5
8
|
|
6
9
|
def act_director
|
@@ -31,7 +34,6 @@ class Card
|
|
31
34
|
directors.each_pair do |card, _dir|
|
32
35
|
card.expire
|
33
36
|
card.director = nil
|
34
|
-
card.action = nil
|
35
37
|
card.clear_action_specific_attributes
|
36
38
|
end
|
37
39
|
expire
|
@@ -92,7 +94,8 @@ class Card
|
|
92
94
|
def delete director
|
93
95
|
return unless @directors
|
94
96
|
|
95
|
-
|
97
|
+
# normal delete was sometimes failing here (eg. when aborting in finalize stage)
|
98
|
+
@directors.delete_if { |k, _v| k == director.card }
|
96
99
|
director.delete
|
97
100
|
end
|
98
101
|
|
@@ -110,6 +113,13 @@ class Card
|
|
110
113
|
def to_s
|
111
114
|
act_director.to_s
|
112
115
|
end
|
116
|
+
|
117
|
+
private
|
118
|
+
|
119
|
+
def delete_card card
|
120
|
+
card_key = @directors.keys.find { |key| key == card }
|
121
|
+
@directors.delete card_key if card_key
|
122
|
+
end
|
113
123
|
end
|
114
124
|
end
|
115
125
|
end
|
data/lib/card/director/phases.rb
CHANGED
@@ -11,7 +11,7 @@ class Card
|
|
11
11
|
end
|
12
12
|
|
13
13
|
def integration_phase_callback?
|
14
|
-
!@only_storage_phase && main?
|
14
|
+
!@abort && !@only_storage_phase && main?
|
15
15
|
end
|
16
16
|
|
17
17
|
def prepare_for_phases
|
@@ -32,15 +32,17 @@ class Card
|
|
32
32
|
# Unlike other phases, the storage phase takes a block,
|
33
33
|
# because it is called by an "around" callback
|
34
34
|
def storage_phase &block
|
35
|
-
catch_up_to_stage :prepare_to_store
|
36
|
-
|
37
|
-
run_stage :
|
35
|
+
catch_up_to_stage :prepare_to_store # unless @abort
|
36
|
+
# puts "before store #{@card.name}: abort:#{@abort}"
|
37
|
+
run_stage :store, &block # unless @abort
|
38
|
+
run_stage :finalize # unless @abort
|
38
39
|
raise ActiveRecord::RecordInvalid, @card if @card.errors.any?
|
39
40
|
ensure
|
40
41
|
@from_trash = nil
|
41
42
|
end
|
42
43
|
|
43
44
|
def integration_phase
|
45
|
+
# puts "integration phase: #{@card.name}"
|
44
46
|
return if @abort
|
45
47
|
|
46
48
|
@card.restore_changes_information
|
@@ -49,6 +51,7 @@ class Card
|
|
49
51
|
run_stage :integrate_with_delay
|
50
52
|
ensure
|
51
53
|
@card.clear_changes_information unless @abort
|
54
|
+
@card.expire unless Cardio.delaying? # if delaying, then expired by clear
|
52
55
|
end
|
53
56
|
end
|
54
57
|
end
|
data/lib/card/director/run.rb
CHANGED
@@ -13,7 +13,7 @@ class Card
|
|
13
13
|
def run_delayed_event act
|
14
14
|
@running = true
|
15
15
|
@act = act
|
16
|
-
@
|
16
|
+
@current_stage_index = stage_index :integrate_with_delay
|
17
17
|
yield
|
18
18
|
run_subcard_stages :integrate_with_delay
|
19
19
|
end
|
@@ -24,65 +24,33 @@ class Card
|
|
24
24
|
|
25
25
|
def restart
|
26
26
|
@running = false
|
27
|
-
@
|
27
|
+
@current_stage_index = nil
|
28
28
|
end
|
29
29
|
|
30
30
|
private
|
31
31
|
|
32
|
-
def upto_stage stage
|
33
|
-
@stage ||= -1
|
34
|
-
(@stage + 1).upto(stage_index(stage)) do |i|
|
35
|
-
yield stage_symbol(i)
|
36
|
-
end
|
37
|
-
end
|
38
|
-
|
39
|
-
def valid_next_stage? next_stage
|
40
|
-
@stage ||= -1
|
41
|
-
return false if in_or_after?(next_stage) || ahead_of_parent?(next_stage)
|
42
|
-
return false unless valid_card? next_stage
|
43
|
-
|
44
|
-
check_skipped_stage next_stage
|
45
|
-
true
|
46
|
-
end
|
47
|
-
|
48
|
-
def valid_card? next_stage
|
49
|
-
@card.errors.empty? || in_or_before?(:validate, next_stage)
|
50
|
-
end
|
51
|
-
|
52
|
-
def check_skipped_stage stage
|
53
|
-
return unless before? previous_stage_index(stage)
|
54
|
-
|
55
|
-
raise Card::Error, "stage #{previous_stage_symbol stage} was " \
|
56
|
-
"skipped for card #{@card}"
|
57
|
-
end
|
58
|
-
|
59
|
-
def ahead_of_parent? next_stage
|
60
|
-
return false if head?
|
61
|
-
|
62
|
-
after? parent.stage, next_stage
|
63
|
-
end
|
64
|
-
|
65
32
|
def run_stage stage, &block
|
66
33
|
return true unless valid_next_stage? stage
|
67
34
|
|
68
35
|
# puts "#{@card.name}: #{stage} stage".yellow
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
prepare_for_phases if stage == :initialize
|
36
|
+
@current_stage_index = stage_index stage
|
37
|
+
handle_stage stage, block do
|
38
|
+
run_stage_callbacks stage
|
39
|
+
run_subcard_stages stage
|
40
|
+
run_final_stage_callbacks stage
|
41
|
+
end
|
76
42
|
end
|
77
43
|
|
78
|
-
def
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
44
|
+
def handle_stage stage, block
|
45
|
+
case stage
|
46
|
+
when :initialize
|
47
|
+
prepare_for_phases
|
48
|
+
when :store
|
49
|
+
# in the store stage it can be necessary that
|
50
|
+
# other subcards must be saved before we save this card
|
51
|
+
return store(&block)
|
52
|
+
end
|
53
|
+
yield
|
86
54
|
end
|
87
55
|
|
88
56
|
def run_stage_callbacks stage, callback_postfix=""
|
@@ -115,6 +83,39 @@ class Card
|
|
115
83
|
def run_final_stage_callbacks stage
|
116
84
|
run_stage_callbacks stage, "_final"
|
117
85
|
end
|
86
|
+
|
87
|
+
def upto_stage stage
|
88
|
+
@current_stage_index ||= -1
|
89
|
+
(@current_stage_index + 1).upto(stage_index(stage)) do |i|
|
90
|
+
yield stage_symbol(i)
|
91
|
+
end
|
92
|
+
end
|
93
|
+
|
94
|
+
def valid_next_stage? next_stage
|
95
|
+
@current_stage_index ||= -1
|
96
|
+
return false if @abort ||
|
97
|
+
in_or_after?(next_stage) ||
|
98
|
+
ahead_of_parent?(next_stage) ||
|
99
|
+
!valid_card?(next_stage)
|
100
|
+
|
101
|
+
check_skipped_stage next_stage
|
102
|
+
true
|
103
|
+
end
|
104
|
+
|
105
|
+
def valid_card? next_stage
|
106
|
+
@card.errors.empty? || in_or_before?(:validate, next_stage)
|
107
|
+
end
|
108
|
+
|
109
|
+
def check_skipped_stage stage
|
110
|
+
return unless before? previous_stage_index(stage)
|
111
|
+
|
112
|
+
raise Card::Error, "stage #{previous_stage_symbol stage} was " \
|
113
|
+
"skipped for card #{@card}"
|
114
|
+
end
|
115
|
+
|
116
|
+
def ahead_of_parent? next_stage
|
117
|
+
head? ? false : after?(parent.current_stage_index, next_stage)
|
118
|
+
end
|
118
119
|
end
|
119
120
|
end
|
120
121
|
end
|
data/lib/card/director/stages.rb
CHANGED
@@ -1,29 +1,31 @@
|
|
1
1
|
class Card
|
2
2
|
class Director
|
3
|
-
# Methods for
|
3
|
+
# Methods for interpreting stages of an action
|
4
4
|
module Stages
|
5
|
-
|
6
|
-
|
7
|
-
|
8
|
-
|
5
|
+
SYMBOLS = %i[initialize prepare_to_validate validate] + # Validation phase
|
6
|
+
%i[prepare_to_store store finalize] + # Storage phase
|
7
|
+
%i[integrate after_integrate integrate_with_delay] # Integration phase
|
8
|
+
.freeze
|
9
|
+
|
10
|
+
INDECES = SYMBOLS.each_with_index.with_object({}) do |(stage, index), hash|
|
9
11
|
Card.define_callbacks "#{stage}_stage", "#{stage}_final_stage"
|
10
12
|
hash[stage] = index
|
11
13
|
end.freeze
|
12
14
|
|
13
15
|
def stage_symbol index
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
16
|
+
if index.is_a?(Symbol) && INDECES[index]
|
17
|
+
index
|
18
|
+
elsif index.is_a?(Integer) && index < SYMBOLS.size
|
19
|
+
SYMBOLS[index]
|
20
|
+
else
|
21
|
+
raise Card::Error, "not a valid stage index: #{index}"
|
19
22
|
end
|
20
|
-
raise Card::Error, "not a valid stage index: #{index}"
|
21
23
|
end
|
22
24
|
|
23
25
|
def stage_index stage
|
24
26
|
case stage
|
25
27
|
when Symbol
|
26
|
-
|
28
|
+
INDECES[stage]
|
27
29
|
when Integer
|
28
30
|
stage
|
29
31
|
when nil
|
@@ -41,17 +43,17 @@ class Card
|
|
41
43
|
end
|
42
44
|
|
43
45
|
def finished_stage? stage
|
44
|
-
@
|
46
|
+
@current_stage_index > stage_index(stage)
|
45
47
|
end
|
46
48
|
|
47
49
|
def reset_stage
|
48
|
-
@
|
50
|
+
@current_stage_index = -1
|
49
51
|
end
|
50
52
|
|
51
53
|
private
|
52
54
|
|
53
55
|
def previous_stage_index from_stage=nil
|
54
|
-
from_stage ||= @
|
56
|
+
from_stage ||= @current_stage_index
|
55
57
|
stage_index(from_stage) - 1
|
56
58
|
end
|
57
59
|
|
@@ -80,7 +82,7 @@ class Card
|
|
80
82
|
end
|
81
83
|
|
82
84
|
def stage_test reference_stage, test_stage=nil
|
83
|
-
test_stage ||= @
|
85
|
+
test_stage ||= @current_stage_index
|
84
86
|
yield stage_index(reference_stage), stage_index(test_stage)
|
85
87
|
end
|
86
88
|
end
|
data/lib/card/director/store.rb
CHANGED
@@ -63,7 +63,7 @@ class Card
|
|
63
63
|
# by the parent director. So the storage phase will only run
|
64
64
|
# the :store stage and the :finalize stage
|
65
65
|
def trigger_storage_phase_callback
|
66
|
-
@
|
66
|
+
@current_stage_index = stage_index :prepare_to_store
|
67
67
|
@only_storage_phase = true
|
68
68
|
@card.save! validate: false, as_subcard: true
|
69
69
|
end
|
data/lib/card/director.rb
CHANGED
@@ -100,7 +100,7 @@ class Card
|
|
100
100
|
# self/bar.rb
|
101
101
|
#
|
102
102
|
# event :met_a_foo_at_the_bar, :prepare_to_store, on: :update do
|
103
|
-
#
|
103
|
+
# subcard "foo"
|
104
104
|
# end
|
105
105
|
#
|
106
106
|
# And then you run `Card[:bar].update!({})`.
|
@@ -133,15 +133,14 @@ class Card
|
|
133
133
|
#
|
134
134
|
# ---
|
135
135
|
class Director
|
136
|
-
extend
|
137
|
-
extend ActDirection
|
136
|
+
extend ClassMethods
|
138
137
|
|
139
138
|
include Stages
|
140
139
|
include Phases
|
141
140
|
include Run
|
142
141
|
include Store
|
143
142
|
|
144
|
-
attr_accessor :act, :card, :
|
143
|
+
attr_accessor :act, :card, :current_stage_index, :parent, :subdirectors, :head
|
145
144
|
attr_reader :running
|
146
145
|
alias_method :running?, :running
|
147
146
|
|
@@ -150,7 +149,7 @@ class Card
|
|
150
149
|
@card.director = self
|
151
150
|
# for read actions there is no validation phase
|
152
151
|
# so we have to set the action here
|
153
|
-
@
|
152
|
+
@current_stage_index = nil
|
154
153
|
@running = false
|
155
154
|
@prepared = false
|
156
155
|
@parent = parent
|
@@ -178,7 +177,7 @@ class Card
|
|
178
177
|
@parent&.subdirectors&.delete self
|
179
178
|
@card.director = nil
|
180
179
|
@subdirectors.clear
|
181
|
-
@
|
180
|
+
@current_stage_index = nil
|
182
181
|
@action = nil
|
183
182
|
@running = false
|
184
183
|
end
|
@@ -220,7 +219,7 @@ class Card
|
|
220
219
|
card.director = self
|
221
220
|
@card = card
|
222
221
|
reset_stage
|
223
|
-
catch_up_to_stage @
|
222
|
+
catch_up_to_stage @current_stage_index if @current_stage_index
|
224
223
|
end
|
225
224
|
|
226
225
|
def update_card card
|
data/lib/card/env/location.rb
CHANGED
@@ -11,11 +11,10 @@ class Card
|
|
11
11
|
# @param serialized_env [Hash]
|
12
12
|
def with serialized_env
|
13
13
|
tmp_env = serialize
|
14
|
-
@
|
15
|
-
@env.update serialized_env
|
14
|
+
@serialized.update serialized_env
|
16
15
|
yield
|
17
16
|
ensure
|
18
|
-
@
|
17
|
+
@serialized.update tmp_env if tmp_env
|
19
18
|
end
|
20
19
|
|
21
20
|
# supercede serializable methods when serialized values are available
|
data/lib/card/env.rb
CHANGED
data/lib/card/error.rb
CHANGED
@@ -1,5 +1,14 @@
|
|
1
1
|
# -*- encoding : utf-8 -*-
|
2
2
|
|
3
|
+
class StandardError
|
4
|
+
MAX_BACKTRACE_LINES = 20
|
5
|
+
|
6
|
+
def report
|
7
|
+
Rails.logger.info "exception = #{self.class}: #{message}"
|
8
|
+
Rails.logger.debug backtrace[0..MAX_BACKTRACE_LINES].join("\n")
|
9
|
+
end
|
10
|
+
end
|
11
|
+
|
3
12
|
class Card
|
4
13
|
# exceptions and errors.
|
5
14
|
# (arguably most of these should be Card::Exception)
|
@@ -29,11 +38,6 @@ class Card
|
|
29
38
|
@backtrace || super
|
30
39
|
end
|
31
40
|
|
32
|
-
def report
|
33
|
-
Rails.logger.info "exception = #{self.class}: #{message}"
|
34
|
-
Rails.logger.debug backtrace.join("\n")
|
35
|
-
end
|
36
|
-
|
37
41
|
def card_message_text
|
38
42
|
card.errors.first&.message
|
39
43
|
end
|
@@ -1,29 +1,32 @@
|
|
1
1
|
class Card
|
2
2
|
class Fetch
|
3
|
-
#
|
4
|
-
#
|
5
|
-
# A multipurpose retrieval operator that integrates caching, database lookups,
|
3
|
+
# A multipurpose retrieval system that integrates caching, database lookups,
|
6
4
|
# and "virtual" card construction
|
7
5
|
module CardClass
|
8
6
|
# Look for cards in
|
9
|
-
#
|
10
|
-
#
|
11
|
-
#
|
7
|
+
# * cache
|
8
|
+
# * database
|
9
|
+
# * virtual cards
|
12
10
|
#
|
13
11
|
# @param args [Integer, String, Card::Name, Symbol, Array]
|
14
12
|
# Initials args must be one or more "marks," which uniquely idenfify cards:
|
13
|
+
#
|
14
|
+
#
|
15
15
|
# 1. a name/key. (String or Card::Name)
|
16
16
|
# 2. a numeric id. Can be (a) an Integer or (b) a String with an integer
|
17
17
|
# prefixed with a tilde, eg "~1234"
|
18
18
|
# 3. a codename. Can be (a) a Symbol or (b) a String with a colon prefix,
|
19
19
|
# eg :mycodename
|
20
|
+
#
|
20
21
|
# If you pass more then one mark or an array of marks they get joined with a '+'.
|
21
22
|
# The final argument can be a Hash to set the following options
|
22
|
-
#
|
23
|
-
#
|
24
|
-
#
|
25
|
-
#
|
26
|
-
#
|
23
|
+
#
|
24
|
+
# :skip_virtual Real cards only
|
25
|
+
# :skip_modules Don't load Set modules
|
26
|
+
# :look_in_trash Return trashed card objects
|
27
|
+
# :local_only Use only local cache for lookup and storing
|
28
|
+
# new: { opts for Card#new } Return a new card when not found
|
29
|
+
#
|
27
30
|
# @return [Card]
|
28
31
|
def fetch *args
|
29
32
|
f = Fetch.new(*args)
|
@@ -32,9 +35,9 @@ class Card
|
|
32
35
|
Card.new name: "card id out of range: #{f.mark}"
|
33
36
|
end
|
34
37
|
|
35
|
-
# fetch only real (no
|
38
|
+
# a shortcut for fetch that returns only real cards (no virtuals)
|
36
39
|
#
|
37
|
-
# @param mark - see #fetch
|
40
|
+
# @param mark [various] - see {#fetch}
|
38
41
|
# @return [Card]
|
39
42
|
def [] *mark
|
40
43
|
fetch(*mark, skip_virtual: true)
|
@@ -62,6 +65,9 @@ class Card
|
|
62
65
|
# ATTRIBUTE FETCHING
|
63
66
|
# The following methods optimize fetching of specific attributes
|
64
67
|
|
68
|
+
# numerical card id
|
69
|
+
# @params cardish [various] interprets integers as id, symbols as codename, etc
|
70
|
+
# @return [Integer]
|
65
71
|
def id cardish
|
66
72
|
case cardish
|
67
73
|
when Integer then cardish
|