From: wmorgan Date: Sat, 15 Sep 2007 03:36:23 +0000 (+0000) Subject: expand twiddles for mbox and maildir uris (thanks to Magnus Therning) X-Git-Url: https://git.cworth.org/git?a=commitdiff_plain;h=3889fb90d61b2218a968cc84aa001e3510decd89;p=sup expand twiddles for mbox and maildir uris (thanks to Magnus Therning) git-svn-id: svn://rubyforge.org/var/svn/sup/trunk@577 5c8cc53c-5e98-4d25-b20a-d8db53a31250 --- diff --git a/bin/sup-add b/bin/sup-add index 78df022..2070e37 100644 --- a/bin/sup-add +++ b/bin/sup-add @@ -93,7 +93,6 @@ begin end parsed_uri = URI(uri) - Trollop::die "no path component to uri: #{parsed_uri}" unless parsed_uri.path source = case parsed_uri.scheme diff --git a/lib/sup/maildir.rb b/lib/sup/maildir.rb index cc487d7..2ecfbe7 100644 --- a/lib/sup/maildir.rb +++ b/lib/sup/maildir.rb @@ -11,8 +11,10 @@ module Redwood class Maildir < Source SCAN_INTERVAL = 30 # seconds + ## remind me never to use inheritance again. yaml_properties :uri, :cur_offset, :usual, :archived, :id, :labels def initialize uri, last_date=nil, usual=true, archived=false, id=nil, labels=[] + uri = Source.expand_filesystem_uri uri super uri, last_date, usual, archived, id uri = URI(uri) @@ -29,6 +31,7 @@ class Maildir < Source def file_path; @dir end def self.suggest_labels_for path; [] end + def is_source_for? uri; super || (URI(Source.expand_filesystem_uri(uri)) == URI(self.uri)); end def check scan_mailbox diff --git a/lib/sup/mbox/loader.rb b/lib/sup/mbox/loader.rb index 3105f4a..b2162c0 100644 --- a/lib/sup/mbox/loader.rb +++ b/lib/sup/mbox/loader.rb @@ -6,14 +6,15 @@ module MBox class Loader < Source yaml_properties :uri, :cur_offset, :usual, :archived, :id, :labels - def initialize uri_or_fp, start_offset=nil, usual=true, archived=false, id=nil, labels=[] - super uri_or_fp, start_offset, usual, archived, id + ## uri_or_fp is horrific. need to refactor. + def initialize uri_or_fp, start_offset=nil, usual=true, archived=false, id=nil, labels=[] @mutex = Mutex.new @labels = (labels || []).freeze case uri_or_fp when String + uri_or_fp = Source.expand_filesystem_uri uri_or_fp uri = URI(uri_or_fp) raise ArgumentError, "not an mbox uri" unless uri.scheme == "mbox" raise ArgumentError, "mbox uri ('#{uri}') cannot have a host: #{uri.host}" if uri.host @@ -21,9 +22,12 @@ class Loader < Source else @f = uri_or_fp end + + super uri_or_fp, start_offset, usual, archived, id end def file_path; URI(uri).path end + def is_source_for? uri; super || (URI(Source.expand_filesystem_uri(uri)) == URI(self.uri)); end def self.suggest_labels_for path ## heuristic: use the filename as a label, unless the file diff --git a/lib/sup/source.rb b/lib/sup/source.rb index 2724b75..db91d11 100644 --- a/lib/sup/source.rb +++ b/lib/sup/source.rb @@ -78,7 +78,7 @@ class Source def reset!; seek_to! start_offset; end def == o; o.uri == uri; end def done?; (self.cur_offset ||= start_offset) >= end_offset; end - def is_source_for? uri; URI(self.uri) == URI(uri); end + def is_source_for? uri; uri == URI(uri); end ## check should throw a FatalSourceError or an OutOfSyncSourcError ## if it can detect a problem. it is called when the sup starts up @@ -96,6 +96,10 @@ class Source protected + def Source.expand_filesystem_uri uri + uri.gsub "~", File.expand_path("~") + end + def cur_offset= o @cur_offset = o @dirty = true