mirror of
https://github.com/tmux/tmux.git
synced 2025-01-07 16:28:48 +00:00
147 lines
6.4 KiB
Plaintext
147 lines
6.4 KiB
Plaintext
- command bits and pieces:
|
|
* allow multiple targets: fnmatch for -t/-c, for example detach all
|
|
clients with -t*
|
|
* add -c for new-session like new-window
|
|
* ' 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:
|
|
* option to quote format (#{q:session_name})
|
|
* 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?
|
|
|
|
- choose mode improvements:
|
|
* choose-pane command (augment choose-tree to do this?)
|
|
* flag to choose-* for sort order
|
|
* two choices (first one then second, for swap-pane and join-pane)
|
|
* choose modes should ditch the key bindings and just have fixed keys, and
|
|
be more customized to their purpose (d to delete a buffer for choose-buffer,
|
|
a preview of buffer contents, etc)
|
|
|
|
- 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)
|
|
|
|
- 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
|
|
* panning over window (window larger than visible)
|
|
* 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
|
|
|
|
- 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
|
|
* respawn -c flag same as neww etc
|
|
|
|
- hooks
|
|
* more hooks for various things
|
|
* finish after hooks for special commands
|
|
* multiple hooks with the same name?
|
|
* finish hooks for notifys
|
|
* for session_closed, if no sessions at all, perhaps fake up a temporary one
|
|
|
|
- current target resolution is still confusing and probably wrong:
|
|
* what if I
|
|
bind -n DoubleClick1Pane selectp -U\; resizep -Z
|
|
and click on a pane that isn't the active pane? It should make the
|
|
pane above the one I clicked on active and zoom it
|
|
* bind q select-pane -U\; resize-pane -Z should do the obvious
|
|
* bind q neww\; splitw as well
|
|
* should we always start with a "current target" and commands can
|
|
update it?
|
|
* a few cases:
|
|
1) normal key bindings - fine, we always know the full target
|
|
but it is important that commands like neww and selectp
|
|
use the updated active window or pane;
|
|
2) mouse key binding - same, but needs to be the mouse target;
|
|
3) from a new client ("tmux whatever") - we may know the best
|
|
s,wl,wp from the pty, guess the client, or guess all if
|
|
we don't know;
|
|
4) hooks - we may know or we may not;
|
|
5) control mode - same as a key binding really, and not
|
|
specifying a target is stupid anyway;
|
|
6) if-shell/run-shell - may be able to preserve its target,
|
|
else guess.
|
|
* of course -t and -s override the current target as now.
|