Skip to content

Commit

Permalink
* lib/irb/locale.rb (IRB::Locale#search_file): make it possible
Browse files Browse the repository at this point in the history
  to load a localization from a gem.
  (IRB::Locale#lc_path): obsoleted because of the change of #search_file
  (IRB::Locale#each_localized_path): new private method, based on lc_path
  (IRB::Locale#find): follows the change of #search_file.
  (IRB::Locale#load): removed duplicate with #find.

git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@30448 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
yugui committed Jan 5, 2011
1 parent 7ba4caf commit 09aefc4
Show file tree
Hide file tree
Showing 2 changed files with 40 additions and 42 deletions.
9 changes: 9 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,12 @@
Sat Jan 1 17:02:50 2011 Yuki Sonoda (Yugui) <[email protected]>

* lib/irb/locale.rb (IRB::Locale#search_file): make it possible
to load a localization from a gem.
(IRB::Locale#lc_path): obsoleted because of the change of #search_file
(IRB::Locale#each_localized_path): new private method, based on lc_path
(IRB::Locale#find): follows the change of #search_file.
(IRB::Locale#load): removed duplicate with #find.

Sat Jan 1 11:44:42 2011 Tanaka Akira <[email protected]>

* strftime.c: parenthesize macro arguments.
Expand Down
73 changes: 31 additions & 42 deletions lib/irb/locale.rb
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ def initialize(locale = nil)
def String(mes)
mes = super(mes)
if @encoding
mes.encode(@encoding)
mes.encode(@encoding, undef: :replace)
else
mes
end
Expand Down Expand Up @@ -111,22 +111,27 @@ def require(file, priv = nil)
alias toplevel_load load

def load(file, priv=nil)
found = find(file)
if found
return real_load(found, priv)
else
raise LoadError, "No such file to load -- #{file}"
end
end

def find(file , paths = $:)
dir = File.dirname(file)
dir = "" if dir == "."
base = File.basename(file)

if dir[0] == ?/ #/
lc_path = search_file(dir, base)
return real_load(lc_path, priv) if lc_path
end

for path in $:
lc_path = search_file(path + "/" + dir, base)
return real_load(lc_path, priv) if lc_path
if dir.start_with?('/')
return each_localized_path(dir, base).find{|full_path| File.readable? full_path}
else
return search_file(paths, dir, base)
end
raise LoadError, "No such file to load -- #{file}"
end

private
def real_load(path, priv)
src = MagicFile.open(path){|f| f.read}
if priv
Expand All @@ -135,41 +140,30 @@ def real_load(path, priv)
eval(src, TOPLEVEL_BINDING, path)
end
end
private :real_load

def find(file , paths = $:)
dir = File.dirname(file)
dir = "" if dir == "."
base = File.basename(file)
if dir =~ /^\//
return lc_path = search_file(dir, base)
else
for path in $:
if lc_path = search_file(path + "/" + dir, base)
return lc_path
end
end
# @param paths load paths in which IRB find a localized file.
# @param dir directory
# @param file basename to be localized
#
# typically, for the parameters and a <path> in paths, it searches
# <path>/<dir>/<locale>/<file>
def search_file(lib_paths, dir, file)
each_localized_path(dir, file) do |lc_path|
lib_paths.each do |libpath|
full_path = File.join(libpath, lc_path)
return full_path if File.readable?(full_path)
end
redo if Gem.try_activate(lc_path)
end
nil
end

def search_file(path, file)
def each_localized_path(dir, file)
return enum_for(:each_localized_path) unless block_given?
each_sublocale do |lc|
full_path = path + lc_path(file, lc)
return full_path if File.exist?(full_path)
end
nil
end
private :search_file

def lc_path(file = "", lc = @locale)
if lc.nil?
LOCALE_DIR + file
else
LOCALE_DIR + @lang + "/" + file
yield lc.nil? ? File.join(dir, LOCALE_DIR, file) : File.join(dir, LOCALE_DIR, lc, file)
end
end
private :lc_path

def each_sublocale
if @lang
Expand All @@ -186,10 +180,5 @@ def each_sublocale
end
yield nil
end
private :each_sublocale
end
end




0 comments on commit 09aefc4

Please sign in to comment.