aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorokan2017-12-07 16:03:10 +0000
committerokan2017-12-07 16:03:10 +0000
commitc41a4e4f8740a3150cb0ed54c5972e075f503b74 (patch)
tree4ffc2414fccd85793b0fca6c60575d9b5a2bb3cf
parent119bed3cf0313cb028627872f7f85a232019991d (diff)
downloadcwm-c41a4e4f8740a3150cb0ed54c5972e075f503b74.tar.gz
give command and group menus their own match callbacks
-rw-r--r--calmwm.h6
-rw-r--r--kbfunc.c11
-rw-r--r--search.c31
3 files changed, 40 insertions, 8 deletions
diff --git a/calmwm.h b/calmwm.h
index cabb85d..21fa3ae 100644
--- a/calmwm.h
+++ b/calmwm.h
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $OpenBSD: calmwm.h,v 1.342 2017/12/07 15:47:14 okan Exp $
+ * $OpenBSD: calmwm.h,v 1.343 2017/12/07 16:03:10 okan Exp $
*/
#ifndef _CALMWM_H_
@@ -444,6 +444,10 @@ void search_match_path(struct menu_q *, struct menu_q *,
char *);
void search_match_text(struct menu_q *, struct menu_q *,
char *);
+void search_match_cmd(struct menu_q *, struct menu_q *,
+ char *);
+void search_match_group(struct menu_q *, struct menu_q *,
+ char *);
void search_print_client(struct menu *, int);
void search_print_cmd(struct menu *, int);
void search_print_group(struct menu *, int);
diff --git a/kbfunc.c b/kbfunc.c
index a645f54..3959046 100644
--- a/kbfunc.c
+++ b/kbfunc.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $OpenBSD: kbfunc.c,v 1.151 2017/12/07 15:39:47 okan Exp $
+ * $OpenBSD: kbfunc.c,v 1.152 2017/12/07 16:03:10 okan Exp $
*/
#include <sys/types.h>
@@ -460,14 +460,13 @@ kbfunc_menu_cmd(void *ctx, struct cargs *cargs)
if ((strcmp(cmd->name, "lock") == 0) ||
(strcmp(cmd->name, "term") == 0))
continue;
- /* search_match_text() needs mi->text */
- menuq_add(&menuq, cmd, "%s", cmd->name);
+ menuq_add(&menuq, cmd, NULL);
}
if ((mi = menu_filter(sc, &menuq,
(m) ? NULL : "application", NULL,
((m) ? CWM_MENU_LIST : 0),
- search_match_text, search_print_cmd)) != NULL) {
+ search_match_cmd, search_print_cmd)) != NULL) {
cmd = (struct cmd_ctx *)mi->ctx;
u_spawn(cmd->path);
}
@@ -488,12 +487,12 @@ kbfunc_menu_group(void *ctx, struct cargs *cargs)
TAILQ_FOREACH(gc, &sc->groupq, entry) {
if (group_holds_only_sticky(gc))
continue;
- menuq_add(&menuq, gc, "%d %s", gc->num, gc->name);
+ menuq_add(&menuq, gc, NULL);
}
if ((mi = menu_filter(sc, &menuq,
(m) ? NULL : "group", NULL, (CWM_MENU_LIST),
- search_match_text, search_print_group)) != NULL) {
+ search_match_group, search_print_group)) != NULL) {
gc = (struct group_ctx *)mi->ctx;
(group_holds_only_hidden(gc)) ?
group_show(gc) : group_hide(gc);
diff --git a/search.c b/search.c
index 607124b..b870c58 100644
--- a/search.c
+++ b/search.c
@@ -15,7 +15,7 @@
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
*
- * $OpenBSD: search.c,v 1.64 2017/12/07 15:40:54 okan Exp $
+ * $OpenBSD: search.c,v 1.65 2017/12/07 16:03:10 okan Exp $
*/
#include <sys/types.h>
@@ -129,6 +129,35 @@ search_match_client(struct menu_q *menuq, struct menu_q *resultq, char *search)
}
}
+void
+search_match_cmd(struct menu_q *menuq, struct menu_q *resultq, char *search)
+{
+ struct menu *mi;
+
+ TAILQ_INIT(resultq);
+ TAILQ_FOREACH(mi, menuq, entry) {
+ struct cmd_ctx *cmd = (struct cmd_ctx *)mi->ctx;
+ if (match_substr(search, cmd->name, 0))
+ TAILQ_INSERT_TAIL(resultq, mi, resultentry);
+ }
+}
+
+void
+search_match_group(struct menu_q *menuq, struct menu_q *resultq, char *search)
+{
+ struct menu *mi;
+ char *s;
+
+ TAILQ_INIT(resultq);
+ TAILQ_FOREACH(mi, menuq, entry) {
+ struct group_ctx *gc = (struct group_ctx *)mi->ctx;
+ xasprintf(&s, "%d %s", gc->num, gc->name);
+ if (match_substr(search, s, 0))
+ TAILQ_INSERT_TAIL(resultq, mi, resultentry);
+ free(s);
+ }
+}
+
static void
match_path_type(struct menu_q *resultq, char *search, int flag)
{