bin/sup-config in sup-0.0.8 vs bin/sup-config in sup-0.1

- old
+ new

@@ -19,15 +19,15 @@ EOS end #' stupid ruby-mode def axe q, default=nil ans = - if default && !default.empty? - ask "#{q} (enter for \"#{default}\"): " - else - ask "#{q}: " - end + if default && !default.empty? + ask "#{q} (enter for \"#{default}\"): " + else + ask "#{q}: " + end ans.empty? ? default : ans end def axe_yes q, default="n" axe(q, default) =~ /^y|yes$/i @@ -40,69 +40,102 @@ def add_source type = nil say "Ok, adding a new source." choose do |menu| - menu.prompt = "What type of mail source is it?" + menu.prompt = "What type of mail source is it? " menu.choice("mbox file") { type = :mbox } menu.choice("maildir directory") { type = :maildir } menu.choice("remote mbox file (accessible via ssh)") { type = :mboxssh } menu.choice("IMAP server (secure)") { type = :imaps } menu.choice("IMAP server (unsecure)") { type = :imap } menu.choice("Get me out of here!") { return } end while true do - say "Now for the details." + say "Ok, now for the details." - components = + default_labels, components = case type when :mbox - fn = axe "What's the full path to the mbox file?", ENV["MAIL"] #"srm + $last_fn ||= ENV["MAIL"] + fn = axe "What's the full path to the mbox file?", $last_fn #"srm return if fn.nil? || fn.empty? - { :scheme => "mbox", :path => fn } + + $last_fn = fn + [Redwood::MBox::Loader.suggest_labels_for(fn), + { :scheme => "mbox", :path => fn }] when :maildir - fn = axe "What's the full path to the maildir directory?", ENV["MAIL"] #"srm + $last_fn ||= ENV["MAIL"] + fn = axe "What's the full path to the maildir directory?", $last_fn #"srm return if fn.nil? || fn.empty? - { :scheme => "maildir", :path => fn } + + $last_fn = fn + [Redwood::Maildir.suggest_labels_for(fn), + { :scheme => "maildir", :path => fn }] when :mboxssh - srv = axe "What server is the mbox file located on?", $last_server + $last_server ||= "localhost" + srv = axe "What machine is the mbox file located on?", $last_server return if srv.nil? || srv.empty? $last_server = srv - fn = axe "What's the full path to the mbox file?", ENV["MAIL"] #"srm + + fn = axe "What's the path to the mbox file?", $last_fn #" stupid ruby-mode return if fn.nil? || fn.empty? + $last_fn = fn fn = "/#{fn}" # lame - { :scheme => "mbox+ssh", :host => srv, :path => fn } + [Redwood::MBox::SSHLoader.suggest_labels_for(fn), + { :scheme => "mbox+ssh", :host => srv, :path => fn }] when :imap, :imaps - srv = axe "What is the IMAP server?", $last_server + $last_server ||= "localhost" + srv = axe "What is the IMAP server (host, or host:port notation)?", $last_server return if srv.nil? || srv.empty? $last_server = srv - fn = axe "What's the folder path?", "INBOX" #"srm + + $last_folder ||= "INBOX" + fn = axe "What's the folder path?", $last_folder #"srm return if fn.nil? || fn.empty? + $last_folder = fn + fn = "/#{fn}" # lame - { :scheme => type.to_s, :host => srv, :path => fn } + if srv =~ /^(\w+):(\d+)$/ + host, port = $1, $2.to_i + else + host, port = srv, nil + end + [Redwood::IMAP.suggest_labels_for(fn), + { :scheme => type.to_s, :host => host, :port => port, :path => fn }] end uri = begin URI::Generic.build components rescue URI::Error => e say "Whoopsie! I couldn't build a URI from that: #{e.message}" if axe_yes("Try again?") then next else return end end - say "I'm going to add this source: #{uri}." + say "I'm going to add this source: #{uri}" unless axe("Does that look right?", "y") =~ /^y|yes$/i if axe_yes("Try again?") then next else return end end usual = axe_yes "Does this source ever receive new messages?", "y" - archive = usual ? axe_yes("Should those new messages be automatically archived?") : false + archive = usual ? axe_yes("Should new messages be automatically archived? (I.e. not appear in your inbox, though still be accessible via search.)") : false + + labels_str = axe("Enter any labels to be automatically added to all messages from this source, separated by spaces (or 'none')", default_labels.join(",")) + + labels = + if labels_str =~ /^\s*none\s*$/i + nil + else + labels_str.split(/\s+/) + end cmd = build_cmd "sup-add" cmd += " --unusual" unless usual cmd += " --archive" if archive + cmd += " --labels=#{labels.join(',')}" if labels && !labels.empty? cmd += " #{uri}" puts "Ok, trying to run \"#{cmd}\"..." system cmd @@ -126,20 +159,19 @@ the next generation of digital cyberspace: the text-based email program. Get ready to be the envy of everyone in your internets with your amazing keyboarding skills! Jump from email to email with nary a click of the mouse! -Just answer these simple questions and you'll be on your way! Press -enter at any point to accept the default answer. +Just answer these simple questions and you'll be on your way. EOS #' stupid ruby-mode account = $config[:accounts][:default] name = axe "What's your name?", account[:name] -email = axe "What's your email address?", account[:email] #'srm +email = axe "What's your (primary) email address?", account[:email] #'srm say "Ok, your header will look like this:" say " From: #{name} <#{email}>" say "\nDo you have any alternate email addresses that also receive email?" @@ -170,11 +202,11 @@ index.sources.each { |s| puts "* #{s}" } end say "\n" choose do |menu| - menu.prompt = "Your wish?" + menu.prompt = "Your wish? " menu.choice("Add a new source.") { add_source } menu.choice("Done adding sources!") { done = true } end end @@ -182,16 +214,10 @@ Ok. The final step is to import all your messages into the Sup index. Depending on how many messages are in the sources, this could take quite a while. -IMPORTANT NOTE: this import will archive messages if the source is -marked archival, and won't otherwise. It will preserve read/unread -status as given by the source, and it will automatically add one label -per source. All of this behavior can be controlled on per-source -basis by running sup-sync manually. - EOS #' if axe_yes "Run sup-sync to import all messages now?" while true cmd = build_cmd("sup-sync") + " --all-sources" @@ -214,9 +240,9 @@ Okee doke, you've got yourself an index of #{index.size} messages. Looks like you're ready to jack in to cyberspace there, cowboy. Just one last command: - sup + #{build_cmd "sup"} Have fun! EOS