From 05f19ad09cbbd7fe97e45a1a15c92d5035e6225e Mon Sep 17 00:00:00 2001 From: Kurtis Rader Date: Mon, 2 Jan 2017 17:15:18 -0800 Subject: [PATCH] clarify autoloading and aliases Another dev pointed out my previous attempt to resolve issue #3612 did not do a good job of clarifying the matter. Hopefully this change is better at explaining why autoloading is not applicable to aliases. --- doc_src/index.hdr.in | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/doc_src/index.hdr.in b/doc_src/index.hdr.in index d4e85a299..577082f07 100644 --- a/doc_src/index.hdr.in +++ b/doc_src/index.hdr.in @@ -240,7 +240,7 @@ There are a few important things that need to be noted about aliases: - If the alias has the same name as the aliased command, it is necessary to prefix the call to the program with `command` in order to tell fish that the function should not call itself, but rather a command with the same name. Failing to do so will cause infinite recursion bugs. -- Autoloading isn't applicable since, by definition, the alias command creates the function at the time it is executed. If you want to defer creation of the function to when it is used simply create a script that uses the function command per the discussion below about autoloading functions. +- Autoloading isn't applicable to aliases. Since, by definition, the function is created at the time the alias command is executed. You cannot autoload aliases. To easily create a function of this form, you can use the alias command. @@ -265,6 +265,8 @@ It is very important that function definition files only contain the definition Autoloading also won't work for event handlers, since fish cannot know that a function is supposed to be executed when an event occurs when it hasn't yet loaded the function. See the event handlers section for more information. +Autoloading is not applicable to functions created by the `alias` command. For functions simple enough that you prefer to use the `alias` command to define them you'll need to put those commands in your `~/.config/fish/config.fish` script or some other script run when the shell starts. + If you are developing another program, you may wish to install functions which are available for all users of the fish shell on a system. They can be installed to the "vendor" functions directory. As this path may vary from system to system, the `pkgconfig` framework should be used to discover this path with the output of `pkg-config --variable functionsdir fish`.