commit edcb35ea97654c29c2e6a77915cf7ba66a526129
parent cf3d44d1c974075ff52957302291599f9c70a41e
Author: wmorgan <wmorgan@5c8cc53c-5e98-4d25-b20a-d8db53a31250>
Date: Fri, 14 Sep 2007 01:47:43 +0000
to: tab completion also loads in the 10 most recent correspondents' email addresses
git-svn-id: svn://rubyforge.org/var/svn/sup/trunk@567 5c8cc53c-5e98-4d25-b20a-d8db53a31250
Diffstat:
2 files changed, 7 insertions(+), 3 deletions(-)
diff --git a/lib/sup/buffer.rb b/lib/sup/buffer.rb
@@ -422,10 +422,14 @@ class BufferManager
def ask_for_contacts domain, question, default_contacts=[]
default = default_contacts.map { |s| s.to_s }.join(" ")
default += " " unless default.empty?
+
+ recent = Index.load_contacts(AccountManager.user_emails, :num => 10).map { |c| [c.longname, c.email] }
+ contacts = ContactManager.contacts.map { |c| [ContactManager.alias_for(c), c.longname, c.email] }
- all_contacts = ContactManager.contacts.map { |c| [ContactManager.alias_for(c), c.longname, c.email] }.flatten.uniq.sort
+ Redwood::log "recent: #{recent.inspect}"
- answer = BufferManager.ask_many_with_completions domain, question, all_contacts, default, /\s*,\s*/
+ completions = (recent + contacts).flatten.uniq.sort
+ answer = BufferManager.ask_many_with_completions domain, question, completions, default, /\s*,\s*/
if answer
answer.split_on_commas.map { |x| ContactManager.contact_for(x.downcase) || PersonManager.person_for(x) }
diff --git a/lib/sup/index.rb b/lib/sup/index.rb
@@ -342,7 +342,7 @@ EOS
num = h[:num] || 20
@index.search_each(q, :sort => "date DESC", :limit => :all) do |docid, score|
break if contacts.size >= num
- #Redwood::log "got message with to: #{@index[docid][:to].inspect} and from: #{@index[docid][:from].inspect}"
+ #Redwood::log "got message #{docid} to: #{@index[docid][:to].inspect} and from: #{@index[docid][:from].inspect}"
f = @index[docid][:from]
t = @index[docid][:to]