| - 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. |
| |