No description
Find a file
Kurtis Rader b1ac07a178 Reduce overhead of setting fish vars
The `react_to_variable_change()` function is called whenever a fish var
is set. Even as a consequence of statements like `for x in a b c`. It is
therefore critical that that function be as fast as possible. Especially
when setting the var doesn't have any side-effects which is true something
like 99.9999% of the time.

This change reduces the overhead of `react_to_variable_change()` to
unmeasurable levels. Making the synthetic benchmark in issue #4341
36% faster.

Fixes #4341
2017-08-18 20:13:13 -07:00
.github change the github issue template 2017-02-28 21:29:50 -08:00
build_tools Revert "Enable support for custom versioning" 2017-08-16 20:54:39 +08:00
debian Upgrade git:// and http:// URLs to https:// 2017-02-17 21:31:44 +08:00
doc_src Clarify docs on $status with and/or/begin/end 2017-08-14 18:18:10 -07:00
etc It's status --is-interactive (#3086) 2016-05-29 12:24:24 +02:00
fish.xcodeproj implement argparse --exclusive 2017-07-12 22:38:31 -07:00
m4 Enable C++11 in autotools build 2016-11-26 12:59:00 -08:00
osx Merge branch 'Integration_2.6.0' 2017-06-03 22:02:59 +08:00
pcre2-10.22 pcre2: add maintainer mode and disable by default 2017-01-18 16:44:48 -08:00
po replace __fish_urlencode with string escape 2017-06-23 22:46:36 -07:00
share Fix typo in xdg-mime completion functions 2017-08-17 10:54:05 -07:00
src Reduce overhead of setting fish vars 2017-08-18 20:13:13 -07:00
tests change env_var_t to a vector of strings 2017-08-18 16:24:30 -07:00
.clang-format config clang-format to ignore oclint pragmas 2016-05-04 18:08:26 -07:00
.cppcheck.rules remove pointless flock() lint warning 2017-05-09 21:03:00 -07:00
.cppcheck.suppressions lint: replace getpwuid() with getpwuid_r() 2017-05-10 21:08:36 -07:00
.editorconfig Add max_line_length to .editorconfig 2017-06-16 01:32:55 +02:00
.gitattributes .gitattributes: include build tools in exported archives 2017-05-16 20:22:06 +08:00
.gitignore Delete trailing spaces 2017-01-15 14:57:21 -08:00
.oclint fix oclint NPATH_COMPLEXITY custom threshold 2017-07-12 22:38:32 -07:00
.travis.yml travis: only run tests if make succeeds 2017-05-24 11:39:59 +08:00
CHANGELOG.md Reduce overhead of setting fish vars 2017-08-18 20:13:13 -07:00
config.guess Update to latest config.sub and config.guess versions 2015-05-28 12:29:46 +08:00
config.sub Update to latest config.sub and config.guess versions 2015-05-28 12:29:46 +08:00
configure.ac Revert "configure: check that errno is threadsafe" 2017-08-14 18:18:10 -07:00
CONTRIBUTING.md Revert "Enable support for custom versioning" 2017-08-16 20:54:39 +08:00
COPYING add flock fallback 2016-12-03 16:36:06 +08:00
Dockerfile math requires bc package 2015-01-22 14:47:28 +08:00
Doxyfile Delete trailing spaces 2017-01-15 14:57:21 -08:00
Doxyfile.help Silence the Makefile build 2016-07-31 12:24:35 -07:00
Doxyfile.user Silence the Makefile build 2016-07-31 12:24:35 -07:00
fish.pc.in Upgrade git:// and http:// URLs to https:// 2017-02-17 21:31:44 +08:00
fish.spec.in fish.spec.in: Remove which dependency 2017-04-08 13:25:26 +02:00
install-sh Update install-sh 2016-09-09 01:24:24 -07:00
lexicon_filter.in 'Correct' error to eror in lexicon_filter 2017-02-12 15:39:22 -08:00
Makefile.in change env_var_t to a vector of strings 2017-08-18 16:24:30 -07:00
README.md Clarify notes on dependency errors, tests, and VCS integration. 2017-08-14 18:18:10 -07:00

fish - the friendly interactive shell Build Status

fish is a smart and user-friendly command line shell for OS X, Linux, and the rest of the family. fish includes features like syntax highlighting, autosuggest-as-you-type, and fancy tab completions that just work, with no configuration required.

For more on fish's design philosophy, see the design document.

Quick Start

fish generally works like other shells, like bash or zsh. A few important differences can be found at https://fishshell.com/docs/current/tutorial.html by searching for the magic phrase "unlike other shells".

Detailed user documentation is available by running help within fish, and also at https://fishshell.com/docs/current/index.html

Building

Dependencies

Compiling fish requires:

  • a C++11 compiler. It builds successfully with g++ 4.8 or later, or with clang 3.3 or later. fish can be built using autotools or Xcode. autoconf 2.60 or later, as well as automake 1.13 or later, are required to build from git versions, but these are not required to build from the officially released tarballs.
  • the headers and libraries of a curses implementation such as ncurses.
  • gettext, for translation support.
  • Doxygen 1.8.7 or newer, for building the documentation.

At runtime, fish requires:

  • a curses implementation such as ncurses (which should provide the tput command).
  • gettext, if you need the localizations.
  • PCRE2, due to the regular expression support contained in the string builtin. A copy is included with the source code, and will be used automatically if it does not already exist on your system.
  • a number of common UNIX utilities:
    • an awk implementation, such as gawk, mawk, etc
    • coreutils --- at least basename, cat, cut, date, dircolors, dirname, ls, mkdir, mkfifo, mktemp, rm, seq, sort, stat, stty, tail, tr, tty, uname, uniq, wc, whoami
    • find
    • grep
    • hostname
    • kill
    • ps
    • sed
  • bc, the "basic calculator" program.

Optional functionality should degrade gracefully. (If fish ever threw a syntax error or a core dump due to missing dependencies for an optional feature, it would be a bug in fish and should be reported on our GitHub.) Optional features and dependencies include:

  • dynamically generating usage tips for builtin functions, which requires man, apropos, nroff, and ul.
  • manual page parsing for auto-completion for external commands, which also requires the above man tools, plus Python 2.6+ or Python 3.3+. Python 2 will also need the backports.lzma package; Python 3.3+ should include the required module by default.
  • the web configuration tool, which requires Python 2.6+ or 3.3+.
  • the fish_clipboard_* functions (bound to \cv and \cx), which require xsel or pbcopy/pbpaste.

fish can also show VCS information in the prompt, when the current working directory is in a VCS-tracked project, with support for Git, Mercurial, and Subversion. This is one of the weakest dependencies, though: if you don't use git, for example, you don't need git information in the prompt, and if you do use git, you already have it. Similarly, fish comes with a variety of auto-completion scripts to help with command-line usage of a variety of applications; these scripts call the application in question, but you should only need these applications if you use them.

Autotools Build

autoreconf --no-recursive [if building from Git]
./configure
make [gmake on BSD]
sudo make install [sudo gmake install on BSD]

Xcode Development Build

  • Build the base target in Xcode
  • Run the fish executable, for example, in DerivedData/fish/Build/Products/Debug/base/bin/fish

Xcode Build and Install

xcodebuild install
sudo ditto /tmp/fish.dst /
sudo make install-doc

Help, it didn't build!

If fish reports that it could not find curses, try installing a curses development package and build again.

On Debian or Ubuntu you want:

sudo apt-get install build-essential ncurses-dev libncurses5-dev gettext autoconf

On RedHat, CentOS, or Amazon EC2:

sudo yum install ncurses-devel

Packages for Linux

Instructions on how to find builds for several Linux distros are at https://github.com/fish-shell/fish-shell/wiki/Nightly-builds

Switching to fish

If you wish to use fish as your default shell, use the following command:

chsh -s /usr/local/bin/fish

chsh will prompt you for your password, and change your default shell. Substitute "/usr/local/bin/fish" with whatever path to fish is in your /etc/shells file.

Use the following command if you didn't already add your fish path to /etc/shells.

echo /usr/local/bin/fish | sudo tee -a /etc/shells

To switch your default shell back, you can run:

chsh -s /bin/bash

Substitute /bin/bash with /bin/tcsh or /bin/zsh as appropriate.

You may need to logout/login for the change (chsh) to take effect.

Contributing Changes to the Code

See the Guide for Developers.

Contact Us

Questions, comments, rants and raves can be posted to the official fish mailing list at https://lists.sourceforge.net/lists/listinfo/fish-users or join us on our gitter.im channel or IRC channel #fish at irc.oftc.net. Or use the fish tag on Stackoverflow for questions related to fish script and the fish tag on Superuser for all other questions (e.g., customizing colors, changing key bindings).

Found a bug? Have an awesome idea? Please open an issue on this github page.