Code

ncmpc.git
15 years agoMakefile.am: require automake 1.10
Thomas Jansen [Tue, 27 Oct 2009 11:18:20 +0000 (12:18 +0100)]
Makefile.am: require automake 1.10

Match the version mpd uses.

15 years agoMakefile.am: enable the "subdir-objects" option
Thomas Jansen [Tue, 27 Oct 2009 08:19:55 +0000 (09:19 +0100)]
Makefile.am: enable the "subdir-objects" option

Don't clutter the top directory with *.o files similar to mpd.

15 years agoscreen_file: sync highlights in screen_file_open
Thomas Jansen [Tue, 27 Oct 2009 08:15:19 +0000 (09:15 +0100)]
screen_file: sync highlights in screen_file_open

Fix bug #2605, where CMD_SCREEN_FILE would show no highlights until some
user action or event changed that.

15 years agompdclient: return after playlist_update() error
Max Kellermann [Fri, 23 Oct 2009 09:01:52 +0000 (11:01 +0200)]
mpdclient: return after playlist_update() error

In each of the functions, the client may get disconnected, and we have
to check c->status!=NULL again.

15 years agohscroll: reimplemented the hscroll library
Max Kellermann [Tue, 20 Oct 2009 06:00:13 +0000 (08:00 +0200)]
hscroll: reimplemented the hscroll library

The hscroll object knows the location on the screen and the text.
Upon initialization, it installs a GLib timer which updates the screen
every second.

15 years agostatus_bar: un-inline constructor and destructor
Max Kellermann [Tue, 20 Oct 2009 06:00:13 +0000 (08:00 +0200)]
status_bar: un-inline constructor and destructor

15 years agohscroll: simplify the code with utf8_cut_width()
Max Kellermann [Tue, 20 Oct 2009 06:00:12 +0000 (08:00 +0200)]
hscroll: simplify the code with utf8_cut_width()

Concatenate the input string twice, and select a substring from that
large string.

15 years agocharset: added function utf8_cut_width()
Max Kellermann [Tue, 20 Oct 2009 06:00:09 +0000 (08:00 +0200)]
charset: added function utf8_cut_width()

This function helps printing UTF-8 strings on limited screen space.

15 years agohscroll: work with UTF-8 strings
Max Kellermann [Tue, 20 Oct 2009 05:59:14 +0000 (07:59 +0200)]
hscroll: work with UTF-8 strings

Convert the input strings to UTF-8 before applying UTF-8 functions on
them.  Convert back to the locale before returning.

15 years agotest: added "run_hscroll" program
Max Kellermann [Tue, 20 Oct 2009 05:59:14 +0000 (07:59 +0200)]
test: added "run_hscroll" program

A program for debugging the hscroll.c library.

15 years agoscreen_browser: initialize local variable
Max Kellermann [Tue, 20 Oct 2009 05:59:11 +0000 (07:59 +0200)]
screen_browser: initialize local variable

15 years agoconfigure.ac: added option --enable-test
Max Kellermann [Tue, 20 Oct 2009 05:19:11 +0000 (07:19 +0200)]
configure.ac: added option --enable-test

This will enable the test suite.

15 years agoconfigure.ac: use standard autoconf variable names
Max Kellermann [Tue, 20 Oct 2009 05:19:06 +0000 (07:19 +0200)]
configure.ac: use standard autoconf variable names

Use the variable name implicitly created by AC_ARG_ENABLE.

15 years agopo: updated Korean translation
Jay Whang [Mon, 19 Oct 2009 13:45:04 +0000 (15:45 +0200)]
po: updated Korean translation

15 years agocharset: added "replace" functions
Max Kellermann [Mon, 19 Oct 2009 06:18:43 +0000 (08:18 +0200)]
charset: added "replace" functions

These functions are a shortcut for a common use case: convert an
allocated string in-place.

15 years agoscreen_browser: free temporary string
Max Kellermann [Sun, 18 Oct 2009 18:53:20 +0000 (20:53 +0200)]
screen_browser: free temporary string

In browser_lw_callback(), free the converted directory base name.

15 years agohscroll: use g_strconcat() instead of g_strlcpy() + g_strlcat()
Max Kellermann [Sun, 18 Oct 2009 18:35:59 +0000 (20:35 +0200)]
hscroll: use g_strconcat() instead of g_strlcpy() + g_strlcat()

15 years agohscroll: pass const strings to strscroll()
Max Kellermann [Sun, 18 Oct 2009 18:35:52 +0000 (20:35 +0200)]
hscroll: pass const strings to strscroll()

15 years agohscroll: don't include ctype.h
Max Kellermann [Sun, 18 Oct 2009 18:35:47 +0000 (20:35 +0200)]
hscroll: don't include ctype.h

15 years agompdclient: don't assign c->status twice in mpdclient_cmd_clear()
Max Kellermann [Sun, 18 Oct 2009 00:27:14 +0000 (02:27 +0200)]
mpdclient: don't assign c->status twice in mpdclient_cmd_clear()

Forgot to delete this line when I switched to mpdclient_recv_status().

15 years agompdclient: removed mpdclient_cmd_swap()
Max Kellermann [Sun, 18 Oct 2009 00:21:56 +0000 (02:21 +0200)]
mpdclient: removed mpdclient_cmd_swap()

Not used anymore.

15 years agoscreen_queue: move ranges with one single "move" command
Max Kellermann [Sun, 18 Oct 2009 00:21:13 +0000 (02:21 +0200)]
screen_queue: move ranges with one single "move" command

Instead of swapping every single song in the selected range, send one
single "move" command which moves the neighbor song to the other end
of the range.

15 years agompdclient: added function mpdclient_cmd_move()
Max Kellermann [Sun, 18 Oct 2009 00:20:17 +0000 (02:20 +0200)]
mpdclient: added function mpdclient_cmd_move()

15 years agoplaylist: added function playlist_move()
Max Kellermann [Sun, 18 Oct 2009 00:20:11 +0000 (02:20 +0200)]
playlist: added function playlist_move()

15 years agoplaylist: don't update the song positions in playlist_swap()
Max Kellermann [Sun, 18 Oct 2009 00:00:01 +0000 (02:00 +0200)]
playlist: don't update the song positions in playlist_swap()

In ncmpc, nobody reads the song's "position" attribute (except for the
"plchanges" handler).  We don't need it, and we don't need to update
it after a swap.

15 years agompdclient: renamed mpdclient_cmd_move() to mpdclient_cmd_swap()
Max Kellermann [Sat, 17 Oct 2009 23:59:28 +0000 (01:59 +0200)]
mpdclient: renamed mpdclient_cmd_move() to mpdclient_cmd_swap()

That function does not move, it swaps two songs.

15 years agompdclient: moved code to mpdclient_recv_status()
Max Kellermann [Sat, 17 Oct 2009 23:48:05 +0000 (01:48 +0200)]
mpdclient: moved code to mpdclient_recv_status()

Merge some duplicate code.

15 years agompdclient: optimize crop with delete_range
Max Kellermann [Sat, 17 Oct 2009 23:36:05 +0000 (01:36 +0200)]
mpdclient: optimize crop with delete_range

MPD 0.16 supports "delete" with a range.

15 years agompdclient: don't update the status in mpdclient_cmd_crop()
Max Kellermann [Sat, 17 Oct 2009 23:34:21 +0000 (01:34 +0200)]
mpdclient: don't update the status in mpdclient_cmd_crop()

This is kind of redundant, because it doesn't solve the theoretical
race condition, and doesn't improve too much to justify the latency.

15 years agompdclient: update mpdclient.playlist in mpdclient_cmd_clear()
Max Kellermann [Sat, 17 Oct 2009 23:04:11 +0000 (01:04 +0200)]
mpdclient: update mpdclient.playlist in mpdclient_cmd_clear()

Reduce UI latency.

15 years agompdclient: removed mpdclient_cmd_play()
Max Kellermann [Sat, 17 Oct 2009 22:57:11 +0000 (00:57 +0200)]
mpdclient: removed mpdclient_cmd_play()

Call mpdclient_run_play_id() directly.

15 years agoscreen_queue: set cursor before button handlers
Max Kellermann [Sat, 17 Oct 2009 22:55:26 +0000 (00:55 +0200)]
screen_queue: set cursor before button handlers

This allows us to use screen_queue_selected_song().

15 years agoscreen_queue: update list_window length after mouse delete
Max Kellermann [Sat, 17 Oct 2009 22:54:14 +0000 (00:54 +0200)]
screen_queue: update list_window length after mouse delete

Fix an assertion failure.

15 years agocheck the return value of mpdclient_get_connection()
Max Kellermann [Sat, 17 Oct 2009 22:32:37 +0000 (00:32 +0200)]
check the return value of mpdclient_get_connection()

When leaving idle mode, the idle callback (which is invoked indirectly
by mpdclient_get_connection()) may close the connection.  Checking
mpdclient_is_connected() before mpdclient_get_connection() is
pointless for that reason.

15 years agoscreen_file: return void from handle_X() functions
Max Kellermann [Sat, 17 Oct 2009 22:32:32 +0000 (00:32 +0200)]
screen_file: return void from handle_X() functions

Nobody evaluates the return values.

15 years agoscreen_browser: convert path only for the message
Max Kellermann [Sat, 17 Oct 2009 22:30:42 +0000 (00:30 +0200)]
screen_browser: convert path only for the message

We don't need the locale path if we don't print a message.

15 years agoscreen_outputs: reset list_window length in clear_outputs_list()
Max Kellermann [Sat, 17 Oct 2009 22:12:37 +0000 (00:12 +0200)]
screen_outputs: reset list_window length in clear_outputs_list()

Fix an assertion failure on disconnect.

15 years agoscreen_artist: check connection!=NULL in load_song_list()
Max Kellermann [Sat, 17 Oct 2009 22:01:18 +0000 (00:01 +0200)]
screen_artist: check connection!=NULL in load_song_list()

15 years agoscreen_file: always set new list_window length
Max Kellermann [Sat, 17 Oct 2009 21:54:58 +0000 (23:54 +0200)]
screen_file: always set new list_window length

screen_file_reload() did not update the list_window length if it was
not connected.  This led to an assertion failure.

15 years agogidle: mpd_glib_enter() returns success
Max Kellermann [Fri, 16 Oct 2009 13:08:51 +0000 (15:08 +0200)]
gidle: mpd_glib_enter() returns success

mpd_glib_enter() is unreliable, because it does nothing when called
during the callback, which in turn was invoked by mpd_glib_leave().
Sometimes, mpdclient.idle is wrong because of that.  This patch sets
mpdclient.idle to the return value of mpd_glib_enter().

15 years agogidle: added internal "destroyed" flag
Max Kellermann [Fri, 16 Oct 2009 13:06:58 +0000 (15:06 +0200)]
gidle: added internal "destroyed" flag

If mpd_glib_leave() invokes the callback, and the callback destroys
the mpd_glib_source object, mpd_glib_leave() is unable to reset the
"leaving" flag.  This patch adds the flag "destroyed" which lets
mpd_glib_leave() do the g_free() when it's ready.

15 years agoscreen_help: translate section names
Max Kellermann [Thu, 15 Oct 2009 13:38:22 +0000 (15:38 +0200)]
screen_help: translate section names

The _() call was missing.

15 years agopo: updated Russian translation
Max Arnold [Thu, 15 Oct 2009 13:36:26 +0000 (15:36 +0200)]
po: updated Russian translation

Conversion to UTF-8.

15 years agolist_window: removed second column support
Max Kellermann [Sun, 11 Oct 2009 17:46:11 +0000 (19:46 +0200)]
list_window: removed second column support

Not used anymore, because both screen_browser and screen_queue have a
row paint callback now.

15 years agoscreen_queue: use paint_song_row()
Max Kellermann [Sun, 11 Oct 2009 17:41:08 +0000 (19:41 +0200)]
screen_queue: use paint_song_row()

Reuse code from screen_browser.c.  Side effect: this patch disables
horizontal scrolling.  The "hscroll" library will return after an
overhaul.

15 years agoscreen_help: simplify the list_window callback
Max Kellermann [Sun, 11 Oct 2009 17:30:20 +0000 (19:30 +0200)]
screen_help: simplify the list_window callback

Return unmodified strings.  Since that callback isn't used for
painting, we don't need to consider the layout here.

15 years agoscreen_help: added paint callback
Max Kellermann [Sun, 11 Oct 2009 17:29:30 +0000 (19:29 +0200)]
screen_help: added paint callback

15 years agoscreen_help: use help_paint()
Max Kellermann [Sun, 11 Oct 2009 17:20:55 +0000 (19:20 +0200)]
screen_help: use help_paint()

Don't call list_window_paint() manually.

15 years agoscreen_help: removed the help_text_row_t typedef
Max Kellermann [Sun, 11 Oct 2009 17:20:52 +0000 (19:20 +0200)]
screen_help: removed the help_text_row_t typedef

Use the struct name.

15 years agocharset: make utf8_with() "pure"
Max Kellermann [Sun, 11 Oct 2009 17:20:49 +0000 (19:20 +0200)]
charset: make utf8_with() "pure"

This allows gcc to optimize further.

15 years agoscreen_queue: check current song only if PLAYER idle event is set
Max Kellermann [Sun, 11 Oct 2009 17:01:57 +0000 (19:01 +0200)]
screen_queue: check current song only if PLAYER idle event is set

15 years agoscreen_outputs: paint "enabled" checkbox
Max Kellermann [Sun, 11 Oct 2009 16:52:21 +0000 (18:52 +0200)]
screen_outputs: paint "enabled" checkbox

Instead of painting names in highlighted color, show the "enabled"
state with a checkbox.

15 years agoscreen_browser: moved paint_song() to song_paint.c
Max Kellermann [Sun, 11 Oct 2009 16:20:49 +0000 (18:20 +0200)]
screen_browser: moved paint_song() to song_paint.c

15 years agorenamed screen_play.c to screen_queue.c
Max Kellermann [Sun, 11 Oct 2009 16:16:05 +0000 (18:16 +0200)]
renamed screen_play.c to screen_queue.c

15 years agoscreen_browser: display song duration
Max Kellermann [Sun, 11 Oct 2009 13:41:34 +0000 (15:41 +0200)]
screen_browser: display song duration

15 years agoscreen_browser: don't return directory name with square brackets
Max Kellermann [Sun, 11 Oct 2009 12:55:53 +0000 (14:55 +0200)]
screen_browser: don't return directory name with square brackets

Since the browser_lw_callback() isn't used for rendering anymore (only
for searching), we can remove the page breaks.

15 years agoscreen_browser: added custom list painting function
Max Kellermann [Sun, 11 Oct 2009 12:55:23 +0000 (14:55 +0200)]
screen_browser: added custom list painting function

Side effect: playlists and directories are rendered with different
colors (configuration "browser-directory" and "browser-playlist").

15 years agolist_window: added callback function for row painting
Max Kellermann [Sun, 11 Oct 2009 12:53:28 +0000 (14:53 +0200)]
list_window: added callback function for row painting

With the function list_window_paint2(), callers can customize how a
row is painted.  The usual callback function is not used anymore.

15 years agolist_window: moved painting utilities to paint.h
Max Kellermann [Sun, 11 Oct 2009 12:15:38 +0000 (14:15 +0200)]
list_window: moved painting utilities to paint.h

Minor optimization: pass the full row width to whline().  This way,
ncurses performs clipping for us, and we don't have to call
utf8_width().

15 years agoscreen_browser: added wrapper function screen_browser_paint()
Max Kellermann [Sat, 10 Oct 2009 18:25:46 +0000 (20:25 +0200)]
screen_browser: added wrapper function screen_browser_paint()

Don't export browser_lw_callback().

15 years agolist_window: simplified narrow cursor drawing
Max Kellermann [Sat, 10 Oct 2009 18:20:24 +0000 (20:20 +0200)]
list_window: simplified narrow cursor drawing

Clear the space after the text before drawing the second column.  The
continue drawing the second column.

15 years agolist_window: simplify show_cursor formula
Max Kellermann [Sat, 10 Oct 2009 17:37:58 +0000 (19:37 +0200)]
list_window: simplify show_cursor formula

And call list_window_get_range() only if show_cursor is true.

15 years agolist_window: removed selected_start, selected_end
Max Kellermann [Sat, 10 Oct 2009 17:36:13 +0000 (19:36 +0200)]
list_window: removed selected_start, selected_end

Calculate those two variables on demand.  This simplifies a lot of
code, and saves some memory and CPU cycles.

15 years agompdclient: fall back to simple "deleteid" if range is 1
Max Kellermann [Sat, 10 Oct 2009 17:09:26 +0000 (19:09 +0200)]
mpdclient: fall back to simple "deleteid" if range is 1

15 years agooptions: removed deprecated password code
Max Kellermann [Sat, 10 Oct 2009 16:54:24 +0000 (18:54 +0200)]
options: removed deprecated password code

libmpdclient2 parses the password from the host name.

15 years agolist_window: eliminate redundant code in list_window_fetch_cursor()
Max Kellermann [Sat, 10 Oct 2009 16:51:36 +0000 (18:51 +0200)]
list_window: eliminate redundant code in list_window_fetch_cursor()

Use list_window_move_cursor() to eliminate redundant code.

15 years agolist_window: removed redundant range_base checks
Max Kellermann [Sat, 10 Oct 2009 16:46:04 +0000 (18:46 +0200)]
list_window: removed redundant range_base checks

No need to check range_base in list_window_check_selected().

15 years agolist_window: moved checks to list_window_validate_index()
Max Kellermann [Sat, 10 Oct 2009 16:39:37 +0000 (18:39 +0200)]
list_window: moved checks to list_window_validate_index()

15 years agolist_window: removed scrolling from list_window_check_selected()
Max Kellermann [Sat, 10 Oct 2009 16:37:18 +0000 (18:37 +0200)]
list_window: removed scrolling from list_window_check_selected()

This broke CMD_LIST_FIRST.

15 years agoscreen_artist.c: use libmpdclient to obtain artist/album list
Max Kellermann [Sat, 10 Oct 2009 16:30:21 +0000 (18:30 +0200)]
screen_artist.c: use libmpdclient to obtain artist/album list

Moved the mpdclient_get_artists/albums() code from mpdclient.c to
screen_artist.c.

15 years agoscreen_artist: don't pass mpdclient object to free_lists()
Max Kellermann [Sat, 10 Oct 2009 16:26:09 +0000 (18:26 +0200)]
screen_artist: don't pass mpdclient object to free_lists()

It's unused.

15 years agompdclient: merged duplicate code into recv_tag_values()
Max Kellermann [Sat, 10 Oct 2009 16:13:49 +0000 (18:13 +0200)]
mpdclient: merged duplicate code into recv_tag_values()

15 years agolist_window: fix list_window_check_origin() indentation
Max Kellermann [Sat, 10 Oct 2009 16:07:11 +0000 (18:07 +0200)]
list_window: fix list_window_check_origin() indentation

15 years agolist_window: fully disable highlighting code on --enable-mini
Max Kellermann [Sat, 10 Oct 2009 16:05:32 +0000 (18:05 +0200)]
list_window: fully disable highlighting code on --enable-mini

15 years agolist_window: moved code to jump_match()
Max Kellermann [Sat, 10 Oct 2009 15:56:11 +0000 (17:56 +0200)]
list_window: moved code to jump_match()

Simplify the list_window_jump() function.

15 years agolist_window: don't allow list_window_jump(NULL)
Max Kellermann [Sat, 10 Oct 2009 15:45:57 +0000 (17:45 +0200)]
list_window: don't allow list_window_jump(NULL)

Added an assertion, removed two runtime checks.  Same for
list_window_find() and list_window_rfind().

15 years agolist_window: moved auto-scrolling code to list_window_check_origin()
Max Kellermann [Sat, 10 Oct 2009 15:45:23 +0000 (17:45 +0200)]
list_window: moved auto-scrolling code to list_window_check_origin()

Moved code from list_window_paint().  Call it in list_window_resize(),
list_window_set_length(), list_window_set_cursor(),
list_window_move_cursor().  Now that all the modifying code has been
removed from list_window_paint(), we can pass a const object to that
function.

15 years agolist_window: added function list_window_resize()
Max Kellermann [Sat, 10 Oct 2009 15:45:19 +0000 (17:45 +0200)]
list_window: added function list_window_resize()

Call this function instead of manually setting the "cols" and "rows"
attributes.

15 years agolist_window: use list_window_move_cursor() in find functions
Max Kellermann [Sat, 10 Oct 2009 15:45:13 +0000 (17:45 +0200)]
list_window: use list_window_move_cursor() in find functions

Don't repeat the range selection code.

15 years agogidle: free all objects in mpd_glib_free()
Max Kellermann [Sat, 10 Oct 2009 14:36:30 +0000 (16:36 +0200)]
gidle: free all objects in mpd_glib_free()

The mpd_parser object was not freed, and neither was the
mpd_glib_source object.

15 years agostrfsong: support multiple values for a tag
Max Kellermann [Sat, 10 Oct 2009 14:36:10 +0000 (16:36 +0200)]
strfsong: support multiple values for a tag

Concatenate them with ", " in between.

15 years agoscreen_song: corrected list_window length
Max Kellermann [Sat, 10 Oct 2009 14:23:03 +0000 (16:23 +0200)]
screen_song: corrected list_window length

15 years agolist_window: don't invoke callback out-of-range
Max Kellermann [Sat, 10 Oct 2009 14:13:55 +0000 (16:13 +0200)]
list_window: don't invoke callback out-of-range

For screen rows after the end of the list, don't invoke the callback.
We know the length of the list, and we know that the callback will
return NULL anyway.

Optimization: after the end of the list, call wclrtobot() to clear all
of the remaining visible (empty) lines.

15 years agolist_window: added attribute "length"
Max Kellermann [Sat, 10 Oct 2009 14:07:33 +0000 (16:07 +0200)]
list_window: added attribute "length"

Don't pass the number of list items to each and every function.
Instead, call list_window_set_length() each time the list contents
change.

15 years agoscreen_search: moved help text into a global variable
Max Kellermann [Sat, 10 Oct 2009 13:58:06 +0000 (15:58 +0200)]
screen_search: moved help text into a global variable

15 years agogidle: work around nested leave/enter problem
Max Kellermann [Sat, 10 Oct 2009 13:47:46 +0000 (15:47 +0200)]
gidle: work around nested leave/enter problem

Add the flag "leaving" which disables the mpd_glib_enter() function
while mpd_glib_leave() is running.

15 years agompdclient: set all idle events on disconnect
Max Kellermann [Sat, 10 Oct 2009 13:47:43 +0000 (15:47 +0200)]
mpdclient: set all idle events on disconnect

After a disconnect, all subsystems have to consider the "new data"
(i.e. nothing).

15 years agolist_window: disable support for second column on --enable-mini
Max Kellermann [Sat, 10 Oct 2009 13:47:35 +0000 (15:47 +0200)]
list_window: disable support for second column on --enable-mini

15 years agoscreen_keydef: call list_window_reset() after entering a command
Max Kellermann [Sat, 10 Oct 2009 12:50:57 +0000 (14:50 +0200)]
screen_keydef: call list_window_reset() after entering a command

15 years agoscreen_{play,keydef,text}: use list_window_set_cursor()
Max Kellermann [Fri, 9 Oct 2009 20:34:04 +0000 (22:34 +0200)]
screen_{play,keydef,text}: use list_window_set_cursor()

Don't write list_window.selected directly.

15 years agolist_window: moved code to list_window_fetch_cursor()
Max Kellermann [Fri, 9 Oct 2009 20:28:45 +0000 (22:28 +0200)]
list_window: moved code to list_window_fetch_cursor()

Merged code from screen_play.c and list_window_scroll_up(),
list_window_scroll_down().

15 years agolist_window: splitted function list_window_set_selected()
Max Kellermann [Fri, 9 Oct 2009 20:13:53 +0000 (22:13 +0200)]
list_window: splitted function list_window_set_selected()

list_window_set_selected() becomes list_window_move_cursor().
list_window_set_cursor() is the new public function, which sets the
cursor and disables range selection.

15 years agoscreen_text: start searching at window origin, not bottom
Max Kellermann [Fri, 9 Oct 2009 20:08:10 +0000 (22:08 +0200)]
screen_text: start searching at window origin, not bottom

Don't add "text->lw->rows" to the window origin.  This won't find text
displayed on the screen.  This patch affects the lyrics screen.

15 years agoscreen_play: repaint after the "select-playing" command
Max Kellermann [Fri, 9 Oct 2009 19:59:07 +0000 (21:59 +0200)]
screen_play: repaint after the "select-playing" command

When the cursor moves, we have to repaint the list.

15 years agolist_window: fix narrow cursor drawing
Max Kellermann [Fri, 9 Oct 2009 19:24:00 +0000 (21:24 +0200)]
list_window: fix narrow cursor drawing

When there's a second column (e.g. in the playlist screen), the space
between the two columns isn't cleared properly, because the cursor
position was changed by the second column renderer.

Side effect of this patch: space drawing is a little bit optimized,
because it won't clear the second column (in wide-cursor mode) only to
draw the second column text on top of it.

15 years agolist_window: optimize second column drawing
Max Kellermann [Fri, 9 Oct 2009 19:23:03 +0000 (21:23 +0200)]
list_window: optimize second column drawing

Paint the space with waddch() instead of waddstr().  Removed the
second cursor movement, it's redundant.

15 years agolist_window: moved code to list_window_paint_row()
Max Kellermann [Fri, 9 Oct 2009 18:54:27 +0000 (20:54 +0200)]
list_window: moved code to list_window_paint_row()

15 years agolist_window: simplified the selection painting code
Max Kellermann [Fri, 9 Oct 2009 18:48:19 +0000 (20:48 +0200)]
list_window: simplified the selection painting code

Combine all the checks in the two boolean variables "show_cursor" and
"selected".

15 years agolist_window: removed the list_window_t typedef
Max Kellermann [Fri, 9 Oct 2009 18:28:25 +0000 (20:28 +0200)]
list_window: removed the list_window_t typedef

Use the plain struct name "list_window".

15 years agolist_window: don't allow list_window_free(NULL)
Max Kellermann [Fri, 9 Oct 2009 18:27:43 +0000 (20:27 +0200)]
list_window: don't allow list_window_free(NULL)

Also don't clear the list_window object.