mirror of
https://github.com/fish-shell/fish-shell
synced 2025-01-09 03:28:48 +00:00
465da28f20
This was the remaining immediately actionable part of #7375.
It's not definitely the last word, but a change here would require a
bigger plan.
Fixes #7375
(cherry picked from commit 0e81d25b36
)
156 lines
5.5 KiB
ReStructuredText
156 lines
5.5 KiB
ReStructuredText
.. _cmd-commandline:
|
|
|
|
commandline - set or get the current command line buffer
|
|
========================================================
|
|
|
|
Synopsis
|
|
--------
|
|
|
|
.. synopsis::
|
|
|
|
commandline [OPTIONS] [CMD]
|
|
|
|
Description
|
|
-----------
|
|
|
|
``commandline`` can be used to set or get the current contents of the command line buffer.
|
|
|
|
With no parameters, ``commandline`` returns the current value of the command line.
|
|
|
|
With **CMD** specified, the command line buffer is erased and replaced with the contents of **CMD**.
|
|
|
|
The following options are available:
|
|
|
|
**-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.
|
|
If one of the options **-j**, **-p** or **-t** is given, the position is relative to the respective substring instead of the entire command line buffer.
|
|
|
|
**-B** or **--selection-start**
|
|
Get current position of the selection start in the buffer.
|
|
|
|
**-E** or **--selection-end**
|
|
Get current position of the selection end in the buffer.
|
|
|
|
**-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 :doc:`bind <bind>` for a list of input functions.
|
|
|
|
**-h** or **--help**
|
|
Displays help about using this command.
|
|
|
|
The following options change the way ``commandline`` updates the command line buffer:
|
|
|
|
**-a** or **--append**
|
|
Do not remove the current commandline, append the specified string at the end of it.
|
|
|
|
**-i** or **--insert**
|
|
Do not remove the current commandline, insert the specified string at the current cursor position
|
|
|
|
**-r** or **--replace**
|
|
Remove the current commandline and replace it with the specified string (default)
|
|
|
|
The following options change what part of the commandline is printed or updated:
|
|
|
|
**-b** or **--current-buffer**
|
|
Select the entire commandline, not including any displayed autosuggestion (default).
|
|
|
|
**-j** or **--current-job**
|
|
Select the current job - a **job** here is one pipeline.
|
|
Stops at logical operators or terminators (**;**, **&**, and newlines).
|
|
|
|
**-p** or **--current-process**
|
|
Select the current process - a **process** here is one command.
|
|
Stops at logical operators, terminators, and pipes.
|
|
|
|
**-s** or **--current-selection**
|
|
Selects the current selection
|
|
|
|
**-t** or **--current-token**
|
|
Selects the current token
|
|
|
|
The following options change the way ``commandline`` prints the current commandline buffer:
|
|
|
|
**-c** or **--cut-at-cursor**
|
|
Only print selection up until the current cursor position.
|
|
If combined with ``--tokenize``, this will print up until the last completed token - excluding the token the cursor is in.
|
|
This is typically what you would want for instance in completions.
|
|
To get both, use both ``commandline --cut-at-cursor --tokenize; commandline --cut-at-cursor --current-token``,
|
|
or ``commandline -co; commandline -ct`` for short.
|
|
|
|
**-o** or **--tokenize**
|
|
Tokenize the selection and print one string-type token per line.
|
|
|
|
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.
|
|
|
|
The following options output metadata about the commandline state:
|
|
|
|
**-L** or **--line**
|
|
Print the line that the cursor is on, with the topmost line starting at 1.
|
|
|
|
**-S** or **--search-mode**
|
|
Evaluates to true if the commandline is performing a history search.
|
|
|
|
**-P** or **--paging-mode**
|
|
Evaluates to true if the commandline is showing pager contents, such as tab completions.
|
|
|
|
**--paging-full-mode**
|
|
Evaluates to true if the commandline is showing pager contents, such as tab completions and all lines are shown (no "<n> more rows" message).
|
|
|
|
**--is-valid**
|
|
Returns true when the commandline is syntactically valid and complete.
|
|
If it is, it would be executed when the ``execute`` bind function is called.
|
|
If the commandline is incomplete, return 2, if erroneus, return 1.
|
|
|
|
Example
|
|
-------
|
|
|
|
``commandline -j $history[3]`` replaces the job under the cursor with the third item from the command line history.
|
|
|
|
If the commandline contains
|
|
|
|
|
|
::
|
|
|
|
>_ echo $flounder >&2 | less; and echo $catfish
|
|
|
|
|
|
(with the cursor on the "o" of "flounder")
|
|
|
|
The ``echo $flounder >&`` is the first process, ``less`` the second and ``and echo $catfish`` the third.
|
|
|
|
``echo $flounder >&2 | less`` is the first job, ``and echo $catfish`` the second.
|
|
|
|
**$flounder** is the current token.
|
|
|
|
The most common use for something like completions is
|
|
|
|
::
|
|
|
|
set -l tokens (commandline -opc)
|
|
|
|
which gives the current *process* (what is being completed), tokenized into separate entries, up to but excluding the currently being completed token
|
|
|
|
If you are then also interested in the in-progress token, add
|
|
|
|
::
|
|
set -l current (commandline -ct)
|
|
|
|
Note that this makes it easy to render fish's infix matching moot - if possible it's best if the completions just print all possibilities and leave the matching to the current token up to fish's logic.
|
|
|
|
More examples:
|
|
|
|
::
|
|
|
|
>_ 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
|
|
|