Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/external/bsd/tmux merge conflicts
details: https://anonhg.NetBSD.org/src/rev/b68c81861b20
branches: trunk
changeset: 1006245:b68c81861b20
user: christos <christos%NetBSD.org@localhost>
date: Mon Jan 06 21:03:23 2020 +0000
description:
merge conflicts
diffstat:
external/bsd/tmux/dist/TODO | 161 --
external/bsd/tmux/dist/client.c | 18 +-
external/bsd/tmux/dist/cmd-attach-session.c | 29 +-
external/bsd/tmux/dist/cmd-display-message.c | 18 +-
external/bsd/tmux/dist/cmd-if-shell.c | 109 +-
external/bsd/tmux/dist/cmd-list.c | 126 -
external/bsd/tmux/dist/cmd-load-buffer.c | 4 +-
external/bsd/tmux/dist/cmd-new-session.c | 119 +-
external/bsd/tmux/dist/cmd-new-window.c | 120 +-
external/bsd/tmux/dist/cmd-parse.c | 2056 --------------------------
external/bsd/tmux/dist/cmd-parse.y | 2 +-
external/bsd/tmux/dist/cmd-queue.c | 161 +-
external/bsd/tmux/dist/cmd-send-keys.c | 92 +-
external/bsd/tmux/dist/cmd-set-hook.c | 133 -
external/bsd/tmux/dist/cmd-show-options.c | 206 +-
external/bsd/tmux/dist/cmd-split-window.c | 172 +-
external/bsd/tmux/dist/cmd-string.c | 390 ----
external/bsd/tmux/dist/cmd-wait-for.c | 8 +-
external/bsd/tmux/dist/colour.c | 84 +-
external/bsd/tmux/dist/compat/fparseln.c | 216 --
external/bsd/tmux/dist/environ.c | 12 +-
external/bsd/tmux/dist/format.c | 402 ++++-
external/bsd/tmux/dist/grid.c | 51 +-
external/bsd/tmux/dist/hooks.c | 173 --
external/bsd/tmux/dist/input-keys.c | 7 +
external/bsd/tmux/dist/input.c | 96 +-
external/bsd/tmux/dist/job.c | 2 +-
external/bsd/tmux/dist/key-bindings.c | 89 +-
external/bsd/tmux/dist/menu.c | 6 +-
external/bsd/tmux/dist/mode-tree.c | 144 +-
external/bsd/tmux/dist/notify.c | 80 +-
external/bsd/tmux/dist/options.c | 390 +++-
external/bsd/tmux/dist/paste.c | 9 +-
external/bsd/tmux/dist/regsub.c | 4 +-
external/bsd/tmux/dist/screen-write.c | 80 +-
external/bsd/tmux/dist/server-client.c | 304 ++-
external/bsd/tmux/dist/server-fn.c | 9 +-
external/bsd/tmux/dist/session.c | 71 +-
external/bsd/tmux/dist/spawn.c | 2 +-
external/bsd/tmux/dist/status.c | 149 +-
external/bsd/tmux/dist/style.c | 20 +-
external/bsd/tmux/dist/tmux.1 | 1194 ++++++++++----
external/bsd/tmux/dist/tmux.c | 9 +-
external/bsd/tmux/dist/tmux.h | 370 +++-
external/bsd/tmux/dist/tty-acs.c | 8 +-
external/bsd/tmux/dist/tty-keys.c | 72 +-
external/bsd/tmux/dist/tty-term.c | 15 +-
external/bsd/tmux/dist/tty.c | 206 ++-
external/bsd/tmux/dist/utf8.c | 29 +-
external/bsd/tmux/dist/window-buffer.c | 55 +-
external/bsd/tmux/dist/window-client.c | 32 +-
external/bsd/tmux/dist/window-copy.c | 1929 ++++++++++++++++++------
external/bsd/tmux/dist/window-tree.c | 49 +-
external/bsd/tmux/dist/window.c | 461 ++---
external/bsd/tmux/usr.bin/tmux/Makefile | 17 +-
55 files changed, 5152 insertions(+), 5618 deletions(-)
diffs (truncated from 15593 to 300 lines):
diff -r ca1043eda9fb -r b68c81861b20 external/bsd/tmux/dist/TODO
--- a/external/bsd/tmux/dist/TODO Mon Jan 06 20:40:36 2020 +0000
+++ /dev/null Thu Jan 01 00:00:00 1970 +0000
@@ -1,161 +0,0 @@
-- 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
- * individual pane synchronize-panes (with pane options?); issue 1638
-
-- 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:
-
-- 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, issue 1269. 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.
-- Command aliases should be able to override builtin commands in order to add
- default flags (some mechanism needed to avoid recursion). GitHub issue 1630.
diff -r ca1043eda9fb -r b68c81861b20 external/bsd/tmux/dist/client.c
--- a/external/bsd/tmux/dist/client.c Mon Jan 06 20:40:36 2020 +0000
+++ b/external/bsd/tmux/dist/client.c Mon Jan 06 21:03:23 2020 +0000
@@ -202,7 +202,7 @@
case CLIENT_EXIT_TERMINATED:
return ("terminated");
case CLIENT_EXIT_LOST_SERVER:
- return ("lost server");
+ return ("server exited unexpectedly");
case CLIENT_EXIT_EXITED:
return ("exited");
case CLIENT_EXIT_SERVER_EXITED:
@@ -215,14 +215,13 @@
int
client_main(struct event_base *base, int argc, char **argv, int flags)
{
+ struct cmd_parse_result *pr;
struct cmd *cmd;
- struct cmd_list *cmdlist;
struct msg_command_data *data;
int cmdflags, fd, i;
const char *ttynam, *cwd;
pid_t ppid;
enum msgtype msg;
- char *cause;
struct termios tio, saved_tio;
size_t size;
@@ -248,14 +247,15 @@
* later in server) but it is necessary to get the start server
* flag.
*/
- cmdlist = cmd_list_parse(argc, argv, NULL, 0, &cause);
- if (cmdlist != NULL) {
- TAILQ_FOREACH(cmd, &cmdlist->list, qentry) {
+ pr = cmd_parse_from_arguments(argc, argv, NULL);
+ if (pr->status == CMD_PARSE_SUCCESS) {
+ TAILQ_FOREACH(cmd, &pr->cmdlist->list, qentry) {
if (cmd->entry->flags & CMD_STARTSERVER)
cmdflags |= CMD_STARTSERVER;
}
- cmd_list_free(cmdlist);
- }
+ cmd_list_free(pr->cmdlist);
+ } else
+ free(pr->error);
}
/* Create client process structure (starts logging). */
@@ -436,7 +436,7 @@
struct msg_stdin_data data;
data.size = read(STDIN_FILENO, data.data, sizeof data.data);
- if (data.size < 0 && (errno == EINTR || errno == EAGAIN))
+ if (data.size == -1 && (errno == EINTR || errno == EAGAIN))
return;
proc_send(client_peer, MSG_STDIN, -1, &data, sizeof data);
diff -r ca1043eda9fb -r b68c81861b20 external/bsd/tmux/dist/cmd-attach-session.c
--- a/external/bsd/tmux/dist/cmd-attach-session.c Mon Jan 06 20:40:36 2020 +0000
+++ b/external/bsd/tmux/dist/cmd-attach-session.c Mon Jan 06 21:03:23 2020 +0000
@@ -37,8 +37,8 @@
.name = "attach-session",
.alias = "attach",
- .args = { "c:dErt:", 0, 0 },
- .usage = "[-dEr] [-c working-directory] " CMD_TARGET_SESSION_USAGE,
+ .args = { "c:dErt:x", 0, 0 },
+ .usage = "[-dErx] [-c working-directory] " CMD_TARGET_SESSION_USAGE,
/* -t is special */
@@ -48,7 +48,7 @@
enum cmd_retval
cmd_attach_session(struct cmdq_item *item, const char *tflag, int dflag,
- int rflag, const char *cflag, int Eflag)
+ int xflag, int rflag, const char *cflag, int Eflag)
{
struct cmd_find_state *current = &item->shared->current;
enum cmd_find_type type;
@@ -58,6 +58,7 @@
struct winlink *wl;
struct window_pane *wp;
char *cause;
+ enum msgtype msgtype;
if (RB_EMPTY(&sessions)) {
cmdq_error(item, "no sessions");
@@ -87,7 +88,7 @@
if (wl != NULL) {
if (wp != NULL)
- window_set_active_pane(wp->window, wp);
+ window_set_active_pane(wp->window, wp, 1);
session_set_current(s, wl);
if (wp != NULL)
cmd_find_from_winlink_pane(current, wl, wp, 0);
@@ -102,11 +103,15 @@
c->last_session = c->session;
if (c->session != NULL) {
- if (dflag) {
+ if (dflag || xflag) {
+ if (xflag)
+ msgtype = MSG_DETACHKILL;
+ else
+ msgtype = MSG_DETACH;
TAILQ_FOREACH(c_loop, &clients, entry) {
if (c_loop->session != s || c == c_loop)
continue;
- server_client_detach(c_loop, MSG_DETACH);
+ server_client_detach(c_loop, msgtype);
}
}
if (!Eflag)
@@ -131,11 +136,15 @@
if (rflag)
c->flags |= CLIENT_READONLY;
- if (dflag) {
+ if (dflag || xflag) {
+ if (xflag)
+ msgtype = MSG_DETACHKILL;
+ else
+ msgtype = MSG_DETACH;
TAILQ_FOREACH(c_loop, &clients, entry) {
if (c_loop->session != s || c == c_loop)
continue;
- server_client_detach(c_loop, MSG_DETACH);
+ server_client_detach(c_loop, msgtype);
}
}
if (!Eflag)
@@ -169,6 +178,6 @@
Home |
Main Index |
Thread Index |
Old Index