mirror of
https://github.com/tmux/tmux.git
synced 2025-01-27 16:48:49 +00:00
Merge branch 'obsd-master'
This commit is contained in:
commit
147b5ae514
34
format.c
34
format.c
@ -660,6 +660,8 @@ format_find(struct format_tree *ft, const char *key, int modifiers)
|
|||||||
return (NULL);
|
return (NULL);
|
||||||
|
|
||||||
found:
|
found:
|
||||||
|
if (found == NULL)
|
||||||
|
return (NULL);
|
||||||
copy = xstrdup(found);
|
copy = xstrdup(found);
|
||||||
if (modifiers & FORMAT_BASENAME) {
|
if (modifiers & FORMAT_BASENAME) {
|
||||||
saved = copy;
|
saved = copy;
|
||||||
@ -685,7 +687,7 @@ format_replace(struct format_tree *ft, const char *key, size_t keylen,
|
|||||||
char *copy, *copy0, *endptr, *ptr, *saved, *trimmed, *value;
|
char *copy, *copy0, *endptr, *ptr, *saved, *trimmed, *value;
|
||||||
size_t valuelen;
|
size_t valuelen;
|
||||||
u_long limit = 0;
|
u_long limit = 0;
|
||||||
int modifiers = 0;
|
int modifiers = 0, brackets;
|
||||||
|
|
||||||
/* Make a copy of the key. */
|
/* Make a copy of the key. */
|
||||||
copy0 = copy = xmalloc(keylen + 1);
|
copy0 = copy = xmalloc(keylen + 1);
|
||||||
@ -733,20 +735,26 @@ format_replace(struct format_tree *ft, const char *key, size_t keylen,
|
|||||||
goto fail;
|
goto fail;
|
||||||
*ptr = '\0';
|
*ptr = '\0';
|
||||||
|
|
||||||
value = saved = format_find(ft, copy + 1, modifiers);
|
|
||||||
if (value != NULL && *value != '\0' &&
|
|
||||||
(value[0] != '0' || value[1] != '\0')) {
|
|
||||||
value = ptr + 1;
|
|
||||||
ptr = strchr(value, ',');
|
|
||||||
if (ptr == NULL)
|
|
||||||
goto fail;
|
|
||||||
*ptr = '\0';
|
|
||||||
} else {
|
|
||||||
ptr = strchr(ptr + 1, ',');
|
|
||||||
if (ptr == NULL)
|
|
||||||
goto fail;
|
|
||||||
value = ptr + 1;
|
value = ptr + 1;
|
||||||
|
saved = format_find(ft, copy + 1, modifiers);
|
||||||
|
|
||||||
|
brackets = 0;
|
||||||
|
for (ptr = ptr + 1; *ptr != '\0'; ptr++) {
|
||||||
|
if (*ptr == '{')
|
||||||
|
brackets++;
|
||||||
|
if (*ptr == '}')
|
||||||
|
brackets--;
|
||||||
|
if (*ptr == ',' && brackets == 0)
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
|
if (*ptr == '\0')
|
||||||
|
goto fail;
|
||||||
|
|
||||||
|
if (saved != NULL && *saved != '\0' &&
|
||||||
|
(saved[0] != '0' || saved[1] != '\0')) {
|
||||||
|
*ptr = '\0';
|
||||||
|
} else
|
||||||
|
value = ptr + 1;
|
||||||
value = format_expand(ft, value);
|
value = format_expand(ft, value);
|
||||||
free(saved);
|
free(saved);
|
||||||
saved = value;
|
saved = value;
|
||||||
|
@ -227,7 +227,7 @@ key_bindings_init(void)
|
|||||||
"bind -n WheelUpStatus previous-window",
|
"bind -n WheelUpStatus previous-window",
|
||||||
"bind -n MouseDrag1Pane if -Ft= '#{mouse_any_flag}' 'if -Ft= \"#{pane_in_mode}\" \"copy-mode -M\" \"send-keys -M\"' 'copy-mode -M'",
|
"bind -n MouseDrag1Pane if -Ft= '#{mouse_any_flag}' 'if -Ft= \"#{pane_in_mode}\" \"copy-mode -M\" \"send-keys -M\"' 'copy-mode -M'",
|
||||||
"bind -n MouseDown3Pane select-pane -mt=",
|
"bind -n MouseDown3Pane select-pane -mt=",
|
||||||
"bind -n WheelUpPane if-shell -Ft= '#{mouse_any_flag}' 'send-keys -M' 'if -Ft= \"#{pane_in_mode}\" \"send-keys -M\" \"copy-mode -e\"'",
|
"bind -n WheelUpPane if-shell -Ft= '#{mouse_any_flag}' 'send-keys -M' 'if -Ft= \"#{pane_in_mode}\" \"send-keys -M\" \"copy-mode -et=\"'",
|
||||||
};
|
};
|
||||||
u_int i;
|
u_int i;
|
||||||
struct cmd_list *cmdlist;
|
struct cmd_list *cmdlist;
|
||||||
|
2
screen.c
2
screen.c
@ -194,8 +194,6 @@ screen_resize_y(struct screen *s, u_int sy)
|
|||||||
* Now just increase the history size, if possible, to take
|
* Now just increase the history size, if possible, to take
|
||||||
* over the lines which are left. If history is off, delete
|
* over the lines which are left. If history is off, delete
|
||||||
* lines from the top.
|
* lines from the top.
|
||||||
*
|
|
||||||
* XXX Should apply history limit?
|
|
||||||
*/
|
*/
|
||||||
available = s->cy;
|
available = s->cy;
|
||||||
if (gd->flags & GRID_HISTORY)
|
if (gd->flags & GRID_HISTORY)
|
||||||
|
Loading…
Reference in New Issue
Block a user