With the first method you are not creating an alias, you are creating a symlink. Symlinks are short for symbolic links:
Symbolic links are files that act as
pointers to other files. [...] A
symbolic link is a special type of
file whose contents are a string that
is the pathname another file, the file
to which the link refers. In other
words, a symbolic link is a pointer to
another name, and not to an underlying
object.
Read more about symlinks here and here.
Only with the second method you are, in fact, creating an alias.
Aliases allow a string to be
substituted for a word when it is used
as the first word of a simple command.
The shell maintains a list of aliases
that may be set and unset with the
alias and unalias builtin commands
(see SHELL BUILTIN COMMANDS below).
The first word of each simple
command, if unquoted, is checked to
see if it has an alias. If so, that
word is replaced by the text of the
alias.
You can define an alias anywhere where you can type a command and have the shell (bash in this case) interpret it, however in order for the alias to be available in other shells it needs to be defined in a file that's interpreted by the shell on startup (shell startup, not computer startup).
For bash these are /etc/bash.bashrc
(system wide) and ~/.bashrc
. These files are interpreted when the shell starts in interactive mode (like when using Terminal
). I'm not going to mention the profile files because they serve a different purpose.
So, you want to add your aliases to ~/.bashrc
to have them available in every interactive shell.
The .bash_aliases
method accomplishes exactly the same thing as putting the aliases in ~/.bashrc
but has the added benefit of being easier to be parsed and manipulated by programs.
The . ~/.bash_aliases
means source (load) _~/.bash_aliases_
in the context of the currently running shell.
Create a script rename1.sh:
#! /bin/bash
old=$1
new=${old//[\''"?*%#^!@$&()=+[]{};,`~']}
new=${new//['<>:\|']/-} # I removed /, see below.
if [[ -e $new ]] ; then
if [[ $old != $new ]] ; then
echo Cannot rename "$old" to "$new" - target already exists.
fi
else
mv "$old" "$new"
fi
It renames one file according to the given rules using parameter expansion. To rename a subtree, run it with find
:
find /path -exec rename1.sh {} \;
Are you sure you want to replace /
with -
? It would put all the files into the same directory.
Best Answer
websync
scriptspawn-progress-multi
scriptIf you don't put
spawn-progress-multi
file in your path websync will not be able to run it