Class: WebConsole::Session
- Inherits:
-
Object
- Object
- WebConsole::Session
- Defined in:
- lib/web_console/session.rb
Overview
A session lets you persist an Evaluator
instance in memory associated with multiple bindings.
Each newly created session is persisted into memory and you can find it later by its id
.
A session may be associated with multiple bindings. This is used by the error pages only, as currently, this is the only client that needs to do that.
Constant Summary collapse
- @@inmemory_storage =
{}
Instance Attribute Summary collapse
-
#id ⇒ Object
readonly
An unique identifier for every REPL.
Class Method Summary collapse
-
.find(id) ⇒ Object
Finds a persisted session in memory by its id.
-
.from(storage) ⇒ Object
Create a Session from an binding or exception in a storage.
Instance Method Summary collapse
-
#context(objpath) ⇒ Object
Returns context of the current binding.
-
#eval(input) ⇒ Object
Evaluate
input
on the current Evaluator associated binding. -
#initialize(bindings) ⇒ Session
constructor
A new instance of Session.
-
#switch_binding_to(index) ⇒ Object
Switches the current binding to the one at specified
index
.
Constructor Details
Instance Attribute Details
#id ⇒ Object (readonly)
An unique identifier for every REPL.
43 44 45 |
# File 'lib/web_console/session.rb', line 43 def id @id end |
Class Method Details
.find(id) ⇒ Object
Finds a persisted session in memory by its id.
Returns a persisted session if found in memory. Raises NotFound error unless found in memory.
22 23 24 |
# File 'lib/web_console/session.rb', line 22 def find(id) inmemory_storage[id] end |
.from(storage) ⇒ Object
Create a Session from an binding or exception in a storage.
The storage is expected to respond to #[]. The binding is expected in :__web_console_binding and the exception in :__web_console_exception.
Can return nil, if no binding or exception have been preserved in the storage.
33 34 35 36 37 38 39 |
# File 'lib/web_console/session.rb', line 33 def from(storage) if exc = storage[:__web_console_exception] new(ExceptionMapper.new(exc)) elsif binding = storage[:__web_console_binding] new([binding]) end end |
Instance Method Details
#context(objpath) ⇒ Object
Returns context of the current binding
68 69 70 |
# File 'lib/web_console/session.rb', line 68 def context(objpath) Context.new(@current_binding).extract(objpath) end |
#eval(input) ⇒ Object
Evaluate input
on the current Evaluator associated binding.
Returns a string of the Evaluator output.
56 57 58 |
# File 'lib/web_console/session.rb', line 56 def eval(input) @evaluator.eval(input) end |