summaryrefslogtreecommitdiff
path: root/lib/irb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/irb')
-rw-r--r--lib/irb/command.rb40
-rw-r--r--lib/irb/context.rb12
-rw-r--r--lib/irb/ext/use-loader.rb4
3 files changed, 14 insertions, 42 deletions
diff --git a/lib/irb/command.rb b/lib/irb/command.rb
index c84474e633..83ec3b1b43 100644
--- a/lib/irb/command.rb
+++ b/lib/irb/command.rb
@@ -315,44 +315,4 @@ module IRB # :nodoc:
install_extend_commands
end
-
- # Extends methods for the Context module
- module ContextExtender
- CE = ContextExtender # :nodoc:
-
- @EXTEND_COMMANDS = [
- [:eval_history=, "ext/eval_history.rb"],
- [:use_loader=, "ext/use-loader.rb"],
- ]
-
- # Installs the default context extensions as irb commands:
- #
- # Context#eval_history=:: +irb/ext/history.rb+
- # Context#use_tracer=:: +irb/ext/tracer.rb+
- # Context#use_loader=:: +irb/ext/use-loader.rb+
- def self.install_extend_commands
- for args in @EXTEND_COMMANDS
- def_extend_command(*args)
- end
- end
-
- # Evaluate the given +command+ from the given +load_file+ on the Context
- # module.
- #
- # Will also define any given +aliases+ for the method.
- def self.def_extend_command(cmd_name, load_file, *aliases)
- line = __LINE__; Context.module_eval %[
- def #{cmd_name}(*opts, &b)
- Context.module_eval {remove_method(:#{cmd_name})}
- require_relative "#{load_file}"
- __send__ :#{cmd_name}, *opts, &b
- end
- for ali in aliases
- alias_method ali, cmd_name
- end
- ], __FILE__, line
- end
-
- CE.install_extend_commands
- end
end
diff --git a/lib/irb/context.rb b/lib/irb/context.rb
index e50958978f..8eef3dff46 100644
--- a/lib/irb/context.rb
+++ b/lib/irb/context.rb
@@ -166,6 +166,18 @@ module IRB
IRB.conf[:USE_TRACER] = val
end
+ def eval_history=(val)
+ self.class.remove_method(__method__)
+ require_relative "ext/eval_history"
+ __send__(__method__, val)
+ end
+
+ def use_loader=(val)
+ self.class.remove_method(__method__)
+ require_relative "ext/use-loader"
+ __send__(__method__, val)
+ end
+
private def build_completor
completor_type = IRB.conf[:COMPLETOR]
case completor_type
diff --git a/lib/irb/ext/use-loader.rb b/lib/irb/ext/use-loader.rb
index c5ecbe2847..b22e6d2bf4 100644
--- a/lib/irb/ext/use-loader.rb
+++ b/lib/irb/ext/use-loader.rb
@@ -4,7 +4,7 @@
# by Keiju ISHITSUKA([email protected])
#
-require_relative "../cmd/load"
+require_relative "../command/load"
require_relative "loader"
class Object
@@ -49,7 +49,7 @@ module IRB
if IRB.conf[:USE_LOADER] != opt
IRB.conf[:USE_LOADER] = opt
if opt
- if !$".include?("irb/cmd/load")
+ if !$".include?("irb/command/load")
end
(class<<@workspace.main;self;end).instance_eval {
alias_method :load, :irb_load