]> git.cworth.org Git - sup/blob - lib/sup/contact.rb
skip system buffers when rolling
[sup] / lib / sup / contact.rb
1 module Redwood
2
3 class ContactManager
4   include Singleton
5
6   def initialize fn
7     @fn = fn
8
9     ## maintain the mapping between people and aliases. for contacts without
10     ## aliases, there will be no @a2p entry, so @p2a.keys should be treated
11     ## as the canonical list of contacts.
12
13     @p2a = {} # person to alias
14     @a2p = {} # alias to person
15
16     if File.exists? fn
17       IO.foreach(fn) do |l|
18         l =~ /^([^:]*): (.*)$/ or raise "can't parse #{fn} line #{l.inspect}"
19         aalias, addr = $1, $2
20         p = Person.from_address addr
21         @p2a[p] = aalias
22         @a2p[aalias] = p unless aalias.nil? || aalias.empty?
23       end
24     end
25
26     self.class.i_am_the_instance self
27   end
28
29   def contacts; @p2a.keys end
30   def contacts_with_aliases; @a2p.values.uniq end
31
32   def update_alias person, aalias=nil
33     if(old_aalias = @p2a[person]) # remove old alias
34       @a2p.delete old_aalias
35     end
36     @p2a[person] = aalias
37     @a2p[aalias] = person unless aalias.nil? || aalias.empty?
38   end
39
40   ## this may not actually be called anywhere, since we still keep contacts
41   ## around without aliases to override any fullname changes.
42   def drop_contact person
43     aalias = @p2a[person]
44     @p2a.delete person
45     @a2p.delete aalias if aalias
46   end
47
48   def contact_for aalias; @a2p[aalias] end
49   def alias_for person; @p2a[person] end
50   def is_aliased_contact? person; !@p2a[person].nil? end
51
52   def save
53     File.open(@fn, "w") do |f|
54       @p2a.sort_by { |(p, a)| [p.full_address, a] }.each do |(p, a)|
55         f.puts "#{a || ''}: #{p.full_address}"
56       end
57     end
58   end
59 end
60
61 end