Class: RubyCms::AppWiring
- Inherits:
-
Object
- Object
- RubyCms::AppWiring
- Defined in:
- lib/ruby_cms/app_wiring.rb
Overview
Wires the host app's config/application.rb so the copied runtime in lib/ruby_cms loads at boot:
* `require_relative "../lib/ruby_cms"` right after Bundler.require (defines
RubyCms.configure et al., which config/initializers/admin.rb depends on)
* adds `ruby_cms` to `config.autoload_lib(ignore: ...)` so Zeitwerk leaves the
manually-required tree alone.
Idempotent: safe to run on every install/add.
Constant Summary collapse
- REQUIRE_LINE =
'require_relative "../lib/ruby_cms"'
Instance Method Summary collapse
-
#apply! ⇒ Object
rubocop:disable Naming/PredicateMethod.
-
#initialize(app_root:) ⇒ AppWiring
constructor
A new instance of AppWiring.
Constructor Details
#initialize(app_root:) ⇒ AppWiring
Returns a new instance of AppWiring.
16 17 18 |
# File 'lib/ruby_cms/app_wiring.rb', line 16 def initialize(app_root:) @path = Pathname.new(app_root).join("config/application.rb") end |
Instance Method Details
#apply! ⇒ Object
rubocop:disable Naming/PredicateMethod
20 21 22 23 24 25 26 27 28 29 |
# File 'lib/ruby_cms/app_wiring.rb', line 20 def apply! # rubocop:disable Naming/PredicateMethod return false unless @path.exist? content = @path.read updated = add_autoload_ignore(add_require(content)) return false if updated == content @path.write(updated) true end |