2019-03-31 17:05:09 +08:00
.. _cmd-commandline:
2018-12-17 09:39:33 +08:00
commandline - set or get the current command line buffer
2019-01-03 12:10:47 +08:00
========================================================
2018-12-17 09:39:33 +08:00
2018-12-18 09:58:24 +08:00
Synopsis
--------
2018-12-17 05:08:41 +08:00
2019-09-17 17:59:04 +08:00
::
2018-12-18 09:58:24 +08:00
2019-09-17 17:59:04 +08:00
commandline [OPTIONS] [CMD]
2018-12-17 05:08:41 +08:00
2018-12-19 10:44:30 +08:00
Description
2019-01-03 12:10:47 +08:00
-----------
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
`` commandline `` can be used to set or get the current contents of the command line buffer.
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
With no parameters, `` commandline `` returns the current value of the command line.
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
With `` CMD `` specified, the command line buffer is erased and replaced with the contents of `` CMD `` .
2018-12-17 05:08:41 +08:00
The following options are available:
2018-12-20 04:02:45 +08:00
- `` -C `` or `` --cursor `` set or get the current cursor position, not the contents of the buffer. If no argument is given, the current cursor position is printed, otherwise the argument is interpreted as the new cursor position.
2018-12-17 05:08:41 +08:00
2019-04-07 02:37:14 +08:00
- `` -f `` or `` --function `` causes any additional arguments to be interpreted as input functions, and puts them into the queue, so that they will be read before any additional actual key presses are. This option cannot be combined with any other option. See :ref: `bind <cmd-bind>` for a list of input functions.
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
The following options change the way `` commandline `` updates the command line buffer:
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
- `` -a `` or `` --append `` do not remove the current commandline, append the specified string at the end of it
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
- `` -i `` or `` --insert `` do not remove the current commandline, insert the specified string at the current cursor position
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
- `` -r `` or `` --replace `` remove the current commandline and replace it with the specified string (default)
2018-12-17 05:08:41 +08:00
The following options change what part of the commandline is printed or updated:
2018-12-20 04:02:45 +08:00
- `` -b `` or `` --current-buffer `` select the entire buffer, including any displayed autosuggestion (default)
2018-12-17 05:08:41 +08:00
2020-10-27 02:19:05 +08:00
- `` -j `` or `` --current-job `` select the current job - a `job` here is one pipeline. It stops at logical operators or terminators (`` ; `` , `` & `` or newlines).
2018-12-17 05:08:41 +08:00
2020-02-12 03:42:12 +08:00
- `` -p `` or `` --current-process `` select the current process - a `process` here is one simple command. It stops at logical operators, terminators or pipes.
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
- `` -s `` or `` --current-selection `` selects the current selection
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
- `` -t `` or `` --current-token `` select the current token
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
The following options change the way `` commandline `` prints the current commandline buffer:
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
- `` -c `` or `` --cut-at-cursor `` only print selection up until the current cursor position
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
- `` -o `` or `` --tokenize `` tokenize the selection and print one string-type token per line
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
If `` commandline `` is called during a call to complete a given string using `` complete -C STRING `` , `` commandline `` will consider the specified string to be the current contents of the command line.
2018-12-17 05:08:41 +08:00
The following options output metadata about the commandline state:
2018-12-20 04:02:45 +08:00
- `` -L `` or `` --line `` print the line that the cursor is on, with the topmost line starting at 1
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
- `` -S `` or `` --search-mode `` evaluates to true if the commandline is performing a history search
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
- `` -P `` or `` --paging-mode `` evaluates to true if the commandline is showing pager contents, such as tab completions
2018-12-17 05:08:41 +08:00
2018-12-19 10:44:30 +08:00
Example
2019-01-03 12:10:47 +08:00
-------
2018-12-17 05:08:41 +08:00
2018-12-20 04:02:45 +08:00
`` commandline -j $history[3] `` replaces the job under the cursor with the third item from the command line history.
2018-12-17 05:08:41 +08:00
If the commandline contains
2018-12-19 11:14:04 +08:00
::
2020-02-12 03:42:12 +08:00
>_ echo $flounder >&2 | less; and echo $catfish
2018-12-19 11:14:04 +08:00
2018-12-17 05:08:41 +08:00
(with the cursor on the "o" of "flounder")
2020-10-27 02:19:05 +08:00
The `` echo $flounder >& `` is the first process, `` less `` the second and `` and echo $catfish `` the third.
2020-02-12 03:42:12 +08:00
2020-10-27 02:19:05 +08:00
`` echo $flounder >&2 | less `` is the first job, `` and echo $catfish `` the second.
2020-02-12 03:42:12 +08:00
2020-10-27 02:19:05 +08:00
`` $flounder `` is the current token.
2020-02-12 03:42:12 +08:00
2020-04-17 11:01:04 +08:00
More examples:
2018-12-19 11:14:04 +08:00
::
>_ commandline -t
$flounder
>_ commandline -ct
$fl
>_ commandline -b # or just commandline
echo $flounder >&2 | less; and echo $catfish
>_ commandline -p
echo $flounder >&2
>_ commandline -j
echo $flounder >&2 | less