'Kaynak' ne yapar?


584
$ whatis source
source: nothing appropriate.
$ man source
No manual entry for source
$ source
bash: source: filename argument required
source: usage: source filename [arguments]

Var ve çalıştırılabilir. Neden Ubuntu'da herhangi bir dokümantasyon yok? Bu ne işe yarıyor? Bununla ilgili belgeleri nasıl kurabilirim?



54
unuttun $ type source source is a shell built-in
bnjmn

2
Bunu kabuğum geri verdi $ whatis source source (1) - bash built-in commands, see bash(1). Ayrıca man sourcebeni BASH_BUILTINS(1)man sayfalarına götürür . Bu Fedora btw'da, bu debian paketlerinin neden un (veya kötü) belgelendirilmediğini bilmiyor.
arielnmz

4
@lesmana, harika bağlantı. Bu bağlantılı cevap , bu sorunun daha ayrıntılı cevabıdır.
Scott

5
"Yardım kaynağı" Deneyin
Jasser

Yanıtlar:


470

sourceGeçerli kabuğunda argüman olarak geçirilen dosyanın içeriğini çalıştıran yerleşik bir bash kabuğudur . .(Dönem) ile eşanlamlıdır .

Sözdizimi

. filename [arguments]

source filename [arguments]

8
sourcebir bash özgü komut veya diğer kabuklar çok var? (Ben soru doğru etiketleri almak istiyorum ...)
Jonik

2
Afaik, sourceBourne kabuğunda mevcuttu ve bu nedenle muhtemelen tüm soyundan geliyordu . en.wikipedia.org/wiki/Bourne_shell . Tüm mermilerin sourcekomuta sahip olmadığını biliyorum, hangi mermilerin içerdiği hakkında daha az kesin.
nagul

13
@ nagul, sourceBourne kabuğunda yoktu, daha sonra gelen bir GNU eklentisidir. Orijinal ve hala taşınabilir sözdizimi (POSIX), " .bunun yerine " nokta "komutunu kullanmaktır. Yazmak sourceiçin daha uzun ve katma değeri olmadığı gerçeği göz önüne alındığında şahsen hiçbir zaman kullanmam . Sanırım asıl amacı senaryoları yeniler için daha okunaklı hale getirmektir.
jlliagre

18
jlliagre benim kişisel "neden kaynağa sahip olduğunu açıkla" ifadesi bu sourcesadece daha açıklayıcı değil, yazım hatası dışında bir şeye benziyor. E-postayla teknik komutlar gönderdiğimde insanların dönemi / noktayı atlamasını sağladım.
Zengin Homolka

3
Bu komutun yaygın bir kullanımı, bir kabuk betiğinin sourceçoğunlukla değişken atamaları içeren bir "yapılandırma dosyasında" olmasıdır. Değişken atamaları daha sonra betiğin geri kalanının yaptığı şeyleri kontrol eder. Tabii ki, iyi bir senaryo değişkenleri, öncesinde makul değerlere ayarlayacaktır sourceveya en azından geçerli değerleri kontrol edecektir .
LawrenceC

276

Dikkatli ol! ./ve sourcevardır oldukça aynı değildir .

  • ./scriptkomut dosyasını çalıştırılabilir bir dosya olarak çalıştırır ve çalıştırmak için yeni bir kabuk başlatır
  • source scriptGeçerli kabuk ortamında dosya ismindeki komutları okur ve çalıştırır.

Not: ./scriptdeğil . script, fakat . script==source script

https://askubuntu.com/questions/182012/is-there-a-difference-between-and-source-in-bash-after-all?lq=1


27
Karıştırıyorsunuz. senaryo. source-command ile aynı komut. ./Meh komutunu kullanmak, şu dizinde meh adlı run script / binary komutunu ve kaynak / ile ilgisi olmadığını söylüyor. -command. Bağlantınızda cevabında açıklandığı gibi.
Joakim Elofsson

2
@JoakimElofsson Bağlantıda bahsedilmiştir, ancak yanlış anlamadan kaçınmak için cevabı değiştireceğim. Lütfen düzeltin.
45’te

3
Kabul edilen cevabın da buna işaret etmesi çok önemli, çünkü bir an için şunu düşündüm./ == source == .
Daniel F

90

'Type' komutunu bilmek faydalıdır:

> type source
source is a shell builtin

ne zaman bir şey yerleşik bir kabuksa, yapmanın zamanı gelmiştir man bash.


1
Her zaman okurken yeni bir şey biliyorum man)

19
Ayrıca kullanabilirsiniz help {builtin-name}, yani help source.
LawrenceC

1
helpher yerde çalışmıyor (en az zsh). typeyapar.
kumarharsh

4
Yükseltmek için: eğer bash kullanıyorsanız ve (belki de 'tip' yoluyla) biliyorsanız, bu yerleşik bir komuttur, o zaman 'yardım' sizi doğrudan 4.184 satırdan geçmeden istediğiniz dokümantasyon paragrafına götürür. adam bash 'metin.
Ron Burk

38

. (nokta), geçerli kabukta argüman olarak geçirilen bir dosyadan komutları çalıştıran bir bash kabuğu yerleşik komutudur . 'kaynak', 'için eşanlamlıdır.

Bash adam sayfasından:

. filename [arguments]
source filename [arguments]
       Read  and  execute  commands  from filename in the current shell
       environment and return the exit status of the last command  exe
       cuted from filename.  If filename does not contain a slash, file
       names in PATH are used to find the  directory  containing  file
       name.   The  file  searched  for in PATH need not be executable.
       When bash is  not  in  posix  mode,  the  current  directory  is
       searched  if no file is found in PATH.  If the sourcepath option
       to the shopt builtin command is turned  off,  the  PATH  is  not
       searched.   If any arguments are supplied, they become the posi
       tional parameters when  filename  is  executed.   Otherwise  the
       positional  parameters  are unchanged.  The return status is the
       status of the last command exited within the  script  (0  if  no
       commands  are  executed),  and false if filename is not found or
       cannot be read.

27

'kaynak', 'uzun' sürümüdür. Komut. Beşinci istemde yapabilecekleriniz:

source ~/.bashrc

Geçerli çalışan bash için (değiştirilmiş?) bash ayarınızı yeniden yüklemek için.

Kısa versiyon şöyle olurdu:

. ~/.bashrc

Adam sayfa:

. filename [arguments]
source filename [arguments]
    Read and execute commands from filename in the current shell environment and
    return the exit status of the last command executed from filename. If 
    filename does not contain a slash, file names in PATH are used to find the
    directory containing filename. The file searched for in PATH need not be
    executable. When bash is not in posix mode, the current directory is
    searched if no file is found in PATH. If the sourcepath option to the short
    builtin command is turned off, the PATH is not searched. If any arguments
    are supplied, they become the positional parameters when filename is
    executed. Otherwise the positional parameters are unchanged. The return 
    status is the status of the last command exited within the script (0 if no
    commands are executed), and false if filename is not found or cannot be
    read. 

Bu kabul edilen cevap olmalı.
Peter Mortensen

25

sourceKomut Resim komut yürütüldüğünde (çalıştırılabilir izni olan zorunlu değildir ) de mevcut ise, kabuk çevre ./temin yürütür yürütülebilir bir komut dosyası yeni kabuk.

sourceemrin bir eş anlamlısı var . filename.

Daha net hale getirmek için, takma adı belirleyen aşağıdaki betiğe bir göz atın.

make_alias

#! /bin/bash

alias myproject='cd ~/Documents/Projects/2015/NewProject'

Şimdi bu betiği çalıştırmak için iki seçeneğimiz var. Ancak, yalnızca bir seçenekle, mevcut kabuk için istenen diğer ad bu iki seçenek arasında oluşturulabilir.

Seçenek 1: ./make_alias

Önce betiği çalıştırılabilir yap.

chmod +x make_alias

Gerçekleştirmek, yerine getirmek, idam etmek

./make_alias

Doğrulamak

alias

Çıktı

**nothing**

Tüh! Takma ad yeni kabukla birlikte gitti.

İkinci seçenekle gidelim.

Seçenek 2: source make_alias

Gerçekleştirmek, yerine getirmek, idam etmek

source make_alias

veya

. make_alias

Doğrulamak

alias

Çıktı

alias myproject='cd ~/Documents/Projects/2015/NewProject'

Evet Takma adı ayarlandı.


10

Şüphe durumunda, yapılacak en iyi şey şu infokomutu kullanmaktır :

[root@abc ~]# info source

BASH BUILTIN COMMANDS
       Unless otherwise noted, each builtin command documented in this section
       as accepting options preceded by - accepts -- to signify the end of the
       options.   The  :, true, false, and test builtins do not accept options
       and do not treat -- specially.  The exit, logout, break, continue, let,
       and  shift builtins accept and process arguments beginning with - with-
       out requiring --.  Other builtins that accept  arguments  but  are  not
       specified  as accepting options interpret arguments beginning with - as
       invalid options and require -- to prevent this interpretation.
       : [arguments]
              No effect; the command does nothing beyond  expanding  arguments
              and  performing any specified redirections.  A zero exit code is
              returned.

        .  filename [arguments]
       source filename [arguments]
              Read and execute commands from filename  in  the  current  shell
              environment  and return the exit status of the last command exe-
              cuted from filename.  If filename does not contain a slash, file
              names  in  PATH  are used to find the directory containing file-
              name.  The file searched for in PATH  need  not  be  executable.
              When  bash  is  not  in  posix  mode,  the  current directory is
              searched if no file is found in PATH.  If the sourcepath  option
              to  the  shopt  builtin  command  is turned off, the PATH is not
              searched.  If any arguments are supplied, they become the  posi-
              tional  parameters  when  filename  is  executed.  Otherwise the
              positional parameters are unchanged.  The return status  is  the
              status  of  the  last  command exited within the script (0 if no
              commands are executed), and false if filename is  not  found  or
              cannot be read.

RTFM'den daha fazlasını sağlar mısınız?
Peter Mortensen

5

Kabuğunuza "yardım kaynağı" komutunu yazın.

Böyle bir çıktı alacaksınız:

source: source filename [arguments]

Execute commands from a file in the current shell.

Read and execute commands from FILENAME in the current shell.  The
entries in $PATH are used to find the directory containing FILENAME.
If any ARGUMENTS are supplied, they become the positional parameters
when FILENAME is executed.

Exit Status:
Returns the status of the last command executed in FILENAME; fails if
FILENAME cannot be read.

4

Linux Belgelendirme Projesinden Advanced Bash Scripting Guide,
Bölüm 15 - İç Komutlar ve Yerleşikler :

Kaynak , . (dot komut):
Bu komut komut satırından çağrıldığında komut dosyasını çalıştırır. Bir komut dosyasında, bir kaynak dosya adı dosya dosya adını yükler. Bir dosyayı almak (dot-command) betiğe ekleyerek kodu betiğe ekler (bir C programındaki #include direktifiyle aynı etki). Net sonuç, "kaynak kodlu" kod satırlarının kodun gövdesinde fiziksel olarak mevcut olması ile aynıdır. Bu, çoklu komut dosyalarının ortak bir veri dosyası veya işlev kitaplığı kullandığı durumlarda kullanışlıdır.
Kaynak dosyanın kendisi çalıştırılabilir bir komut dosyasıysa, o zaman çalıştırılacak, daha sonra onu çağıran komut dosyasına kontrol döndürecektir. Kaynaklı bir yürütülebilir komut dosyası bu amaç için bir dönüş kullanabilir.

Dolayısıyla, C programlama dilini bilenler için, bir dosyanın kaynak kodunun #includeyönergeye benzer bir etkisi vardır .

Ayrıca, kaynak argümanlara konumsal argümanlar iletebileceğinizi de unutmayın:

$ source $filename $arg1 arg2

Bu cevap önceki 9 cevaptan ne kadar farklı?
Stephen Rauch

2
Daha önce belirtilmeyen başka bir bilgi kaynağı ve ek bilgi eklerim.
Alexandro de Oliveira

Bunun sourceargüman alabileceğini veya kullanabileceğini bilmiyordum return.
Joe,

2

Bu unutulmamalıdır ki olmanın müthiş bir komut, ne olsa sourcene onun stenografi .ediyorum kaynak birden fazla dosya, anlam

source *.sh

veya

. script1.sh script2.sh

olacak değil çalışır.

forDöngüleri kullanarak geri çekilebiliriz , ancak çalıştırılabilir birçok kez çalıştırılır, birden çok komut veya sorun çıkarır.

Sonuç: sourcegirdi olarak birden fazla dosya almaz. Argüman bir olmalı.

Hangi IMHO berbat.


0

Kaynak ile başka bir dosyadaki değişkenleri veya fonksiyonları betiğinize aktarabilir ve tekrar yazmak zorunda kalmadan kullanabilirsiniz.

FI:

#!/bin/bash

source /etc/environment

source /myscripts/jetty-common/config/jetty-functions.sh

Şerefe

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.