fish-shell/doc_src/cmds/contains.rst

61 lines
1.3 KiB
ReStructuredText
Raw Normal View History

.. _cmd-contains:
contains - test if a word is present in a list
==============================================
Synopsis
--------
2021-12-17 23:23:02 +00:00
``contains`` [**options**] *KEY* [*VALUES* ...]
Description
-----------
``contains`` tests whether the set *VALUES* contains the string *KEY*.
If so, ``contains`` exits with code 0; if not, it exits with code 1.
The following options are available:
- **-i** or **--index** print the word index
Note that ``contains`` interprets all arguments starting with a **-** as an option to ``contains``, until an **--** argument is reached.
See the examples below.
Example
-------
If *animals* is a list of animals, the following will test if *animals* contains "cat":
2018-12-19 03:14:04 +00:00
::
if contains cat $animals
echo Your animal list is evil!
end
This code will add some directories to :envvar:`PATH` if they aren't yet included:
2018-12-19 03:14:04 +00:00
::
for i in ~/bin /usr/local/bin
if not contains $i $PATH
set PATH $PATH $i
end
end
2018-12-19 03:14:04 +00:00
While this will check if function ``hasargs`` is being ran with the **-q** option:
2018-12-19 03:14:04 +00:00
::
function hasargs
if contains -- -q $argv
echo '$argv contains a -q option'
end
end
2018-12-19 03:14:04 +00:00
The **--** here stops ``contains`` from treating **-q** to an option to itself.
Instead it treats it as a normal string to check.