diff options
Diffstat (limited to 'TODO')
-rw-r--r-- | TODO | 245 |
1 files changed, 245 insertions, 0 deletions
@@ -0,0 +1,245 @@ +- command bits and pieces: + * allow multiple targets: fnmatch for -t/-c, for example detach all + clients with -t* + * ' and " should be parsed the same (eg "\e" vs '\e') in config + and command prompt + * last-pane across sessions + * resize-pane -p to match split-window -p + * flag to wait-for to have a timeout and/or to stop waiting when the + client gets a signal + +- make command sequences more usable + * don't require space after ; + * options for error handling: && and ||? + +- options bits and pieces: + * way to set socket path from config file + +- format improvements: + * some way to pad # stuff with spaces + * formats to show if a window is linked into multiple sessions, into + multiple attached sessions, and is the active window in multiple + attached sessions? + * comparison operators like < and > (for #{version}?) + +- improve monitor-*: + * straighten out rules for multiple clients + * think about what happens across sessions + * monitor changes within a region + * perhaps monitor /all/ panes in the window not just one + +- improve mouse support: + * bind commands to mouse in different areas? + * commands executed when clicking on a pattern (URL) + +- warts on current naming: + * display-time but message-fg/bg/attr + * list-* vs show-* + +- copy/paste improvements: + * paste w/o trailing whitespace + * command to toggle selection not to move it in copy-mode + * regex searching + * searching in copy mode should unwrap lines, so if you search for "foobar" + then it should be found even if it is now "foo\nbar" (if the WRAP flag + is set on the line) + * capture-pane option to preserve spaces but not join lines + * improve word and line selection in copy mode (for example when + dragging it should select by word. compare how xterm works. GitHub + issue 682) + * key to search for word under cursor (GitHub issue 1240) + * when entering copy mode, should copy grid so that input does not + need to be suspended + * allow the prefix for automatic buffers to be specified as part of the + key binding to allow session buffers or similar (GitHub issue 1501) + * copy-pipe should be synchronous (GitHub issue 1517) + +- layout stuff + * way to tag a layout as a number/name + * maybe keep last layout + size around and if size reverts just put it + back + * revamp layouts: they are too complicated, should be more closely + integrated, should support hints, layout sets should just be a + special case of custom layouts, and we should support panes that are + not attached to a cell at all. this could be the time to introduce + panelink to replace layout_cell + * way to set hints/limits about pane size for resizing + * a mode where one application can cross two panes (ie x|y, width = + COLUMNS/2 but height = ROWS * 2) + * separate active panes for different clients + * way to choose where the freed space goes when a pane is killed: + option to kill-pane? GitHub issue 918 + +- code cleanup + * instead of separate window and session options, just one master + options list with each option having a type (window or session), then + options on window, on session, and global. for window options we look + window->session->global, and for session we look session->global. + problem: what about windows in multiple sessions? there are contexts + where we do not know which session, or where multiple choices makes + no sense... could at least have one global list for all types of + global options and keep separate window,session lists + * the way pane, window, session destroy is handled is too complicated + and the distinction between session.c, window.c and server-fn.c + functions is not clear. could we just have kill_pane(), + kill_window(), unlink_window(), kill_session() that fix up all data + structures (flagging sessions as dead) and return a value to say + whether clients need to be checked for dead sessions? sort of like + session_detach now but more so. or some other scheme to make it + simpler and clearer? also would be nice to remove/rename server-fn.c + * more readable way to work out the various things commands need to + know about the client, notably: + - is this the config file? (cmdq->c == NULL) + - is this a command client? (cmdq->c != NULL && + cmdq->c->session == NULL) + - is this a control client? + - can i do stdin or stdout to this client? + or even guarantee that cmdq->c != NULL and provide a better way to + tell when in the config file - then we use cmdq->c if we need a + client w/o a session else cmd_current_client + +- miscellaneous + * link panes into multiple windows + * live update: server started with -U connects to server, requests + sessions and windows, receives file descriptors + * there are inconsistencies in what we get from old shell and what + comes from config for new sessions and windows. likewise, panes and + jobs and run-shell and lock command all start with slightly different + environments + * multiline status line? separate command prompt and status line? + * automatic pane logging + * marks in history, automatically add (move?) one when pane is changed + * this doesn't work, need pane reference count probably: + bind -n DoubleClick3Status confirm-before -p "kill-window #I? (y/n)" kill-window + * marker lines in history (GitHub issue 1042) + * tree mode stuff: make command prompt (:) common code so all modes get it, + predefined filters, tag-all key, ... + * drag panes and windows around to move/swap them in choose mode + * flag to specify environment to new-window, split-window, + new-session (issue 1498) + * multiple column panes (issue 1503) + * support for ZERO WIDTH JOINER U+200D + +- hooks + * more hooks for various things + * finish after hooks for special commands. these do not have a hook at + the moment: + attach-session detach-client kill-server respawn-window + swap-window break-pane find-window kill-session rotate-window + switch-client choose-tree if-shell kill-window run-shell + wait-for command-prompt join-pane move-window source-file + confirm-before kill-pane respawn-pane swap-pane + at the moment AFTERHOOK uses current only if target is not valid, + but target is ALWAYS valid - it should use current if no -t flag? + then select-* could use AFTERHOOK + * multiple hooks with the same name? + * finish hooks for notifys + * for session_closed, if no sessions at all, perhaps fake up a + temporary one + +- pan + * tty_window_offset should try to keep as much off active pane + visible as possible + * rather than centering cursor it might be better if only + moved offset when it gets close to an edge? + +---- + +TODO soonish maybe: + +- Horizontal cursor position is incorrect after resize (bug), issue 1323. +- Multiple status lines: + + 1) Extend formats to include some way to loop over every window + (or pane or session), perhaps something like + #{W:#{window_name} }. It would need to be able to reach + into a window's options in order to allow different windows + to have different format. (DONE) An operator to evaluate an + option value as a format, maybe make it so E: on evaluates + the result as a format again something like, so end up with + something like #{W:#{E:window-status-format} } + + 2) Some way to include alignment information for part of a format. + + 3) Then the entire status line can be drawn with one option, + instead of status-left/status-right. But how to stay + backwards compatible, even slightly? Can probably keep + status-left and right and the default status-format becomes + something like (plus some bits for current window): + + #{L:#{E:status-left} #{M:#{W:{E:window-status-format}}} #{R:#{E:status-right}} + + Where L = left, M = middle, R = right; W = for each window; + E = get option value and evaluate as format. + + 4) Also need a way to return mouse positioning, so a format + like the alignment that stores the offset/size for + Mouse*Status{Left,Right}. + + 5) Likewise, styles. Alignment, mouse, styles can all be done + similarly - format_expand can be given the available width + and then build a list of format_range with type (ALIGN_LEFT, + STYLE, MOUSE_LEFT and so on) which a format_draw function + can use to draw the format, and can be stored to be used by + the mouse positioning check code. + +(DONE) 6) status-left-length and similar will need to be taken into + account. + + 7) Supporting trimming the window list and adding <> might be + tricky, probably a second pass over the format_range list to + trim as appropriate. But it will need to know which element + to trim first, so some way to mark that is needed (maybe a + priority or something in the alignment/length limit). + +(DONE) 8) Formats are going to get very long so perhaps standardize + them a bit so they are all something like #{F/argument:text} + then then could be #{A/foo;B/bar:text} rather than + #{A:foo,#{B:bar,text}} and so on. Need to keep the old style + for compatibility, at least for the most popular formats. So + the status-left part would be something like: + + #{A/left;S/#{status-left-style};M/left;=/#{status-left-length};E:status-left} + + Where A = alignment, S = style, M = mouse, = = length limit, + E = expand again. + + Existing formats are: + + #{l:foo} <-- literal + #{m:foo} <-- match + #{C:foo} <-- search + #{b:foo} <-- basename + #{d:foo} <-- dirname + #{t:foo} <-- time + #{q:foo} <-- quote + #{s/a/b/:foo} <-- sub + #{=123:foo} <-- length + + #{||:foo,bar} <-- or + #{&&:foo,bar} <-- and + #{!=:foo,bar} <-- neq + #{==:foo,bar} <-- eq + #{?foo,bar,baz} <-- if + + So comparisons and ? can stay as they are. + + All other formats can be parsed as #{X/arg1/arg2/arg3:...} + with an optional leading and trailing /. Each argument can + be expanded. + + 9) Then status-format can be an array option specifying + multiple status lines. Perhaps one option for top and one + for bottom. + +- Store hooks as options, issue 1619. +- Support buffer prefixes, issue 1501. +- copy-pipe should be synchronous, issue 1517. +- -E flag to pass environment to new-*, issue 1498. +- Copy mode searching is slow when there is a big history, issue 1545. +- Grid "block" stuff - some work done, there is an issue + somewhere. Can be used potentially for compression of history (bit + silly really though), reflow performance (can reflow blocks on + demand). It would possibly be good if history-limit could be global + and collected LRU. + |