Class: Vagrant::Action::Builtin::Call
- Inherits:
-
Object
- Object
- Vagrant::Action::Builtin::Call
- Defined in:
- lib/vagrant/action/builtin/call.rb
Overview
This middleware class allows a sort of "conditional" run within a single middlware sequence. It takes another middleware runnable, runs it with the same environment, then yields the resulting env to a block, allowing that block to determine the next course of action in the middleware sequence.
The first argument to this middleware sequence is anywhere middleware
runnable, whether it be a class, lambda, or something else that
responds to call
. This middleware runnable is run with the same
environment as this class.
After running, Call takes the environment and yields it to a block given to initialize the class, along with an instance of Vagrant::Action::Builder. The result is used to build up a new sequence on the given builder. This builder is then run.
Instance Method Summary collapse
- #call(env) ⇒ Object
-
#initialize(app, env, callable, *callable_args) {|result, builder| ... } ⇒ Call
constructor
For documentation, read the description of the Call class.
- #recover(env) ⇒ Object
Constructor Details
#initialize(app, env, callable, *callable_args) {|result, builder| ... } ⇒ Call
For documentation, read the description of the Vagrant::Action::Builtin::Call class.
29 30 31 32 33 34 35 36 37 |
# File 'lib/vagrant/action/builtin/call.rb', line 29 def initialize(app, env, callable, *callable_args, &block) raise ArgumentError, "A block must be given to Call" if !block @app = app @callable = callable @callable_args = callable_args @block = block @child_app = nil end |
Instance Method Details
#call(env) ⇒ Object
39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 |
# File 'lib/vagrant/action/builtin/call.rb', line 39 def call(env) runner = Runner.new # Build the callable that we'll run callable = Builder.build(@callable, *@callable_args) # Run our callable with our environment new_env = runner.run(callable, env) # Build our new builder based on the result builder = Builder.new @block.call(new_env, builder) # Append our own app onto the builder so we slide the new # stack into our own chain... builder.use @app @child_app = builder.to_app(new_env) final_env = runner.run(@child_app, new_env) # Merge the environment into our original environment env.merge!(final_env) end |
#recover(env) ⇒ Object
62 63 64 65 |
# File 'lib/vagrant/action/builtin/call.rb', line 62 def recover(env) # Call back into our compiled application and recover it. @child_app.recover(env) if @child_app end |