aboutsummaryrefslogtreecommitdiff
path: root/layout-custom.c
Commit message (Collapse)AuthorAge
* Support for windows larger than the client.Nicholas Marriott2018-08-20
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This adds two new options, window-size and default-size, and a new command, resize-window. The force-width and force-height options, and the session_width and session_height formats have been removed. The new window-size option tells tmux how to work out the size of windows: largest means it picks the size of the largest session, smallest the smallest session (similar to the old behaviour) and manual means that it does not automatically resize windows. aggressive-resize modifies the choice of session for largest and smallest as it did before. If a window is in a session attached to a client that is too small, only part of the window is shown. tmux attempts to keep the cursor visible, so the part of the window displayed is changed as the cursor moves (with a small delay, to try and avoid excess redrawing when applications redraw status lines or similar that are not currently visible). Drawing windows which are larger than the client is not as efficient as those which fit, particularly when the cursor moves, so it is recommended to avoid using this on slow machines or networks (set window-size to smallest or manual). The resize-window command can be used to resize a window manually. If it is used, the window-size option is automatically set to manual for the window (undo this with "setw -u window-size"). resize-window works in a similar way to resize-pane (-U -D -L -R -x -y flags) but also has -a and -A flags. -a sets the window to the size of the smallest client (what it would be if window-size was smallest) and -A the largest. For the same behaviour as force-width or force-height, use resize-width -x or -y. If the global window-size option is set to manual, the default-size option is used for new windows. If -x or -y is used with new-session, that sets the default-size option for the new session. The maximum size of a window is 10000x10000. But expect applications to complain and higher memory use if you make a window that big. The minimum size is the size required for the current layout including borders. This change allows some code improvements, most notably that since windows can now never be cropped, that code can be removed from the layout code, and since panes can now never be outside the size of the window, window_pane_visible can be removed.
* Use the notify name string instead of going via an enum and changenicm2016-10-16
| | | | existing hooks to use notifys instead.
* Fix minimum size when pane status line is enabled, reported by Y Petremann.nicm2016-08-03
|
* Wrap some long lines and apply some static.nicm2016-07-15
|
* I no longer use my SourceForge address so replace it.nicm2016-01-19
|
* Always format real layout even when zoomed.nicm2015-04-21
|
* Fix handling of short (< 4 character) checksums and a bug with parsingNicholas Marriott2013-03-25
| | | | old-style custom layouts. Based on fix from Chris Johnsen.
* Add notify hooks for various events, the functions are currently emptyNicholas Marriott2012-03-17
| | | | stubs but will be filled in for control mode later. From George Nachman.
* Check for the right return value from sscanf.Nicholas Marriott2012-02-05
|
* Add pane id to each pane in layout description (while still acceptingNicholas Marriott2012-01-30
| | | | the old form). Based on diff from George Nachman.
* Get rid of the layout string code which tries to walk through the layoutNicholas Marriott2011-06-05
| | | | hierarchy and instead just look at what panes are actually in the window.
* Custom layouts. list-windows command displays the layout as a string (such asNicholas Marriott2010-06-29
"bb62,159x48,0,0{79x48,0,0,79x48,80,0}") and it can be applied to another window (with the same number of panes or fewer) using select-layout.