mirror of
https://github.com/tmux/tmux.git
synced 2024-11-18 10:28:54 +00:00
160 lines
7.1 KiB
Plaintext
160 lines
7.1 KiB
Plaintext
- command bits and pieces:
|
|
* why doesn't command-prompt work if made read-only?
|
|
* allow multiple targets: fnmatch for -t/-c, for example detach all
|
|
clients with -t*
|
|
* add -c for new-session like new-window
|
|
* attach should take a pane and select it as well as attaching
|
|
* ' and " should be parsed the same (eg "\e" vs '\e') in config
|
|
and command prompt
|
|
* last-pane across sessions
|
|
* exact match operator for targets (or break the substring match
|
|
and require eg x* instead of just x)
|
|
|
|
- make command sequences more usable
|
|
* don't require space after ;
|
|
* options for error handling: && and ||?
|
|
|
|
- options bits and pieces:
|
|
* set-remain-on-exit is a complete hack
|
|
* way to set socket path from config file
|
|
|
|
- format improvements:
|
|
* last bits of status_replace into formats?
|
|
* option to quote format (#{session_name:quoted})
|
|
* formats need conditions for >0 (for #P)
|
|
* some way to pad # stuff with spaces, #!2T maybe
|
|
* last window update time and format for it
|
|
* 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?)
|
|
* choose-mode and copy-mode are very similar, make choose-mode a subset?
|
|
* flag to choose-* for sort order
|
|
* choose mode would be better per client than per window?
|
|
* two choices (first one then second, for swap-pane and join-pane)
|
|
|
|
- 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?
|
|
* more fine-grained options?
|
|
* commands executed when clicking on a pattern (URL)
|
|
* mouse-select-pane will screw up with !MODE_MOUSE_STANDARD (it sets
|
|
the flag on w/o checking the others before calling tty_update_mode)
|
|
* mouse can be like normal key bindings?
|
|
- {button-{1,2,3},wheel-{up,down}}-{status,pane,border} and
|
|
drag-{start,end}-{status,pane,border} plus the modifiers
|
|
- resize and copy can be special cases - once you call something
|
|
like copy-mode -M or resize-pane -M to start the drag, it tracks
|
|
mouse until you call -m to stop the drag. or just keep drags
|
|
entirely special?
|
|
- what happens with stuff that wants mouse inside? especially for
|
|
pane clicks which need to run command AND pass event through
|
|
(like mouse-select-pane). maybe just a flag to say whether it
|
|
always runs or only if pane hasn't taken mouse? or it could be
|
|
eg bind Button1Pane "select-pane -t=; send-keys -Mt='
|
|
- also need a) some way to tell commands bound to key which
|
|
window or pane the mouse key binding applies to (maybe a new
|
|
special char in target, or pass targets through formats?) b) a
|
|
way to bind repeat count to mode keys so that wheel up/down can
|
|
do multiple lines c) send-keys -M to pass a mouse event through?
|
|
- what does the mouse->KEYC_* conversion and find-the-pane bit?
|
|
server_client_handle_key?
|
|
|
|
- hooks!
|
|
|
|
- warts on current naming:
|
|
* display-time but message-fg/bg/attr
|
|
* list-* vs show-*
|
|
* split-window -> split-pane??
|
|
|
|
- better UTF-8 support:
|
|
* window names and titles
|
|
* message display
|
|
* prompt input
|
|
* multibyte key input
|
|
|
|
- copy/paste improvements:
|
|
* incremental searching
|
|
* append to buffer
|
|
* paste w/o trailing whitespace
|
|
* command to toggle selection not to move it in copy-mode
|
|
* regex searching
|
|
|
|
- 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)
|
|
* general key to space cells out evenly (horiz or vert) within their
|
|
parent cell (could replace even-vert/even-horiz layouts)
|
|
* separate active panes for different clients
|
|
|
|
- terminfo bits
|
|
* use a better termcap internally instead of screen, perhaps xterm
|
|
* use screen-256color when started on 256 colour terminal?
|
|
* need a tmux terminfo entry to document the extensions we are using in
|
|
upstream terminfo
|
|
|
|
- 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
|
|
* 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
|
|
* optimize pane redraws, 20120318184853.GK10965@yelena.nicm.ath.cx
|
|
* cmd_find_* could be much simpler - parse everything the same, only
|
|
difference is what to choose when not given a ":" or "." (such as a
|
|
plain "0" could be session, window or pane). So just cmd_find_target
|
|
with a type (session, window, or pane)
|
|
* instead of all the obscure =, ^ -t codes, we should support something
|
|
simpler and easier like -t:mouse:, -t:first:
|
|
|
|
- miscellaneous
|
|
* way to keep a job running just read its last line of output for #()
|
|
* 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?
|
|
* bind commands to key sequences -- make it so ALL keys go through a
|
|
table, first an implicit table in which C-b is the only default
|
|
binding to a command that says "next key from $othertable" and so
|
|
on. means -n can go away as well
|
|
* customizable command aliases
|
|
* any remaining clients in wait-for should be woken when server exits
|