aboutsummaryrefslogtreecommitdiff
path: root/mode-tree.c
diff options
context:
space:
mode:
authorNicholas Marriott <nicholas.marriott@gmail.com>2020-05-12 08:57:55 +0100
committerNicholas Marriott <nicholas.marriott@gmail.com>2020-05-12 08:57:55 +0100
commit5a34f51d337aefa723d3e5366727f88c723b293a (patch)
treeb9221653b0593f8c696ab4dc5826d957ef84f16a /mode-tree.c
parentc489bf0a1e5d1ef7dfd886a95b638fa7bfa1fbe2 (diff)
downloadrtmux-5a34f51d337aefa723d3e5366727f88c723b293a.tar.gz
rtmux-5a34f51d337aefa723d3e5366727f88c723b293a.tar.bz2
rtmux-5a34f51d337aefa723d3e5366727f88c723b293a.zip
Include key bindings in customize mode.
Diffstat (limited to 'mode-tree.c')
-rw-r--r--mode-tree.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/mode-tree.c b/mode-tree.c
index 9ed2e102..0b454468 100644
--- a/mode-tree.c
+++ b/mode-tree.c
@@ -80,6 +80,7 @@ struct mode_tree_item {
int expanded;
int tagged;
+ int draw_as_parent;
struct mode_tree_list children;
TAILQ_ENTRY(mode_tree_item) entry;
@@ -248,6 +249,12 @@ mode_tree_get_current(struct mode_tree_data *mtd)
return (mtd->line_list[mtd->current].item->itemdata);
}
+const char *
+mode_tree_get_current_name(struct mode_tree_data *mtd)
+{
+ return (mtd->line_list[mtd->current].item->name);
+}
+
void
mode_tree_expand_current(struct mode_tree_data *mtd)
{
@@ -257,6 +264,15 @@ mode_tree_expand_current(struct mode_tree_data *mtd)
}
}
+void
+mode_tree_collapse_current(struct mode_tree_data *mtd)
+{
+ if (mtd->line_list[mtd->current].item->expanded) {
+ mtd->line_list[mtd->current].item->expanded = 0;
+ mode_tree_build(mtd);
+ }
+}
+
static int
mode_tree_get_tag(struct mode_tree_data *mtd, uint64_t tag, u_int *found)
{
@@ -544,6 +560,12 @@ mode_tree_add(struct mode_tree_data *mtd, struct mode_tree_item *parent,
}
void
+mode_tree_draw_as_parent(struct mode_tree_item *mti)
+{
+ mti->draw_as_parent = 1;
+}
+
+void
mode_tree_remove(struct mode_tree_data *mtd, struct mode_tree_item *mti)
{
struct mode_tree_item *parent = mti->parent;
@@ -683,6 +705,8 @@ mode_tree_draw(struct mode_tree_data *mtd)
line = &mtd->line_list[mtd->current];
mti = line->item;
+ if (mti->draw_as_parent)
+ mti = mti->parent;
screen_write_cursormove(&ctx, 0, h, 0);
screen_write_box(&ctx, w, sy - h);