[Script] Strip pango markup when matching rows (#1795)

This is effectively the same fix that was made to DMenu in
a42e9f869f.
This commit is contained in:
Tim Pope 2023-01-29 15:30:36 -05:00 committed by GitHub
parent fb7c8c71ef
commit 215e55408f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 26 additions and 12 deletions

View File

@ -444,22 +444,36 @@ static char *_get_display_value(const Mode *sw, unsigned int selected_line,
static int script_token_match(const Mode *sw, rofi_int_matcher **tokens, static int script_token_match(const Mode *sw, rofi_int_matcher **tokens,
unsigned int index) { unsigned int index) {
ScriptModePrivateData *rmpd = sw->private_data; ScriptModePrivateData *rmpd = sw->private_data;
int match = 1; /** Strip out the markup when matching. */
if (tokens) { char *esc = NULL;
for (int j = 0; match && tokens[j] != NULL; j++) { if (rmpd->do_markup) {
rofi_int_matcher *ftokens[2] = {tokens[j], NULL}; pango_parse_markup(rmpd->cmd_list[index].entry, -1, 0, NULL, &esc, NULL,
int test = 0; NULL);
test = helper_token_match(ftokens, rmpd->cmd_list[index].entry); } else {
if (test == tokens[j]->invert && rmpd->cmd_list[index].meta) { esc = rmpd->cmd_list[index].entry;
test = helper_token_match(ftokens, rmpd->cmd_list[index].meta); }
} if (esc) {
int match = 1;
if (tokens) {
for (int j = 0; match && tokens[j] != NULL; j++) {
rofi_int_matcher *ftokens[2] = {tokens[j], NULL};
int test = 0;
test = helper_token_match(ftokens, esc);
if (test == tokens[j]->invert && rmpd->cmd_list[index].meta) {
test = helper_token_match(ftokens, rmpd->cmd_list[index].meta);
}
if (test == 0) { if (test == 0) {
match = 0; match = 0;
}
} }
} }
if (rmpd->do_markup) {
g_free(esc);
}
return match;
} }
return match; return FALSE;
} }
static char *script_get_message(const Mode *sw) { static char *script_get_message(const Mode *sw) {
ScriptModePrivateData *pd = sw->private_data; ScriptModePrivateData *pd = sw->private_data;