lib/sup/contact.rb in sup-0.12.1 vs lib/sup/contact.rb in sup-0.13.0
- old
+ new
@@ -10,42 +10,48 @@
## aliases, there will be no @a2p entry, so @p2a.keys should be treated
## as the canonical list of contacts.
@p2a = {} # person to alias
@a2p = {} # alias to person
+ @e2p = {} # email to person
if File.exists? fn
IO.foreach(fn) do |l|
l =~ /^([^:]*): (.*)$/ or raise "can't parse #{fn} line #{l.inspect}"
aalias, addr = $1, $2
- p = Person.from_address addr
- @p2a[p] = aalias
- @a2p[aalias] = p unless aalias.nil? || aalias.empty?
+ update_alias Person.from_address(addr), aalias
end
end
end
def contacts; @p2a.keys end
def contacts_with_aliases; @a2p.values.uniq end
def update_alias person, aalias=nil
- if(old_aalias = @p2a[person]) # remove old alias
+ old_aalias = @p2a[person]
+ if(old_aalias != nil and old_aalias != "") # remove old alias
@a2p.delete old_aalias
+ @e2p.delete person.email
end
@p2a[person] = aalias
- @a2p[aalias] = person unless aalias.nil? || aalias.empty?
+ unless aalias.nil? || aalias.empty?
+ @a2p[aalias] = person
+ @e2p[person.email] = person
+ end
end
## this may not actually be called anywhere, since we still keep contacts
## around without aliases to override any fullname changes.
def drop_contact person
aalias = @p2a[person]
@p2a.delete person
+ @e2p.delete person.email
@a2p.delete aalias if aalias
end
def contact_for aalias; @a2p[aalias] end
def alias_for person; @p2a[person] end
+ def person_for email; @e2p[email] end
def is_aliased_contact? person; !@p2a[person].nil? end
def save
File.open(@fn, "w") do |f|
@p2a.sort_by { |(p, a)| [p.full_address, a] }.each do |(p, a)|