diff options
author | Stan Lo <[email protected]> | 2023-12-18 14:36:55 +0000 |
---|---|---|
committer | Hiroshi SHIBATA <[email protected]> | 2023-12-20 19:11:01 +0900 |
commit | 2793a30b69177e7c7bbf124ccfca7b4f4216ca84 (patch) | |
tree | e3482667fc4e646e69b1b9ca698249dee9825bdd /lib | |
parent | 7c2d8198625ca2e38835ad06ab47b4ea3afbc34b (diff) |
[ruby/irb] Warn users about errors in loading RC files
(https://github.com/ruby/irb/pull/817)
1. Because `IRB.rc_file` always generates an rc file name, even if the
file doesn't exist, we should check the file exists before trying to
load it.
2. If any type of errors occur while loading the rc file, we should
warn the user about it.
https://github.com/ruby/irb/commit/37ffdc6b19
Diffstat (limited to 'lib')
-rw-r--r-- | lib/irb/init.rb | 18 |
1 files changed, 8 insertions, 10 deletions
diff --git a/lib/irb/init.rb b/lib/irb/init.rb index d9676fd9a5..66e7b61468 100644 --- a/lib/irb/init.rb +++ b/lib/irb/init.rb @@ -389,18 +389,16 @@ module IRB # :nodoc: $LOAD_PATH.unshift(*load_path) end - # running config + # Run the config file def IRB.run_config if @CONF[:RC] begin - load rc_file - rescue LoadError, Errno::ENOENT - rescue # StandardError, ScriptError - print "load error: #{rc_file}\n" - print $!.class, ": ", $!, "\n" - for err in $@[0, [email protected] - 2] - print "\t", err, "\n" - end + file = rc_file + # Because rc_file always returns `HOME/.irbrc` even if no rc file is present, we can't warn users about missing rc files. + # Otherwise, it'd be very noisy. + load file if File.exist?(file) + rescue StandardError, ScriptError => e + warn "Error loading RC file '#{file}':\n#{e.full_message(highlight: false)}" end end end @@ -418,7 +416,7 @@ module IRB # :nodoc: end case rc_file = @CONF[:RC_NAME_GENERATOR].call(ext) when String - return rc_file + rc_file else fail IllegalRCNameGenerator end |