Después de leer la respuesta de @ DennisWilliamson, hay algunos problemas, ver a continuación:
Como esta pregunta representa ksh y intento, hay otra parte en esta respuesta sobre ksh... vea abajo.
Sencillo intento camino
[ "$0" = "$BASH_SOURCE" ]
Probemos (sobre la marcha porque esa fiesta podría ;-):
source <(echo $'#!/bin/bash
[ "$0" = "$BASH_SOURCE" ] && v=own || v=sourced;
echo "process $$ is $v ($0, $BASH_SOURCE)" ')
process 29301 is sourced (bash, /dev/fd/63)
bash <(echo $'#!/bin/bash
[ "$0" = "$BASH_SOURCE" ] && v=own || v=sourced;
echo "process $$ is $v ($0, $BASH_SOURCE)" ')
process 16229 is own (/dev/fd/63, /dev/fd/63)
En su source
lugar, uso off .
para facilitar la lectura (como .
es un alias source
):
. <(echo $'#!/bin/bash
[ "$0" = "$BASH_SOURCE" ] && v=own || v=sourced;
echo "process $$ is $v ($0, $BASH_SOURCE)" ')
process 29301 is sourced (bash, /dev/fd/63)
Tenga en cuenta que el número de proceso no cambia mientras el proceso permanece en origen :
echo $$
29301
¿Por qué no usar la $_ == $0
comparación?
Para asegurar muchos casos, comienzo a escribir un script verdadero :
#!/bin/bash
# As $_ could be used only once, uncomment one of two following lines
#printf '_="%s", 0="%s" and BASH_SOURCE="%s"\n' "$_" "$0" "$BASH_SOURCE"
[[ "$_" != "$0" ]] && DW_PURPOSE=sourced || DW_PURPOSE=subshell
[ "$0" = "$BASH_SOURCE" ] && BASH_KIND_ENV=own || BASH_KIND_ENV=sourced;
echo "proc: $$[ppid:$PPID] is $BASH_KIND_ENV (DW purpose: $DW_PURPOSE)"
Copie esto a un archivo llamado testscript
:
cat >testscript
chmod +x testscript
Ahora podríamos probar:
./testscript
proc: 25758[ppid:24890] is own (DW purpose: subshell)
Está bien.
. ./testscript
proc: 24890[ppid:24885] is sourced (DW purpose: sourced)
source ./testscript
proc: 24890[ppid:24885] is sourced (DW purpose: sourced)
Está bien.
Pero, para probar un script antes de agregar una -x
bandera:
bash ./testscript
proc: 25776[ppid:24890] is own (DW purpose: sourced)
O para usar variables predefinidas:
env PATH=/tmp/bintemp:$PATH ./testscript
proc: 25948[ppid:24890] is own (DW purpose: sourced)
env SOMETHING=PREDEFINED ./testscript
proc: 25972[ppid:24890] is own (DW purpose: sourced)
Esto ya no funcionará.
Mover el comentario de la 5ta línea a la 6ta daría una respuesta más legible:
./testscript
_="./testscript", 0="./testscript" and BASH_SOURCE="./testscript"
proc: 26256[ppid:24890] is own
. testscript
_="_filedir", 0="bash" and BASH_SOURCE="testscript"
proc: 24890[ppid:24885] is sourced
source testscript
_="_filedir", 0="bash" and BASH_SOURCE="testscript"
proc: 24890[ppid:24885] is sourced
bash testscript
_="/bin/bash", 0="testscript" and BASH_SOURCE="testscript"
proc: 26317[ppid:24890] is own
env FILE=/dev/null ./testscript
_="/usr/bin/env", 0="./testscript" and BASH_SOURCE="./testscript"
proc: 26336[ppid:24890] is own
Más fuerte: ksh ahora...
Como no uso ksh mucho, después de leer algo en la página del manual, están mis intentos:
#!/bin/ksh
set >/tmp/ksh-$$.log
Copia esto en un testfile.ksh
:
cat >testfile.ksh
chmod +x testfile.ksh
Que ejecutarlo dos veces:
./testfile.ksh
. ./testfile.ksh
ls -l /tmp/ksh-*.log
-rw-r--r-- 1 user user 2183 avr 11 13:48 /tmp/ksh-9725.log
-rw-r--r-- 1 user user 2140 avr 11 13:48 /tmp/ksh-9781.log
echo $$
9725
y ver:
diff /tmp/ksh-{9725,9781}.log | grep ^\> # OWN SUBSHELL:
> HISTCMD=0
> PPID=9725
> RANDOM=1626
> SECONDS=0.001
> lineno=0
> SHLVL=3
diff /tmp/ksh-{9725,9781}.log | grep ^\< # SOURCED:
< COLUMNS=152
< HISTCMD=117
< LINES=47
< PPID=9163
< PS1='$ '
< RANDOM=29667
< SECONDS=23.652
< level=1
< lineno=1
< SHLVL=2
Hay alguna variable heredada en una ejecución de origen , pero nada realmente relacionado ...
Incluso podría verificar que $SECONDS
esté cerca 0.000
, pero eso garantiza que solo los casos de origen manual ...
Incluso podría intentar verificar qué es el padre:
Coloque esto en su testfile.ksh
:
ps $PPID
Que:
./testfile.ksh
PID TTY STAT TIME COMMAND
32320 pts/4 Ss 0:00 -ksh
. ./testfile.ksh
PID TTY STAT TIME COMMAND
32319 ? S 0:00 sshd: user@pts/4
o ps ho cmd $PPID
, pero esto funciona solo para un nivel de subsesiones ...
Lo siento, no pude encontrar una manera confiable de hacerlo, bajo ksh.