fluid_cli 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/README.md +1 -0
- data/dev.yml +5 -0
- data/exe/fluid +24 -0
- data/lib/fluid_cli/api.rb +135 -0
- data/lib/fluid_cli/assets/post_auth_page/index.html.erb +34 -0
- data/lib/fluid_cli/assets/post_auth_page/style.css +58 -0
- data/lib/fluid_cli/command.rb +55 -0
- data/lib/fluid_cli/commands/help.rb +21 -0
- data/lib/fluid_cli/commands/login.rb +30 -0
- data/lib/fluid_cli/commands/logout.rb +38 -0
- data/lib/fluid_cli/commands/switch.rb +23 -0
- data/lib/fluid_cli/commands/theme/common/company_helper.rb +15 -0
- data/lib/fluid_cli/commands/theme/common/root_helper.rb +95 -0
- data/lib/fluid_cli/commands/theme/dev.rb +61 -0
- data/lib/fluid_cli/commands/theme/help.rb +21 -0
- data/lib/fluid_cli/commands/theme/init.rb +46 -0
- data/lib/fluid_cli/commands/theme/pull.rb +68 -0
- data/lib/fluid_cli/commands/theme/push.rb +132 -0
- data/lib/fluid_cli/commands/theme.rb +23 -0
- data/lib/fluid_cli/commands/whoami.rb +23 -0
- data/lib/fluid_cli/commands.rb +19 -0
- data/lib/fluid_cli/company_switcher.rb +69 -0
- data/lib/fluid_cli/context.rb +691 -0
- data/lib/fluid_cli/db.rb +114 -0
- data/lib/fluid_cli/entry_point.rb +10 -0
- data/lib/fluid_cli/environment.rb +32 -0
- data/lib/fluid_cli/file_system_listener.rb +29 -0
- data/lib/fluid_cli/form.rb +42 -0
- data/lib/fluid_cli/git.rb +319 -0
- data/lib/fluid_cli/http_request.rb +54 -0
- data/lib/fluid_cli/identity_auth/servlet.rb +39 -0
- data/lib/fluid_cli/identity_auth.rb +126 -0
- data/lib/fluid_cli/options.rb +38 -0
- data/lib/fluid_cli/theme/dev_server/certificate_manager.rb +79 -0
- data/lib/fluid_cli/theme/dev_server/errors.rb +9 -0
- data/lib/fluid_cli/theme/dev_server/header_hash.rb +98 -0
- data/lib/fluid_cli/theme/dev_server/hooks/file_change_hook.rb +39 -0
- data/lib/fluid_cli/theme/dev_server/hot_reload/resources/hot-reload-no-script.html +27 -0
- data/lib/fluid_cli/theme/dev_server/hot_reload/resources/hot_reload.js +28 -0
- data/lib/fluid_cli/theme/dev_server/hot_reload/resources/sse_client.js +43 -0
- data/lib/fluid_cli/theme/dev_server/hot_reload/resources/theme.js +16 -0
- data/lib/fluid_cli/theme/dev_server/hot_reload/script_injector.rb +54 -0
- data/lib/fluid_cli/theme/dev_server/hot_reload.rb +75 -0
- data/lib/fluid_cli/theme/dev_server/local_assets.rb +92 -0
- data/lib/fluid_cli/theme/dev_server/proxy.rb +235 -0
- data/lib/fluid_cli/theme/dev_server/proxy_param_builder.rb +82 -0
- data/lib/fluid_cli/theme/dev_server/reload_mode.rb +34 -0
- data/lib/fluid_cli/theme/dev_server/sse.rb +75 -0
- data/lib/fluid_cli/theme/dev_server/watcher.rb +57 -0
- data/lib/fluid_cli/theme/dev_server/web_server.rb +140 -0
- data/lib/fluid_cli/theme/dev_server.rb +289 -0
- data/lib/fluid_cli/theme/development_theme.rb +101 -0
- data/lib/fluid_cli/theme/file.rb +105 -0
- data/lib/fluid_cli/theme/forms/select.rb +33 -0
- data/lib/fluid_cli/theme/mime_type.rb +34 -0
- data/lib/fluid_cli/theme/presenters/theme_presenter.rb +49 -0
- data/lib/fluid_cli/theme/presenters/themes_presenter.rb +31 -0
- data/lib/fluid_cli/theme/root.rb +62 -0
- data/lib/fluid_cli/theme/syncer/checksums.rb +66 -0
- data/lib/fluid_cli/theme/syncer/downloader.rb +54 -0
- data/lib/fluid_cli/theme/syncer/error_reporter.rb +45 -0
- data/lib/fluid_cli/theme/syncer/merger.rb +53 -0
- data/lib/fluid_cli/theme/syncer/operation.rb +58 -0
- data/lib/fluid_cli/theme/syncer/standard_reporter.rb +32 -0
- data/lib/fluid_cli/theme/syncer/unsupported_script_warning.rb +90 -0
- data/lib/fluid_cli/theme/syncer/uploader/forms/apply_to_all.rb +41 -0
- data/lib/fluid_cli/theme/syncer/uploader/forms/apply_to_all_form.rb +37 -0
- data/lib/fluid_cli/theme/syncer/uploader/forms/base_strategy_form.rb +64 -0
- data/lib/fluid_cli/theme/syncer/uploader/forms/select_delete_strategy.rb +29 -0
- data/lib/fluid_cli/theme/syncer/uploader/forms/select_update_strategy.rb +30 -0
- data/lib/fluid_cli/theme/syncer/uploader/json_delete_handler.rb +49 -0
- data/lib/fluid_cli/theme/syncer/uploader/json_update_handler.rb +71 -0
- data/lib/fluid_cli/theme/syncer/uploader.rb +105 -0
- data/lib/fluid_cli/theme/syncer.rb +412 -0
- data/lib/fluid_cli/theme/theme.rb +186 -0
- data/lib/fluid_cli/theme/ui/sync_progress_bar.rb +22 -0
- data/lib/fluid_cli/thread_pool/job.rb +35 -0
- data/lib/fluid_cli/thread_pool.rb +49 -0
- data/lib/fluid_cli/version.rb +3 -0
- data/lib/fluid_cli.rb +59 -0
- data/vendor/deps/base64/.document +5 -0
- data/vendor/deps/base64/.gitignore +9 -0
- data/vendor/deps/base64/BSDL +22 -0
- data/vendor/deps/base64/COPYING +56 -0
- data/vendor/deps/base64/Gemfile +9 -0
- data/vendor/deps/base64/LEGAL +60 -0
- data/vendor/deps/base64/README.md +48 -0
- data/vendor/deps/base64/Rakefile +31 -0
- data/vendor/deps/base64/base64.gemspec +28 -0
- data/vendor/deps/base64/bin/console +14 -0
- data/vendor/deps/base64/bin/setup +8 -0
- data/vendor/deps/base64/lib/base64.rb +382 -0
- data/vendor/deps/base64/sig/base64.rbs +358 -0
- data/vendor/deps/base64/test/base64/test_base64.rb +115 -0
- data/vendor/deps/base64/test_sig/test_base64.rb +44 -0
- data/vendor/deps/cli-kit/REVISION +1 -0
- data/vendor/deps/cli-kit/lib/cli/kit/args/definition.rb +286 -0
- data/vendor/deps/cli-kit/lib/cli/kit/args/evaluation.rb +215 -0
- data/vendor/deps/cli-kit/lib/cli/kit/args/parser/node.rb +128 -0
- data/vendor/deps/cli-kit/lib/cli/kit/args/parser.rb +125 -0
- data/vendor/deps/cli-kit/lib/cli/kit/args/tokenizer.rb +130 -0
- data/vendor/deps/cli-kit/lib/cli/kit/args.rb +16 -0
- data/vendor/deps/cli-kit/lib/cli/kit/base_command.rb +30 -0
- data/vendor/deps/cli-kit/lib/cli/kit/command_help.rb +268 -0
- data/vendor/deps/cli-kit/lib/cli/kit/command_registry.rb +150 -0
- data/vendor/deps/cli-kit/lib/cli/kit/config.rb +137 -0
- data/vendor/deps/cli-kit/lib/cli/kit/core_ext.rb +28 -0
- data/vendor/deps/cli-kit/lib/cli/kit/error_handler.rb +166 -0
- data/vendor/deps/cli-kit/lib/cli/kit/executor.rb +92 -0
- data/vendor/deps/cli-kit/lib/cli/kit/ini.rb +91 -0
- data/vendor/deps/cli-kit/lib/cli/kit/levenshtein.rb +92 -0
- data/vendor/deps/cli-kit/lib/cli/kit/logger.rb +94 -0
- data/vendor/deps/cli-kit/lib/cli/kit/opts.rb +248 -0
- data/vendor/deps/cli-kit/lib/cli/kit/parse_args.rb +55 -0
- data/vendor/deps/cli-kit/lib/cli/kit/resolver.rb +66 -0
- data/vendor/deps/cli-kit/lib/cli/kit/support/test_helper.rb +260 -0
- data/vendor/deps/cli-kit/lib/cli/kit/support.rb +11 -0
- data/vendor/deps/cli-kit/lib/cli/kit/system.rb +290 -0
- data/vendor/deps/cli-kit/lib/cli/kit/util.rb +118 -0
- data/vendor/deps/cli-kit/lib/cli/kit/version.rb +7 -0
- data/vendor/deps/cli-kit/lib/cli/kit.rb +139 -0
- data/vendor/deps/cli-ui/REVISION +1 -0
- data/vendor/deps/cli-ui/lib/cli/ui/ansi.rb +218 -0
- data/vendor/deps/cli-ui/lib/cli/ui/color.rb +101 -0
- data/vendor/deps/cli-ui/lib/cli/ui/formatter.rb +219 -0
- data/vendor/deps/cli-ui/lib/cli/ui/frame/frame_stack.rb +67 -0
- data/vendor/deps/cli-ui/lib/cli/ui/frame/frame_style/box.rb +179 -0
- data/vendor/deps/cli-ui/lib/cli/ui/frame/frame_style/bracket.rb +152 -0
- data/vendor/deps/cli-ui/lib/cli/ui/frame/frame_style.rb +127 -0
- data/vendor/deps/cli-ui/lib/cli/ui/frame.rb +286 -0
- data/vendor/deps/cli-ui/lib/cli/ui/glyph.rb +92 -0
- data/vendor/deps/cli-ui/lib/cli/ui/os.rb +63 -0
- data/vendor/deps/cli-ui/lib/cli/ui/printer.rb +64 -0
- data/vendor/deps/cli-ui/lib/cli/ui/progress.rb +132 -0
- data/vendor/deps/cli-ui/lib/cli/ui/progress_reporter.rb +209 -0
- data/vendor/deps/cli-ui/lib/cli/ui/prompt/interactive_options.rb +583 -0
- data/vendor/deps/cli-ui/lib/cli/ui/prompt/options_handler.rb +36 -0
- data/vendor/deps/cli-ui/lib/cli/ui/prompt.rb +381 -0
- data/vendor/deps/cli-ui/lib/cli/ui/spinner/async.rb +48 -0
- data/vendor/deps/cli-ui/lib/cli/ui/spinner/spin_group.rb +602 -0
- data/vendor/deps/cli-ui/lib/cli/ui/spinner.rb +79 -0
- data/vendor/deps/cli-ui/lib/cli/ui/stdout_router.rb +399 -0
- data/vendor/deps/cli-ui/lib/cli/ui/table.rb +83 -0
- data/vendor/deps/cli-ui/lib/cli/ui/terminal.rb +55 -0
- data/vendor/deps/cli-ui/lib/cli/ui/truncater.rb +106 -0
- data/vendor/deps/cli-ui/lib/cli/ui/version.rb +8 -0
- data/vendor/deps/cli-ui/lib/cli/ui/widgets/base.rb +46 -0
- data/vendor/deps/cli-ui/lib/cli/ui/widgets/status.rb +79 -0
- data/vendor/deps/cli-ui/lib/cli/ui/widgets.rb +89 -0
- data/vendor/deps/cli-ui/lib/cli/ui/work_queue.rb +142 -0
- data/vendor/deps/cli-ui/lib/cli/ui/wrap.rb +61 -0
- data/vendor/deps/cli-ui/lib/cli/ui.rb +359 -0
- data/vendor/deps/cli-ui/vendor/reentrant_mutex.rb +78 -0
- data/vendor/deps/debug/CONTRIBUTING.md +573 -0
- data/vendor/deps/debug/Gemfile +10 -0
- data/vendor/deps/debug/LICENSE.txt +22 -0
- data/vendor/deps/debug/README.md +996 -0
- data/vendor/deps/debug/Rakefile +57 -0
- data/vendor/deps/debug/TODO.md +23 -0
- data/vendor/deps/debug/debug.gemspec +33 -0
- data/vendor/deps/debug/exe/rdbg +53 -0
- data/vendor/deps/debug/ext/debug/Makefile +273 -0
- data/vendor/deps/debug/ext/debug/debug.c +228 -0
- data/vendor/deps/debug/ext/debug/debug_version.h +1 -0
- data/vendor/deps/debug/ext/debug/extconf.rb +27 -0
- data/vendor/deps/debug/ext/debug/iseq_collector.c +93 -0
- data/vendor/deps/debug/lib/debug/abbrev_command.rb +77 -0
- data/vendor/deps/debug/lib/debug/breakpoint.rb +556 -0
- data/vendor/deps/debug/lib/debug/client.rb +263 -0
- data/vendor/deps/debug/lib/debug/color.rb +123 -0
- data/vendor/deps/debug/lib/debug/config.rb +592 -0
- data/vendor/deps/debug/lib/debug/console.rb +224 -0
- data/vendor/deps/debug/lib/debug/dap_custom/traceInspector.rb +336 -0
- data/vendor/deps/debug/lib/debug/debug.bundle +0 -0
- data/vendor/deps/debug/lib/debug/frame_info.rb +190 -0
- data/vendor/deps/debug/lib/debug/irb_integration.rb +37 -0
- data/vendor/deps/debug/lib/debug/local.rb +115 -0
- data/vendor/deps/debug/lib/debug/open.rb +13 -0
- data/vendor/deps/debug/lib/debug/open_nonstop.rb +15 -0
- data/vendor/deps/debug/lib/debug/prelude.rb +50 -0
- data/vendor/deps/debug/lib/debug/server.rb +534 -0
- data/vendor/deps/debug/lib/debug/server_cdp.rb +1348 -0
- data/vendor/deps/debug/lib/debug/server_dap.rb +1108 -0
- data/vendor/deps/debug/lib/debug/session.rb +2667 -0
- data/vendor/deps/debug/lib/debug/source_repository.rb +150 -0
- data/vendor/deps/debug/lib/debug/start.rb +5 -0
- data/vendor/deps/debug/lib/debug/thread_client.rb +1457 -0
- data/vendor/deps/debug/lib/debug/tracer.rb +241 -0
- data/vendor/deps/debug/lib/debug/version.rb +5 -0
- data/vendor/deps/debug/lib/debug.rb +9 -0
- data/vendor/deps/debug/misc/README.md.erb +660 -0
- data/vendor/deps/listen/.github/release-drafter.yml +17 -0
- data/vendor/deps/listen/.github/workflows/development.yml +67 -0
- data/vendor/deps/listen/.github/workflows/push.yml +12 -0
- data/vendor/deps/listen/.gitignore +28 -0
- data/vendor/deps/listen/.rspec +3 -0
- data/vendor/deps/listen/.rubocop.yml +283 -0
- data/vendor/deps/listen/.yardopts +11 -0
- data/vendor/deps/listen/CHANGELOG.md +1 -0
- data/vendor/deps/listen/CONTRIBUTING.md +45 -0
- data/vendor/deps/listen/Gemfile +33 -0
- data/vendor/deps/listen/Guardfile +26 -0
- data/vendor/deps/listen/LICENSE.txt +22 -0
- data/vendor/deps/listen/README.md +490 -0
- data/vendor/deps/listen/Rakefile +154 -0
- data/vendor/deps/listen/bin/listen +11 -0
- data/vendor/deps/listen/lib/listen/adapter/base.rb +129 -0
- data/vendor/deps/listen/lib/listen/adapter/bsd.rb +104 -0
- data/vendor/deps/listen/lib/listen/adapter/config.rb +31 -0
- data/vendor/deps/listen/lib/listen/adapter/darwin.rb +77 -0
- data/vendor/deps/listen/lib/listen/adapter/linux.rb +108 -0
- data/vendor/deps/listen/lib/listen/adapter/polling.rb +40 -0
- data/vendor/deps/listen/lib/listen/adapter/windows.rb +96 -0
- data/vendor/deps/listen/lib/listen/adapter.rb +43 -0
- data/vendor/deps/listen/lib/listen/backend.rb +40 -0
- data/vendor/deps/listen/lib/listen/change.rb +69 -0
- data/vendor/deps/listen/lib/listen/cli.rb +65 -0
- data/vendor/deps/listen/lib/listen/directory.rb +93 -0
- data/vendor/deps/listen/lib/listen/error.rb +11 -0
- data/vendor/deps/listen/lib/listen/event/config.rb +39 -0
- data/vendor/deps/listen/lib/listen/event/loop.rb +92 -0
- data/vendor/deps/listen/lib/listen/event/processor.rb +128 -0
- data/vendor/deps/listen/lib/listen/event/queue.rb +52 -0
- data/vendor/deps/listen/lib/listen/file.rb +95 -0
- data/vendor/deps/listen/lib/listen/fsm.rb +131 -0
- data/vendor/deps/listen/lib/listen/listener/config.rb +41 -0
- data/vendor/deps/listen/lib/listen/listener.rb +136 -0
- data/vendor/deps/listen/lib/listen/logger.rb +65 -0
- data/vendor/deps/listen/lib/listen/monotonic_time.rb +27 -0
- data/vendor/deps/listen/lib/listen/options.rb +24 -0
- data/vendor/deps/listen/lib/listen/queue_optimizer.rb +129 -0
- data/vendor/deps/listen/lib/listen/record/entry.rb +66 -0
- data/vendor/deps/listen/lib/listen/record/symlink_detector.rb +47 -0
- data/vendor/deps/listen/lib/listen/record.rb +122 -0
- data/vendor/deps/listen/lib/listen/silencer/controller.rb +50 -0
- data/vendor/deps/listen/lib/listen/silencer.rb +106 -0
- data/vendor/deps/listen/lib/listen/thread.rb +54 -0
- data/vendor/deps/listen/lib/listen/version.rb +5 -0
- data/vendor/deps/listen/lib/listen.rb +47 -0
- data/vendor/deps/listen/listen.gemspec +40 -0
- data/vendor/deps/listen/spec/acceptance/listen_spec.rb +320 -0
- data/vendor/deps/listen/spec/lib/listen/adapter/base_spec.rb +101 -0
- data/vendor/deps/listen/spec/lib/listen/adapter/bsd_spec.rb +13 -0
- data/vendor/deps/listen/spec/lib/listen/adapter/config_spec.rb +122 -0
- data/vendor/deps/listen/spec/lib/listen/adapter/darwin_spec.rb +82 -0
- data/vendor/deps/listen/spec/lib/listen/adapter/linux_spec.rb +199 -0
- data/vendor/deps/listen/spec/lib/listen/adapter/polling_spec.rb +83 -0
- data/vendor/deps/listen/spec/lib/listen/adapter/windows_spec.rb +13 -0
- data/vendor/deps/listen/spec/lib/listen/adapter_spec.rb +69 -0
- data/vendor/deps/listen/spec/lib/listen/backend_spec.rb +82 -0
- data/vendor/deps/listen/spec/lib/listen/change_spec.rb +102 -0
- data/vendor/deps/listen/spec/lib/listen/cli_spec.rb +116 -0
- data/vendor/deps/listen/spec/lib/listen/directory_spec.rb +284 -0
- data/vendor/deps/listen/spec/lib/listen/event/config_spec.rb +33 -0
- data/vendor/deps/listen/spec/lib/listen/event/loop_spec.rb +118 -0
- data/vendor/deps/listen/spec/lib/listen/event/processor_spec.rb +250 -0
- data/vendor/deps/listen/spec/lib/listen/event/queue_spec.rb +118 -0
- data/vendor/deps/listen/spec/lib/listen/file_spec.rb +254 -0
- data/vendor/deps/listen/spec/lib/listen/fsm_spec.rb +147 -0
- data/vendor/deps/listen/spec/lib/listen/listener/config_spec.rb +29 -0
- data/vendor/deps/listen/spec/lib/listen/listener_spec.rb +321 -0
- data/vendor/deps/listen/spec/lib/listen/logger_spec.rb +212 -0
- data/vendor/deps/listen/spec/lib/listen/monotonic_time_spec.rb +58 -0
- data/vendor/deps/listen/spec/lib/listen/queue_optimizer_spec.rb +111 -0
- data/vendor/deps/listen/spec/lib/listen/record_spec.rb +424 -0
- data/vendor/deps/listen/spec/lib/listen/silencer/controller_spec.rb +97 -0
- data/vendor/deps/listen/spec/lib/listen/silencer_spec.rb +109 -0
- data/vendor/deps/listen/spec/lib/listen/thread_spec.rb +133 -0
- data/vendor/deps/listen/spec/lib/listen_spec.rb +25 -0
- data/vendor/deps/listen/spec/spec_helper.rb +49 -0
- data/vendor/deps/listen/spec/support/acceptance_helper.rb +260 -0
- data/vendor/deps/listen/spec/support/fixtures_helper.rb +32 -0
- data/vendor/deps/listen/spec/support/platform_helper.rb +17 -0
- data/vendor/deps/observer/.github/dependabot.yml +6 -0
- data/vendor/deps/observer/.github/workflows/test.yml +33 -0
- data/vendor/deps/observer/.gitignore +8 -0
- data/vendor/deps/observer/BSDL +22 -0
- data/vendor/deps/observer/COPYING +56 -0
- data/vendor/deps/observer/Gemfile +9 -0
- data/vendor/deps/observer/README.md +139 -0
- data/vendor/deps/observer/Rakefile +10 -0
- data/vendor/deps/observer/bin/console +14 -0
- data/vendor/deps/observer/bin/setup +8 -0
- data/vendor/deps/observer/lib/observer.rb +229 -0
- data/vendor/deps/observer/observer.gemspec +32 -0
- data/vendor/deps/observer/test/test_observer.rb +66 -0
- data/vendor/deps/webrick/.gitignore +9 -0
- data/vendor/deps/webrick/Gemfile +3 -0
- data/vendor/deps/webrick/LICENSE.txt +22 -0
- data/vendor/deps/webrick/README.md +61 -0
- data/vendor/deps/webrick/Rakefile +10 -0
- data/vendor/deps/webrick/lib/webrick/accesslog.rb +157 -0
- data/vendor/deps/webrick/lib/webrick/cgi.rb +313 -0
- data/vendor/deps/webrick/lib/webrick/compat.rb +36 -0
- data/vendor/deps/webrick/lib/webrick/config.rb +158 -0
- data/vendor/deps/webrick/lib/webrick/cookie.rb +172 -0
- data/vendor/deps/webrick/lib/webrick/htmlutils.rb +30 -0
- data/vendor/deps/webrick/lib/webrick/httpauth/authenticator.rb +117 -0
- data/vendor/deps/webrick/lib/webrick/httpauth/basicauth.rb +116 -0
- data/vendor/deps/webrick/lib/webrick/httpauth/digestauth.rb +395 -0
- data/vendor/deps/webrick/lib/webrick/httpauth/htdigest.rb +132 -0
- data/vendor/deps/webrick/lib/webrick/httpauth/htgroup.rb +97 -0
- data/vendor/deps/webrick/lib/webrick/httpauth/htpasswd.rb +158 -0
- data/vendor/deps/webrick/lib/webrick/httpauth/userdb.rb +53 -0
- data/vendor/deps/webrick/lib/webrick/httpauth.rb +96 -0
- data/vendor/deps/webrick/lib/webrick/httpproxy.rb +354 -0
- data/vendor/deps/webrick/lib/webrick/httprequest.rb +636 -0
- data/vendor/deps/webrick/lib/webrick/httpresponse.rb +564 -0
- data/vendor/deps/webrick/lib/webrick/https.rb +152 -0
- data/vendor/deps/webrick/lib/webrick/httpserver.rb +294 -0
- data/vendor/deps/webrick/lib/webrick/httpservlet/abstract.rb +152 -0
- data/vendor/deps/webrick/lib/webrick/httpservlet/cgi_runner.rb +47 -0
- data/vendor/deps/webrick/lib/webrick/httpservlet/cgihandler.rb +126 -0
- data/vendor/deps/webrick/lib/webrick/httpservlet/erbhandler.rb +88 -0
- data/vendor/deps/webrick/lib/webrick/httpservlet/filehandler.rb +552 -0
- data/vendor/deps/webrick/lib/webrick/httpservlet/prochandler.rb +47 -0
- data/vendor/deps/webrick/lib/webrick/httpservlet.rb +23 -0
- data/vendor/deps/webrick/lib/webrick/httpstatus.rb +194 -0
- data/vendor/deps/webrick/lib/webrick/httputils.rb +512 -0
- data/vendor/deps/webrick/lib/webrick/httpversion.rb +76 -0
- data/vendor/deps/webrick/lib/webrick/log.rb +156 -0
- data/vendor/deps/webrick/lib/webrick/server.rb +381 -0
- data/vendor/deps/webrick/lib/webrick/ssl.rb +215 -0
- data/vendor/deps/webrick/lib/webrick/utils.rb +265 -0
- data/vendor/deps/webrick/lib/webrick/version.rb +18 -0
- data/vendor/deps/webrick/lib/webrick.rb +232 -0
- data/vendor/deps/webrick/webrick.gemspec +74 -0
- metadata +412 -0
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
|
|
2
|
+
require "forwardable"
|
|
3
|
+
|
|
4
|
+
module FluidCLI
|
|
5
|
+
module Theme
|
|
6
|
+
module Presenters
|
|
7
|
+
class ThemePresenter
|
|
8
|
+
extend Forwardable
|
|
9
|
+
|
|
10
|
+
COLOR_BY_STATUS = {
|
|
11
|
+
"active" => "green",
|
|
12
|
+
"draft" => "yellow",
|
|
13
|
+
"development" => "blue",
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
attr_reader :theme
|
|
17
|
+
|
|
18
|
+
def_delegators :theme, :id, :name, :status
|
|
19
|
+
|
|
20
|
+
def initialize(theme)
|
|
21
|
+
@theme = theme
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
def to_s(mode = :long)
|
|
25
|
+
case mode
|
|
26
|
+
when :short
|
|
27
|
+
"{{bold:#{name}}}"
|
|
28
|
+
when :long
|
|
29
|
+
"{{green:##{id}}} {{bold:#{name}}}"
|
|
30
|
+
else
|
|
31
|
+
inspect
|
|
32
|
+
end
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
private
|
|
36
|
+
|
|
37
|
+
def theme_tags
|
|
38
|
+
tags = ["{{#{tag_color}:[#{status}]}}"]
|
|
39
|
+
tags << "{{cyan:[yours]}}}}" if theme.current_development?
|
|
40
|
+
tags.join(" ")
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
def tag_color
|
|
44
|
+
COLOR_BY_STATUS[status] || "italic"
|
|
45
|
+
end
|
|
46
|
+
end
|
|
47
|
+
end
|
|
48
|
+
end
|
|
49
|
+
end
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require_relative "theme_presenter"
|
|
4
|
+
|
|
5
|
+
module FluidCLI
|
|
6
|
+
module Theme
|
|
7
|
+
module Presenters
|
|
8
|
+
class ThemesPresenter
|
|
9
|
+
SUPPORTED_STATUSES = %w(active draft development)
|
|
10
|
+
|
|
11
|
+
def initialize(ctx, root)
|
|
12
|
+
@ctx = ctx
|
|
13
|
+
@root = root
|
|
14
|
+
end
|
|
15
|
+
|
|
16
|
+
def all
|
|
17
|
+
all_themes
|
|
18
|
+
.select { |theme| SUPPORTED_STATUSES.include?(theme.status) }
|
|
19
|
+
.sort_by { |theme| SUPPORTED_STATUSES.index(theme.status) }
|
|
20
|
+
.map { |theme| ThemePresenter.new(theme) }
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
private
|
|
24
|
+
|
|
25
|
+
def all_themes
|
|
26
|
+
FluidCLI::Theme::Theme.all(@ctx, root: @root)
|
|
27
|
+
end
|
|
28
|
+
end
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
end
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
require_relative "file"
|
|
3
|
+
require "pathname"
|
|
4
|
+
|
|
5
|
+
module FluidCLI
|
|
6
|
+
module Theme
|
|
7
|
+
class Root
|
|
8
|
+
attr_reader :root, :ctx
|
|
9
|
+
|
|
10
|
+
def initialize(ctx, root:)
|
|
11
|
+
@ctx = ctx
|
|
12
|
+
@root = Pathname.new(root) if root
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def static_asset_files
|
|
16
|
+
glob("assets/*", raise_on_dir: true)
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
def liquid_files
|
|
20
|
+
glob("**/*.liquid")
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
def json_files
|
|
24
|
+
glob("**/*.json")
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
def glob(pattern, raise_on_dir: false)
|
|
28
|
+
root
|
|
29
|
+
.glob(pattern)
|
|
30
|
+
.select { |path| file?(path, raise_on_dir) }
|
|
31
|
+
.map { |path| File.new(path, root) }
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
def static_asset_file?(file)
|
|
35
|
+
static_asset_files.include?(self[file])
|
|
36
|
+
end
|
|
37
|
+
|
|
38
|
+
def static_asset_paths
|
|
39
|
+
static_asset_files.map(&:relative_path)
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
def [](file)
|
|
43
|
+
case file
|
|
44
|
+
when File
|
|
45
|
+
file
|
|
46
|
+
when Pathname
|
|
47
|
+
File.new(file, root)
|
|
48
|
+
when String
|
|
49
|
+
File.new(root.join(file), root)
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
|
|
53
|
+
def file?(path, raise_on_dir = false)
|
|
54
|
+
if raise_on_dir && ::File.directory?(path)
|
|
55
|
+
@ctx.abort(@ctx.message("theme.serve.error.invalid_subdirectory", path.to_s))
|
|
56
|
+
end
|
|
57
|
+
|
|
58
|
+
::File.file?(path)
|
|
59
|
+
end
|
|
60
|
+
end
|
|
61
|
+
end
|
|
62
|
+
end
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module FluidCLI
|
|
4
|
+
module Theme
|
|
5
|
+
class Syncer
|
|
6
|
+
class Checksums
|
|
7
|
+
def initialize(theme)
|
|
8
|
+
@theme = theme
|
|
9
|
+
@checksum_by_key = {}
|
|
10
|
+
|
|
11
|
+
# Mutex used to coordinate changes in the checksums (shared accross `Syncer` threads)
|
|
12
|
+
@checksums_mutex = Mutex.new
|
|
13
|
+
end
|
|
14
|
+
|
|
15
|
+
def has?(file)
|
|
16
|
+
checksum_by_key.key?(to_key(file))
|
|
17
|
+
end
|
|
18
|
+
|
|
19
|
+
def file_has_changed?(file)
|
|
20
|
+
file.checksum != checksum_by_key[file.relative_path]
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
def delete(file)
|
|
24
|
+
checksums_mutex.synchronize do
|
|
25
|
+
checksum_by_key.delete(to_key(file))
|
|
26
|
+
end
|
|
27
|
+
end
|
|
28
|
+
|
|
29
|
+
def keys
|
|
30
|
+
checksum_by_key.keys
|
|
31
|
+
end
|
|
32
|
+
|
|
33
|
+
def [](key)
|
|
34
|
+
checksum_by_key[key]
|
|
35
|
+
end
|
|
36
|
+
|
|
37
|
+
def []=(key, value)
|
|
38
|
+
checksums_mutex.synchronize do
|
|
39
|
+
checksum_by_key[key] = value
|
|
40
|
+
end
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
# Generate .liquid asset files are reported twice in checksum:
|
|
44
|
+
# once of generated, once for .liquid. We only keep the .liquid, that's the one we have
|
|
45
|
+
# on disk.
|
|
46
|
+
def reject_duplicated_checksums!
|
|
47
|
+
checksums_mutex.synchronize do
|
|
48
|
+
checksum_by_key.reject! { |key, _| checksum_by_key.key?("#{key}.liquid") }
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
private
|
|
53
|
+
|
|
54
|
+
def to_key(file)
|
|
55
|
+
theme[file].relative_path
|
|
56
|
+
end
|
|
57
|
+
|
|
58
|
+
# Private getters only used in unit tests
|
|
59
|
+
|
|
60
|
+
attr_reader :checksum_by_key
|
|
61
|
+
attr_reader :theme
|
|
62
|
+
attr_reader :checksums_mutex
|
|
63
|
+
end
|
|
64
|
+
end
|
|
65
|
+
end
|
|
66
|
+
end
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require "forwardable"
|
|
4
|
+
|
|
5
|
+
module FluidCLI
|
|
6
|
+
module Theme
|
|
7
|
+
class Syncer
|
|
8
|
+
class Downloader
|
|
9
|
+
extend Forwardable
|
|
10
|
+
|
|
11
|
+
attr_reader :syncer, :ctx
|
|
12
|
+
|
|
13
|
+
def_delegators :syncer,
|
|
14
|
+
:ctx,
|
|
15
|
+
:checksums,
|
|
16
|
+
:get_theme_resources!,
|
|
17
|
+
:wait!
|
|
18
|
+
|
|
19
|
+
def initialize(syncer, delete, &update_progress_bar_block)
|
|
20
|
+
@syncer = syncer
|
|
21
|
+
@delete = delete
|
|
22
|
+
@update_progress_bar_block = update_progress_bar_block
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
def download!
|
|
26
|
+
get_theme_resources!
|
|
27
|
+
|
|
28
|
+
if delete_local_files?
|
|
29
|
+
to_be_deleted.each { |file| delete(file) }
|
|
30
|
+
end
|
|
31
|
+
wait!(&@update_progress_bar_block)
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
private
|
|
35
|
+
|
|
36
|
+
def delete(file)
|
|
37
|
+
ctx.debug("[#{self.class}] rm #{file.relative_path}")
|
|
38
|
+
file.delete
|
|
39
|
+
end
|
|
40
|
+
|
|
41
|
+
def delete_local_files?
|
|
42
|
+
@delete
|
|
43
|
+
end
|
|
44
|
+
|
|
45
|
+
def to_be_deleted
|
|
46
|
+
@to_be_deleted ||= syncer
|
|
47
|
+
.theme
|
|
48
|
+
.theme_files
|
|
49
|
+
.reject { |file| checksums.has?(file) }.uniq
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
end
|
|
53
|
+
end
|
|
54
|
+
end
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module FluidCLI
|
|
4
|
+
module Theme
|
|
5
|
+
class Syncer
|
|
6
|
+
##
|
|
7
|
+
# FluidCLI::Theme::Syncer::ErrorReporter allows delaying log of errors,
|
|
8
|
+
# mainly to not break the progress bar.
|
|
9
|
+
#
|
|
10
|
+
class ErrorReporter
|
|
11
|
+
attr_reader :ctx, :delayed_errors
|
|
12
|
+
|
|
13
|
+
def initialize(ctx)
|
|
14
|
+
@ctx = ctx
|
|
15
|
+
@has_any_error = false
|
|
16
|
+
@delay_errors = false
|
|
17
|
+
@delayed_errors = []
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
def disable!
|
|
21
|
+
@delay_errors = true
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
def enable!
|
|
25
|
+
@delay_errors = false
|
|
26
|
+
@delayed_errors.each { |error| report(error) }
|
|
27
|
+
@delayed_errors.clear
|
|
28
|
+
end
|
|
29
|
+
|
|
30
|
+
def report(error_message)
|
|
31
|
+
if @delay_errors
|
|
32
|
+
@delayed_errors << error_message
|
|
33
|
+
else
|
|
34
|
+
@has_any_error = true
|
|
35
|
+
@ctx.error(error_message)
|
|
36
|
+
end
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
def has_any_error?
|
|
40
|
+
@has_any_error
|
|
41
|
+
end
|
|
42
|
+
end
|
|
43
|
+
end
|
|
44
|
+
end
|
|
45
|
+
end
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require "tempfile"
|
|
4
|
+
|
|
5
|
+
module FluidCLI
|
|
6
|
+
module Theme
|
|
7
|
+
class Syncer
|
|
8
|
+
class Merger
|
|
9
|
+
class << self
|
|
10
|
+
##
|
|
11
|
+
# Merge `theme_file` with the `new_content` by relying on the union merge
|
|
12
|
+
#
|
|
13
|
+
def union_merge(theme_file, new_content)
|
|
14
|
+
git_merge(theme_file, new_content, ["--union", "-p"])
|
|
15
|
+
end
|
|
16
|
+
|
|
17
|
+
private
|
|
18
|
+
|
|
19
|
+
##
|
|
20
|
+
# Merge theme file (`FluidCLI::Theme::File`) with a new content (String),
|
|
21
|
+
# by creating a temporary file based on the `new_content`.
|
|
22
|
+
#
|
|
23
|
+
def git_merge(theme_file, new_content, opts)
|
|
24
|
+
remote_file = create_tmp_file(tmp_file_name(theme_file), new_content)
|
|
25
|
+
empty_file = create_tmp_file("empty")
|
|
26
|
+
|
|
27
|
+
FluidCLI::Git.merge_file(
|
|
28
|
+
theme_file.absolute_path,
|
|
29
|
+
empty_file.path,
|
|
30
|
+
remote_file.path,
|
|
31
|
+
opts
|
|
32
|
+
)
|
|
33
|
+
ensure
|
|
34
|
+
# Remove temporary files on Windows as well
|
|
35
|
+
remote_file.close!
|
|
36
|
+
empty_file.close!
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
def create_tmp_file(basename, content = "")
|
|
40
|
+
tmp_file = Tempfile.new(basename)
|
|
41
|
+
tmp_file.write(content)
|
|
42
|
+
tmp_file.close # Make it ready to merge
|
|
43
|
+
tmp_file
|
|
44
|
+
end
|
|
45
|
+
|
|
46
|
+
def tmp_file_name(ref_file)
|
|
47
|
+
"fluid-cli-merge-#{ref_file.name(".*")}"
|
|
48
|
+
end
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
end
|
|
52
|
+
end
|
|
53
|
+
end
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module FluidCLI
|
|
4
|
+
module Theme
|
|
5
|
+
class Syncer
|
|
6
|
+
class Operation
|
|
7
|
+
attr_accessor :method, :file, :options
|
|
8
|
+
|
|
9
|
+
COLOR_BY_STATUS = {
|
|
10
|
+
error: :red,
|
|
11
|
+
synced: :green,
|
|
12
|
+
warning: :yellow,
|
|
13
|
+
fixed: :cyan,
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
def initialize(ctx, method, file, options = {})
|
|
17
|
+
@ctx = ctx
|
|
18
|
+
@method = method
|
|
19
|
+
@file = file
|
|
20
|
+
@options = options
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
def to_s
|
|
24
|
+
"#{method} #{file_path}"
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
def as_error_message
|
|
28
|
+
as_message_with(status: :error)
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
def as_synced_message(color: :green)
|
|
32
|
+
as_message_with(status: :synced, color: color)
|
|
33
|
+
end
|
|
34
|
+
|
|
35
|
+
def as_fix_message
|
|
36
|
+
as_message_with(status: :fixed)
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
def file_path
|
|
40
|
+
file&.relative_path
|
|
41
|
+
end
|
|
42
|
+
|
|
43
|
+
private
|
|
44
|
+
|
|
45
|
+
def as_message_with(status:, color: nil)
|
|
46
|
+
color ||= COLOR_BY_STATUS[status]
|
|
47
|
+
text = "#{status.to_s.capitalize}"
|
|
48
|
+
|
|
49
|
+
"#{timestamp} {{#{color}:#{text}}} {{>}} {{blue:#{self}}}"
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
def timestamp
|
|
53
|
+
Time.now.strftime("%T")
|
|
54
|
+
end
|
|
55
|
+
end
|
|
56
|
+
end
|
|
57
|
+
end
|
|
58
|
+
end
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module FluidCLI
|
|
4
|
+
module Theme
|
|
5
|
+
class Syncer
|
|
6
|
+
##
|
|
7
|
+
# FluidCLI::Theme::Syncer::StdReporter allows disabling/enabling
|
|
8
|
+
# messages reported in the standard error output (FluidCLI::Context#puts).
|
|
9
|
+
#
|
|
10
|
+
class StandardReporter
|
|
11
|
+
attr_reader :ctx
|
|
12
|
+
|
|
13
|
+
def initialize(ctx)
|
|
14
|
+
@enabled = true
|
|
15
|
+
@ctx = ctx
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
def disable!
|
|
19
|
+
@enabled = false
|
|
20
|
+
end
|
|
21
|
+
|
|
22
|
+
def enable!
|
|
23
|
+
@enabled = true
|
|
24
|
+
end
|
|
25
|
+
|
|
26
|
+
def report(message)
|
|
27
|
+
ctx.error(message) if @enabled
|
|
28
|
+
end
|
|
29
|
+
end
|
|
30
|
+
end
|
|
31
|
+
end
|
|
32
|
+
end
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module FluidCLI
|
|
4
|
+
module Theme
|
|
5
|
+
class Syncer
|
|
6
|
+
class UnsupportedScriptWarning
|
|
7
|
+
attr_reader :ctx
|
|
8
|
+
|
|
9
|
+
def initialize(ctx, file)
|
|
10
|
+
@ctx = ctx
|
|
11
|
+
@file = file
|
|
12
|
+
end
|
|
13
|
+
|
|
14
|
+
def to_s
|
|
15
|
+
"\n\n#{occurrences} #{long_text}"
|
|
16
|
+
end
|
|
17
|
+
|
|
18
|
+
private
|
|
19
|
+
|
|
20
|
+
def occurrences
|
|
21
|
+
warnings.map { |w| occurrence(w) }.join("\n")
|
|
22
|
+
end
|
|
23
|
+
|
|
24
|
+
def occurrence(warning)
|
|
25
|
+
line_number = "{{blue: #{warning.line} |}}"
|
|
26
|
+
pointer = pointer_message(warning)
|
|
27
|
+
|
|
28
|
+
<<~OCCURRENCE
|
|
29
|
+
#{line_number} #{warning.line_content}
|
|
30
|
+
#{pointer}
|
|
31
|
+
OCCURRENCE
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
def long_text
|
|
35
|
+
lines_and_columns = warnings.map do |warning|
|
|
36
|
+
message("line_and_column", warning.line, warning.column)
|
|
37
|
+
end
|
|
38
|
+
|
|
39
|
+
message("unsupported_script_text", lines_and_columns.join)
|
|
40
|
+
.split("\n")
|
|
41
|
+
.reduce("") do |text, line|
|
|
42
|
+
# Add indentation in the long text to improve readability
|
|
43
|
+
line = " #{line}"
|
|
44
|
+
|
|
45
|
+
# Inline yellow (otherwise `CLI::UI::Frame` breaks multiline formatting)
|
|
46
|
+
line = "{{yellow:#{line}}}"
|
|
47
|
+
|
|
48
|
+
"#{text}#{line}\n"
|
|
49
|
+
end
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
def pointer_message(warning)
|
|
53
|
+
padding = warning.column + warning.line.to_s.size + 2
|
|
54
|
+
text = message("unsupported_script")
|
|
55
|
+
|
|
56
|
+
"{{yellow:#{" " * padding} ^ {{bold:#{text}}}}}"
|
|
57
|
+
end
|
|
58
|
+
|
|
59
|
+
def message(*args)
|
|
60
|
+
key = args.shift
|
|
61
|
+
@ctx.message("theme.serve.syncer.warnings.#{key}", *args)
|
|
62
|
+
end
|
|
63
|
+
|
|
64
|
+
def warnings
|
|
65
|
+
@warnings ||= @file.warnings.map { |w| Warning.new(@file, w) }
|
|
66
|
+
end
|
|
67
|
+
|
|
68
|
+
class Warning
|
|
69
|
+
attr_reader :line, :column
|
|
70
|
+
|
|
71
|
+
def initialize(file, warning_hash)
|
|
72
|
+
@file = file
|
|
73
|
+
@line = warning_hash["line"].to_i
|
|
74
|
+
@column = warning_hash["column"].to_i
|
|
75
|
+
end
|
|
76
|
+
|
|
77
|
+
def line_content
|
|
78
|
+
file_lines[line - 1]
|
|
79
|
+
end
|
|
80
|
+
|
|
81
|
+
private
|
|
82
|
+
|
|
83
|
+
def file_lines
|
|
84
|
+
@file_lines ||= @file.read.split("\n")
|
|
85
|
+
end
|
|
86
|
+
end
|
|
87
|
+
end
|
|
88
|
+
end
|
|
89
|
+
end
|
|
90
|
+
end
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
require_relative "apply_to_all_form"
|
|
4
|
+
|
|
5
|
+
module FluidCLI
|
|
6
|
+
module Theme
|
|
7
|
+
class Syncer
|
|
8
|
+
class Uploader
|
|
9
|
+
module Forms
|
|
10
|
+
class ApplyToAll
|
|
11
|
+
attr_reader :value
|
|
12
|
+
|
|
13
|
+
def initialize(ctx, number_of_files)
|
|
14
|
+
@ctx = ctx
|
|
15
|
+
@number_of_files = number_of_files
|
|
16
|
+
@value = nil
|
|
17
|
+
@apply = nil
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
def apply?(value)
|
|
21
|
+
return unless @number_of_files > 1
|
|
22
|
+
|
|
23
|
+
if @apply.nil?
|
|
24
|
+
@apply = ask.apply?
|
|
25
|
+
@value = value if @apply
|
|
26
|
+
end
|
|
27
|
+
|
|
28
|
+
@apply
|
|
29
|
+
end
|
|
30
|
+
|
|
31
|
+
private
|
|
32
|
+
|
|
33
|
+
def ask
|
|
34
|
+
ApplyToAllForm.ask(@ctx, [], number_of_files: @number_of_files)
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
end
|
|
38
|
+
end
|
|
39
|
+
end
|
|
40
|
+
end
|
|
41
|
+
end
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module FluidCLI
|
|
4
|
+
module Theme
|
|
5
|
+
class Syncer
|
|
6
|
+
class Uploader
|
|
7
|
+
module Forms
|
|
8
|
+
class ApplyToAllForm < FluidCLI::Form
|
|
9
|
+
attr_accessor :apply
|
|
10
|
+
flag_arguments :number_of_files
|
|
11
|
+
|
|
12
|
+
def ask
|
|
13
|
+
title = message("title", number_of_files - 1)
|
|
14
|
+
|
|
15
|
+
self.apply = CLI::UI::Prompt.ask(title, allow_empty: false) do |handler|
|
|
16
|
+
handler.option(message("yes")) { true }
|
|
17
|
+
handler.option(message("no")) { false }
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
self
|
|
21
|
+
end
|
|
22
|
+
|
|
23
|
+
def apply?
|
|
24
|
+
apply
|
|
25
|
+
end
|
|
26
|
+
|
|
27
|
+
private
|
|
28
|
+
|
|
29
|
+
def message(key, *params)
|
|
30
|
+
ctx.message("theme.serve.syncer.forms.apply_to_all.#{key}", *params)
|
|
31
|
+
end
|
|
32
|
+
end
|
|
33
|
+
end
|
|
34
|
+
end
|
|
35
|
+
end
|
|
36
|
+
end
|
|
37
|
+
end
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
# frozen_string_literal: true
|
|
2
|
+
|
|
3
|
+
module FluidCLI
|
|
4
|
+
module Theme
|
|
5
|
+
class Syncer
|
|
6
|
+
class Uploader
|
|
7
|
+
module Forms
|
|
8
|
+
class BaseStrategyForm < FluidCLI::Form
|
|
9
|
+
attr_accessor :strategy
|
|
10
|
+
|
|
11
|
+
def ask
|
|
12
|
+
ctx.puts(title_context(file))
|
|
13
|
+
|
|
14
|
+
self.strategy = CLI::UI::Prompt.ask(title_question, allow_empty: false) do |handler|
|
|
15
|
+
strategies.each do |strategy|
|
|
16
|
+
handler.option(as_text(strategy)) { strategy }
|
|
17
|
+
end
|
|
18
|
+
end
|
|
19
|
+
|
|
20
|
+
exit_cli if self.strategy == :exit
|
|
21
|
+
|
|
22
|
+
self
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
protected
|
|
26
|
+
|
|
27
|
+
##
|
|
28
|
+
# List of strategies that populate the form options
|
|
29
|
+
#
|
|
30
|
+
def strategies
|
|
31
|
+
raise "`#{self.class.name}#strategies' must be defined"
|
|
32
|
+
end
|
|
33
|
+
|
|
34
|
+
##
|
|
35
|
+
# Message prefix for the form title and options (strategies).
|
|
36
|
+
# See the methods `title` and `as_text`
|
|
37
|
+
#
|
|
38
|
+
def prefix
|
|
39
|
+
raise "`#{self.class.name}#prefix' must be defined"
|
|
40
|
+
end
|
|
41
|
+
|
|
42
|
+
private
|
|
43
|
+
|
|
44
|
+
def exit_cli
|
|
45
|
+
exit(0)
|
|
46
|
+
end
|
|
47
|
+
|
|
48
|
+
def title_context(file)
|
|
49
|
+
ctx.message("#{prefix}.title_context", file.relative_path)
|
|
50
|
+
end
|
|
51
|
+
|
|
52
|
+
def title_question
|
|
53
|
+
ctx.message("#{prefix}.title_question")
|
|
54
|
+
end
|
|
55
|
+
|
|
56
|
+
def as_text(strategy)
|
|
57
|
+
ctx.message("#{prefix}.#{strategy}")
|
|
58
|
+
end
|
|
59
|
+
end
|
|
60
|
+
end
|
|
61
|
+
end
|
|
62
|
+
end
|
|
63
|
+
end
|
|
64
|
+
end
|