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