From 776206b3e7a1374e8517431c9f63745079b3b1bf Mon Sep 17 00:00:00 2001 From: nobu Date: Sat, 7 Feb 2004 10:56:16 +0000 Subject: * lib/irb/init.rb (IRB.rc_files): yield possible rc file names. * lib/irb/input-method.rb (IRB::ReadlineInputMethod::initialize): load and save history automatically. [ruby-core:02352] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@5638 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- lib/irb/init.rb | 17 ++++++++++------- lib/irb/input-method.rb | 37 +++++++++++++++++++++++++++++++++++++ 2 files changed, 47 insertions(+), 7 deletions(-) (limited to 'lib/irb') diff --git a/lib/irb/init.rb b/lib/irb/init.rb index 9fd86e94a2..1df2926fa5 100644 --- a/lib/irb/init.rb +++ b/lib/irb/init.rb @@ -180,17 +180,20 @@ module IRB end end + # enumerate possible rc files + def IRB.rc_files(rc) + yield File.expand_path("~/.irb#{rc}") if ENV.key?("HOME") + yield ".irb#{rc}" + yield "irb#{rc.sub(/\A_?/, '.')}" + yield "_irb#{rc}" + yield "$irb#{rc}" + end + # running config def IRB.run_config if @CONF[:RC] - rcs = [] - rcs.push File.expand_path("~/.irbrc") if ENV.key?("HOME") - rcs.push ".irbrc" - rcs.push "irb.rc" - rcs.push "_irbrc" - rcs.push "$irbrc" catch(:EXIT) do - for rc in rcs + rc_files("rc") do |rc| begin load rc throw :EXIT diff --git a/lib/irb/input-method.rb b/lib/irb/input-method.rb index ec834b17bc..d1fc83a975 100644 --- a/lib/irb/input-method.rb +++ b/lib/irb/input-method.rb @@ -85,12 +85,49 @@ module IRB require "readline" class ReadlineInputMethod < InputMethod include Readline + + def ReadlineInputMethod.create_finalizer(hist, file) + proc do + if num = IRB.conf[:SAVE_HISTORY] and (num = num.to_i) > 0 + if hf = IRB.conf[:HISTORY_FILE] + file = File.expand_path(hf) + end + if file + open(file, 'w' ) do |f| + hist = hist.to_a + f.puts(hist[-num..-1] || hist) + end + end + end + end + end + def initialize super @line_no = 0 @line = [] @eof = false + + loader = proc {|f| f.each {|l| HISTORY << l.chomp}} + if hist = IRB.conf[:HISTORY_FILE] + hist = File.expand_path(hist) + begin + open(hist, &loader) + rescue + end + else + IRB.rc_files("_history") do |hist| + begin + open(hist, &loader) + rescue + hist = nil + else + break + end + end + end + ObjectSpace.define_finalizer(self, ReadlineInputMethod.create_finalizer(HISTORY, hist)) end def gets -- cgit v1.2.3