Compare commits

..

No commits in common. "24449fe721dfa6cf2bd1fe41ea0f0106efef0d91" and "20502200d9450cbbf6701ac726af247c3d5f63c6" have entirely different histories.

3 changed files with 2 additions and 34 deletions

2
NEWS
View File

@ -1,6 +1,6 @@
Unreleased
* Made global search indicate the search terms, and match on filenames
* Made global search indicate the search terms
2.1.1 (2024-02-27)

@ -1 +1 @@
Subproject commit 8a8437634a2dc58768172f481ccf3c6637745d46
Subproject commit 969a4cfc3ea1c4d7c0327907385fc64906ed5d4c

View File

@ -3616,21 +3616,6 @@ out:
free (filter);
}
static char *
mpd_quoted_filter_string (const char *value)
{
struct str quoted = str_make ();
str_append_c (&quoted, '\'');
for (const char *p = value; *p; p++)
{
if (mpd_client_must_escape_in_quote (*p))
str_append_c (&quoted, '\\');
str_append_c (&quoted, *p);
}
str_append_c (&quoted, '\'');
return str_steal (&quoted);
}
static void
search_on_changed (void)
{
@ -3638,25 +3623,8 @@ search_on_changed (void)
size_t 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);
// 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_idle (c, 0);
}