bin/sup in sup-0.0.6 vs bin/sup in sup-0.0.7

- old
+ new

@@ -10,13 +10,13 @@ global_keymap = Keymap.new do |k| k.add :quit, "Quit Redwood", 'q' k.add :help, "Show help", 'H', '?' k.add :roll_buffers, "Switch to next buffer", 'b' - k.add :roll_buffers_backwards, "Switch to previous buffer", 'B' +# k.add :roll_buffers_backwards, "Switch to previous buffer", 'B' k.add :kill_buffer, "Kill the current buffer", 'x' - k.add :list_buffers, "List all buffers", 'A' + k.add :list_buffers, "List all buffers", 'B' k.add :list_contacts, "List contacts", 'C' k.add :redraw, "Redraw screen", :ctrl_l k.add :search, "Search messages", '/' k.add :list_labels, "List labels", 'L' k.add :poll, "Poll for new messages", 'P' @@ -69,10 +69,12 @@ c.add :labellist_new_color, Ncurses::COLOR_WHITE, Ncurses::COLOR_BLACK, Ncurses::A_BOLD c.add :twiddle_color, Ncurses::COLOR_BLUE, Ncurses::COLOR_BLACK c.add :label_color, Ncurses::COLOR_YELLOW, Ncurses::COLOR_BLACK c.add :message_patina_color, Ncurses::COLOR_BLACK, Ncurses::COLOR_GREEN + c.add :alternate_patina_color, Ncurses::COLOR_BLACK, Ncurses::COLOR_BLUE + c.add :missing_message_color, Ncurses::COLOR_BLACK, Ncurses::COLOR_RED c.add :mime_color, Ncurses::COLOR_CYAN, Ncurses::COLOR_BLACK c.add :quote_patina_color, Ncurses::COLOR_YELLOW, Ncurses::COLOR_BLACK c.add :sig_patina_color, Ncurses::COLOR_YELLOW, Ncurses::COLOR_BLACK c.add :quote_color, Ncurses::COLOR_YELLOW, Ncurses::COLOR_BLACK c.add :sig_color, Ncurses::COLOR_YELLOW, Ncurses::COLOR_BLACK @@ -98,12 +100,22 @@ log "ready for (inter)action!" Logger.make_buf bm.draw_screen - imode.load_threads :num => ibuf.content_height, :when_done => lambda { reporting_thread { sleep 1; PollManager.poll } } + Index.usual_sources.each do |s| + reporting_thread do + begin + s.connect + rescue SourceError => e + Redwood::log "Fatal error loading from #{s}: #{e.message}" + end + end if s.respond_to? :connect + end + imode.load_threads :num => ibuf.content_height, :when_done => lambda { reporting_thread { sleep 1; PollManager.poll } } + PollManager.start_thread until $exception bm.draw_screen c = Ncurses.nonblocking_getch @@ -114,25 +126,25 @@ elsif c unless bm.handle_input(c) x = global_keymap.action_for c case x when :quit - break + break if bm.kill_all_buffers_safely when :help curmode = bm.focus_buf.mode bm.spawn_unless_exists("<help for #{curmode.name}>") { HelpMode.new curmode, global_keymap } when :roll_buffers bm.roll_buffers when :roll_buffers_backwards bm.roll_buffers_backwards when :kill_buffer - bm.kill_buffer bm.focus_buf if bm.focus_buf.mode.killable? + bm.kill_buffer_safely bm.focus_buf when :list_buffers bm.spawn_unless_exists("Buffer List") { BufferListMode.new } when :list_contacts b = bm.spawn_unless_exists("Contact List") { ContactListMode.new } - b.mode.load_more b.content_height + b.mode.load_in_background when :search text = bm.ask :search, "query: " next unless text && text !~ /^\s*$/ begin @@ -143,11 +155,10 @@ bm.spawn "search: \"#{short_text}\"", mode mode.load_threads :num => mode.buffer.content_height rescue Ferret::QueryParser::QueryParseException => e bm.flash "Couldn't parse query." end - when :list_labels b = bm.spawn_unless_exists("Label List") { LabelListMode.new } b.mode.load_in_background when :compose mode = ComposeMode.new @@ -179,15 +190,20 @@ bm.flash "Unknown key press '#{c.to_character}' for #{bm.focus_buf.mode.name}." end end end end - bm.kill_all_buffers rescue Exception => e $exception ||= e ensure Redwood::finish stop_cursing + + # don't ask me why, but sometimes it's necessary to print something + # to stderr at this point or the exception doesn't get printed. + # doesn't get printed. WHY? + + $stderr.puts " " end Index.save unless $exception # TODO: think about this if $exception