Compare commits
2 Commits
20502200d9
...
24449fe721
Author | SHA1 | Date | |
---|---|---|---|
24449fe721 | |||
60171cc5a3 |
2
NEWS
2
NEWS
@ -1,6 +1,6 @@
|
|||||||
Unreleased
|
Unreleased
|
||||||
|
|
||||||
* Made global search indicate the search terms
|
* Made global search indicate the search terms, and match on filenames
|
||||||
|
|
||||||
|
|
||||||
2.1.1 (2024-02-27)
|
2.1.1 (2024-02-27)
|
||||||
|
2
liberty
2
liberty
@ -1 +1 @@
|
|||||||
Subproject commit 969a4cfc3ea1c4d7c0327907385fc64906ed5d4c
|
Subproject commit 8a8437634a2dc58768172f481ccf3c6637745d46
|
32
nncmpp.c
32
nncmpp.c
@ -3616,6 +3616,21 @@ out:
|
|||||||
free (filter);
|
free (filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static char *
|
||||||
|
mpd_quoted_filter_string (const char *value)
|
||||||
|
{
|
||||||
|
struct str quoted = str_make ();
|
||||||
|
str_append_c ("ed, '\'');
|
||||||
|
for (const char *p = value; *p; p++)
|
||||||
|
{
|
||||||
|
if (mpd_client_must_escape_in_quote (*p))
|
||||||
|
str_append_c ("ed, '\\');
|
||||||
|
str_append_c ("ed, *p);
|
||||||
|
}
|
||||||
|
str_append_c ("ed, '\'');
|
||||||
|
return str_steal ("ed);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
search_on_changed (void)
|
search_on_changed (void)
|
||||||
{
|
{
|
||||||
@ -3623,8 +3638,25 @@ search_on_changed (void)
|
|||||||
|
|
||||||
size_t len;
|
size_t len;
|
||||||
char *u8 = (char *) u32_to_u8 (g.editor.line, g.editor.len + 1, NULL, &len);
|
char *u8 = (char *) u32_to_u8 (g.editor.line, g.editor.len + 1, NULL, &len);
|
||||||
|
mpd_client_list_begin (c);
|
||||||
mpd_client_send_command (c, "search", "any", u8, NULL);
|
mpd_client_send_command (c, "search", "any", u8, NULL);
|
||||||
|
|
||||||
|
// Just tag search doesn't consider filenames.
|
||||||
|
// Older MPD can do `search any X file X` but without the negation,
|
||||||
|
// which is necessary to avoid duplicates. Neither syntax supports OR.
|
||||||
|
// XXX: We should parse this, but it's probably not going to reach 100 soon,
|
||||||
|
// and it is not really documented what this should even look like.
|
||||||
|
if (strcmp (c->got_hello, "0.21.") > 1)
|
||||||
|
{
|
||||||
|
char *quoted = mpd_quoted_filter_string (u8);
|
||||||
|
char *expression = xstrdup_printf ("((!(any contains %s)) AND "
|
||||||
|
"(file contains %s))", quoted, quoted);
|
||||||
|
mpd_client_send_command (c, "search", expression, NULL);
|
||||||
|
free (expression);
|
||||||
|
free (quoted);
|
||||||
|
}
|
||||||
|
|
||||||
|
mpd_client_list_end (c);
|
||||||
mpd_client_add_task (c, library_tab_on_search_data, u8);
|
mpd_client_add_task (c, library_tab_on_search_data, u8);
|
||||||
mpd_client_idle (c, 0);
|
mpd_client_idle (c, 0);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user