Wiele programów korzysta z tej techniki, gdy istnieje jeden plik wykonywalny, który zmienia swoje zachowanie w zależności od sposobu jego wykonania.
Zazwyczaj w programie znajduje się struktura nazywana instrukcją case / switch, która określa nazwę, z którą został wywołany plik wykonywalny, a następnie wywołuje odpowiednią funkcjonalność dla tej nazwy pliku wykonywalnego. Ta nazwa jest zwykle pierwszym argumentem otrzymywanym przez program. Na przykład C
podczas pisania:
int main(int argc, char** argv)
argv[0]
zawiera nazwę wywoływanego pliku wykonywalnego. Przynajmniej jest to standardowe zachowanie wszystkich powłok i wszystkie pliki wykonywalne, które używają argumentów, powinny o tym wiedzieć.
Przykład w Perlu
Oto wymyślony przykład, który stworzyłem w Perlu, który pokazuje również technikę.
Oto rzeczywisty skrypt, nazwij go mycmd.pl
:
#!/usr/bin/perl
use feature ':5.10';
(my $arg = $0) =~ s#./##;
my $msg = "I was called as: ";
given ($arg) {
$msg .= $arg when 'ls';
$msg .= $arg when 'find';
$msg .= $arg when 'pwd';
default { $msg = "Error: I don't know who I am 8-)"; }
}
say $msg;
exit 0;
Oto konfiguracja systemu plików:
$ ls -l
total 4
lrwxrwxrwx 1 saml saml 8 May 24 20:49 find -> mycmd.pl
lrwxrwxrwx 1 saml saml 8 May 24 20:34 ls -> mycmd.pl
-rwxrwxr-x 1 saml saml 275 May 24 20:49 mycmd.pl
lrwxrwxrwx 1 saml saml 8 May 24 20:49 pwd -> mycmd.pl
Teraz, gdy uruchamiam polecenia:
$ ./find
I was called as: find
$ ./ls
I was called as: ls
$ ./pwd
I was called as: pwd
$ ./mycmd.pl
Error: I don't know who I am 8-)