summaryrefslogtreecommitdiff
path: root/lib/irb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/irb')
-rw-r--r--lib/irb/completion.rb49
1 files changed, 31 insertions, 18 deletions
diff --git a/lib/irb/completion.rb b/lib/irb/completion.rb
index e059bc4055..ee5cf69409 100644
--- a/lib/irb/completion.rb
+++ b/lib/irb/completion.rb
@@ -91,60 +91,73 @@ module IRB
rescue Exception
candidates = []
end
- candidates.grep(/^#{message}/).collect{|e| receiver + "::" + e}
+ select_message(receiver, message, candidates, "::")
- when /^(:[^:.]+)\.([^.]*)$/
+ when /^(:[^:.]+)(\.|::)([^.]*)$/
# Symbol
receiver = $1
- message = Regexp.quote($2)
+ sep = $2
+ message = Regexp.quote($3)
candidates = Symbol.instance_methods.collect{|m| m.to_s}
- select_message(receiver, message, candidates)
+ select_message(receiver, message, candidates, sep)
- when /^(-?(0[dbo])?[0-9_]+(\.[0-9_]+)?([eE]-?[0-9]+)?)\.([^.]*)$/
+ when /^(-?(0[dbo])?[0-9_]+(\.[0-9_]+)?([eE]-?[0-9]+)?)(\.|::)([^.]*)$/
# Numeric
receiver = $1
- message = Regexp.quote($5)
+ sep = $5
+ message = Regexp.quote($6)
begin
candidates = eval(receiver, bind).methods.collect{|m| m.to_s}
rescue Exception
candidates = []
end
- select_message(receiver, message, candidates)
+ select_message(receiver, message, candidates, sep)
- when /^(-?0x[0-9a-fA-F_]+)\.([^.]*)$/
+ when /^(-?0x[0-9a-fA-F_]+)(\.|::)([^.]*)$/
# Numeric(0xFFFF)
receiver = $1
- message = Regexp.quote($2)
+ sep = $2
+ message = Regexp.quote($3)
begin
candidates = eval(receiver, bind).methods.collect{|m| m.to_s}
rescue Exception
candidates = []
end
- select_message(receiver, message, candidates)
+ select_message(receiver, message, candidates, sep)
when /^(\$[^.]*)$/
+ # global var
regmessage = Regexp.new(Regexp.quote($1))
candidates = global_variables.collect{|m| m.to_s}.grep(regmessage)
# when /^(\$?(\.?[^.]+)+)\.([^.]*)$/
# when /^((\.?[^.]+)+)\.([^.]*)$/
- when /^([^."].*)\.([^.]*)$/
- # variable
+# when /^([^."].*)\.([^.]*)$/
+ when /^([^."].*)(\.|::)([^.]*)$/
+ # variable.func or func.func
receiver = $1
- message = Regexp.quote($2)
+ sep = $2
+ message = Regexp.quote($3)
gv = eval("global_variables", bind).collect{|m| m.to_s}
lv = eval("local_variables", bind).collect{|m| m.to_s}
cv = eval("self.class.constants", bind).collect{|m| m.to_s}
if (gv | lv | cv).include?(receiver) or /^[A-Z]/ =~ receiver && /\./ !~ receiver
- # foo.func and foo is local var. OR
+ # foo.func and foo is var. OR
+ # foo::func and foo is var. OR
+ # foo::Const and foo is var. OR
# Foo::Bar.func
begin
- candidates = eval("#{receiver}.methods", bind).collect{|m| m.to_s}
+ candidates = []
+ rec = eval(receiver, bind)
+ if sep == "::" and rec.kind_of?(Module)
+ candidates = rec.constants.collect{|m| m.to_s}
+ end
+ candidates |= rec.methods.collect{|m| m.to_s}
rescue Exception
candidates = []
end
@@ -164,7 +177,7 @@ module IRB
candidates.sort!
candidates.uniq!
end
- select_message(receiver, message, candidates)
+ select_message(receiver, message, candidates, sep)
when /^\.([^.]*)$/
# unknown(maybe String)
@@ -186,11 +199,11 @@ module IRB
"<", "<<", "<=", "<=>", "==", "===", "=~", ">", ">=", ">>",
"[]", "[]=", "^", "!", "!=", "!~"]
- def self.select_message(receiver, message, candidates)
+ def self.select_message(receiver, message, candidates, sep = ".")
candidates.grep(/^#{message}/).collect do |e|
case e
when /^[a-zA-Z_]/
- receiver + "." + e
+ receiver + sep + e
when /^[0-9]/
when *Operators
#receiver + " " + e