Differences

This shows you the differences between two versions of the page.

Link to this comparison view

uso:laboratoare:laborator-06:inspect-shell [2022/11/07 18:49]
iustina.caramida [Redirectări]
uso:laboratoare:laborator-06:inspect-shell [2023/11/07 19:59] (current)
maria_irina.gherman [Execuția comenzilor]
Line 3: Line 3:
 ===== Configurarea shellului Bash ===== ===== Configurarea shellului Bash =====
  
-Așa cum am menționat în secțiunea Configurarea rulării ​aplicațiilor,​ modul în care o aplicație rulează este configurabil. Fișierul de configurare al shellului **Bash** este ''​%%~/​.bashrc%%''​. În directorul home al fiecărui utilizator se găsește un fișier ''​%%.bashrc%%''​ pentru a le permite utilizatorilor să își personalizeze comportamentul shellului lor Bash, fără a intra în conflict cu configurările Bash ale altor utilizatori din sistem. Atunci când un utilizator pornește un shell Bash, conținutul fișierului ''​%%~/​.bashrc%%''​ este citit și sunt aplicate configurările specifice utilizatorului.+Așa cum am menționat în laboratorul **Instalarea și utilizarea ​aplicațiilor**, modul în care o aplicație rulează este configurabil. Fișierul de configurare al shellului **Bash** este ''​%%~/​.bashrc%%''​. În directorul home al fiecărui utilizator se găsește un fișier ''​%%.bashrc%%''​pentru a le permite utilizatorilor să își personalizeze comportamentul shellului lor Bash, fără a intra în conflict cu configurările Bash ale altor utilizatori din sistem. Atunci când un utilizator pornește un shell Bash, conținutul fișierului ''​%%~/​.bashrc%%''​ este citit și sunt aplicate configurările specifice utilizatorului.
  
-Shellul //Bash//, ca majoritatea programelor,​ vine cu un set de configurări implicite (default), care nu sunt pe placul tuturor utilizatorilor. Prin fișierul ''​%%.bashrc%%''​ utilizatorul poate modifica setul default astfel încât să se potrivească cu stilul său: un exemplu des întâlnit este modificarea dimensiunii istoricului de comenzi. +Shellul //Bash//, ca majoritatea programelor,​ vine cu un set de configurări implicite (default), care pot să nu fie pe placul tuturor utilizatorilor. Prin fișierul ''​%%.bashrc%%''​ utilizatorul poate modifica setul default astfel încât să se potrivească cu stilul său: un exemplu des întâlnit este modificarea dimensiunii istoricului de comenzi.
- +
-==== Modificarea dimensiunii istoricului ==== +
- +
-Inspectăm conținutul fișierului ''​%%~/​.bashrc%%''​ folosind comanda următoare:​ +
- +
-<code bash> +
-student@uso:​~$ less ~/.bashrc +
-</​code>​ +
-În sesiunea interactivă ''​%%less%%''​ căutăm după cuvântul ''​%%HISTSIZE%%'':​ +
- +
-<code bash> +
-[...] +
-# for setting history length see HISTSIZE and HISTFILESIZE in bash(1) +
-HISTSIZE=1000 +
-HISTFILESIZE=2000 +
-[...] +
-</​code>​ +
-Shellul Bash reține istoricul de comenzi în fișierul ''​%%~/​.bash_history%%''​ din directorul home al fiecărui utilizator. Valorile variabilelor ''​%%HISTSIZE%%''​ și ''​%%HISTFILESIZE%%''​ limitează numărul maxim de comenzi, respectiv linii, din fișierul ''​%%~/​.bash_history%%''​. Dacă vrem să avem un istoric nelimitat putem seta valoarea variabilelor la un număr negativ. +
- +
-**Exercițiu**:​ Deschideți fișierul ''​%%~/​.bashrc%%''​ în editorul preferat și atribuiți valoarea ''​%%-1%%''​ pentru ''​%%HISTSIZE%%''​ și ''​%%HISTFILESIZE%%''​. Salvați modificările făcute. +
- +
-<note warning>​ +
-Atenție! **Nu** trebuie să existe spațiu între numele variabilei, ''​%%=%%''​ și valoarea atribuită. +
-</​note>​ +
- +
-<note tip> +
-Pentru a afla mai multe despre valorile ''​%%HISTSIZE%%''​ și ''​%%HISTFILESIZE%%''​ accesați pagina de manual a shellului Bash (''​%%man bash%%''​) și căutați după numele variabilelor. +
-</​note>​+
  
  
Line 67: Line 39:
 alias ncal='​ncal -M alias ncal='​ncal -M
 </​code>​ </​code>​
-Observăm că atât ''​%%grep%%''​ cât și ''​%%egrep%%''​ au câte un alias pentru opțiunea ''​%%--color%%'',​ care în cazul acesta evidenția expresia găsită. Putem defini un alias și pentru un typo pe care îl facem des, așa cum este cazul pentru ''​%%gti%%'',​ un alias pentru comanda ''​%%git%%''​.+Observăm că atât ''​%%grep%%''​ cât și ''​%%egrep%%''​ au câte un alias pentru opțiunea ''​%%--color%%'',​ care în cazul acesta evidențiază expresia găsită. Putem defini un alias și pentru un typo pe care îl facem des, așa cum este cazul pentru ''​%%gti%%'',​ un alias pentru comanda ''​%%git%%'',​ sau ''​%%grpe%%''​ pentru comanda ''​%%grep%%''​.
  
 O parte din aceste aliasuri sunt definite în fișierul ''​%%~/​.bashrc%%'',​ iar altele în fișierul ''​%%~/​.bash_aliases%%''​. Conținutul fișierului ''​%%~/​.bash_aliases%%''​ este inclus de către fișierul ''​%%~/​.bashrc%%''​ la pornirea shellului Bash. Astfel, pentru o organizare mai bună, este recomandat ca utilizatorul să-și definească aliasurile în fișierul ''​%%~/​.bash_aliases%%''​. O parte din aceste aliasuri sunt definite în fișierul ''​%%~/​.bashrc%%'',​ iar altele în fișierul ''​%%~/​.bash_aliases%%''​. Conținutul fișierului ''​%%~/​.bash_aliases%%''​ este inclus de către fișierul ''​%%~/​.bashrc%%''​ la pornirea shellului Bash. Astfel, pentru o organizare mai bună, este recomandat ca utilizatorul să-și definească aliasurile în fișierul ''​%%~/​.bash_aliases%%''​.
Line 101: Line 73:
 <code bash> <code bash>
 student@uso:​~$ go https://​www.google.com student@uso:​~$ go https://​www.google.com
-gnome-open: command ​not found+Command '​go' ​not found, but can be installed with: 
 +sudo snap install go         # version 1.18.7, or 
 +sudo apt  install golang-go ​ # version 2:​1.18~0ubuntu2 
 +sudo apt  install gccgo-go ​  # version 2:​1.18~0ubuntu2 
 +See 'snap info go' for additional versions.
 </​code>​ </​code>​
 Acest lucru se întâmplă din cauză că fișierul ''​%%~/​.bashrc%%''​ este citit atunci când pornim o instanță de Bash (când deschidem un terminal). Ca să recitim fișierul, și să aplicăm modificările,​ folosim comanda ''​%%source%%'',​ ca în exemplul de mai jos: Acest lucru se întâmplă din cauză că fișierul ''​%%~/​.bashrc%%''​ este citit atunci când pornim o instanță de Bash (când deschidem un terminal). Ca să recitim fișierul, și să aplicăm modificările,​ folosim comanda ''​%%source%%'',​ ca în exemplul de mai jos:
Line 109: Line 85:
 student@uso:​~$ go https://​www.google.com student@uso:​~$ go https://​www.google.com
 </​code>​ </​code>​
-Comanda ''​%%source ~/​.bashrc%%''​ a avut ca efect citirea ​și aplicarea modificărilor definite în fișierul ''​%%.bashrc%%''​ și fișierele pe care acesta le include.+Comanda ''​%%source ~/​.bashrc%%''​ a avut ca efect recitirea ​și aplicarea modificărilor definite în fișierul ''​%%.bashrc%%''​ și fișierele pe care acesta le include.
  
 ===== Execuția comenzilor ===== ===== Execuția comenzilor =====
Line 115: Line 91:
 ==== Încheierea execuției unei comenzi ==== ==== Încheierea execuției unei comenzi ====
  
-Atunci când rulăm o comandă aceasta își poate încheia execuția în două moduri: cu **succes** sau cu **eșec**. Atunci când își încheie execuția, orice proces întoarce un cod de ieșire (exit code), care este un număr:+Atunci când rulăm o comandăaceasta își poate încheia execuția în două moduri: cu **succes** sau cu **eșec**. Atunci când își încheie execuția, orice proces întoarce un cod de ieșire (exit code), care este un număr:
  
-  * Dacă numărul întors are valoarea ''​%%0%%'',​ procesul și-a încheiat execuția cu succes. +  * Dacă numărul întors are valoarea ''​%%0%%'', ​atunci ​procesul și-a încheiat execuția cu succes. 
-  * Dacă numărul întors are orice altă valoare, procesul și-a încheiat execuția cu eroare, iar codul întors poate fi folosit pentru a afla mai multe informații despre eroarea pe care a întors-o procesul. În pagina ''​%%man%%''​ a utilitarului ''​%%ls%%''​ este specificat:<code bash> +  * Dacă numărul întors are orice altă valoare, ​atunci ​procesul și-a încheiat execuția cu eroare, iar codul întors poate fi folosit pentru a afla mai multe informații despre eroarea pe care a întors-o procesul. În pagina ''​%%man%%''​ a utilitarului ''​%%ls%%''​ este specificat ​fiecare cod de eroare și ce înseamnă.
-Exit status: +
-       ​0 ​     if OK, +
- +
-       ​1 ​     if minor problems (e.g., cannot access subdirectory),​ +
- +
-       ​2 ​     if serious trouble (e.g., cannot access command-line argument). +
-</​code>​+
  
 Pentru a vedea codul cu care și-a încheiat execuția o comandă folosim sintaxa ''​%%$?​%%''​. Urmărim exemplul de mai jos: Pentru a vedea codul cu care și-a încheiat execuția o comandă folosim sintaxa ''​%%$?​%%''​. Urmărim exemplul de mai jos:
Line 143: Line 112:
 === Înlănțuirea comenzilor în funcție de succes sau eșec === === Înlănțuirea comenzilor în funcție de succes sau eșec ===
  
-De multe ori vrem să executăm o succesiune de comenzi pentru a realiza o sarcină. De exemplu, atunci când vrem să instalăm o aplicație ​rulăm trei comenzi:+De multe ori vrem să executăm o succesiune de comenzi pentru a realiza o sarcină. De exemplu, atunci când vrem să instalăm o aplicație rulăm trei comenzi:
  
   * O să actualizăm indexul surselor de pachete folosind ''​%%apt update%%''​   * O să actualizăm indexul surselor de pachete folosind ''​%%apt update%%''​
Line 149: Line 118:
   * O să rulăm aplicația pentru a valida că instalarea a fost cu succes.   * O să rulăm aplicația pentru a valida că instalarea a fost cu succes.
  
-Preferăm să înlănțuim cele trei comenzi într-una singură pentru că astfel putem să pornim tot acest proces, să plecăm de la calculator, iar când ne întoarcem avem tot sistemul pregătit.+Preferăm să înlănțuim cele trei comenzi într-una singură pentru că astfel putem să pornim tot acest proces, să plecăm de la calculator, iar când ne întoarcem ​să avem tot sistemul pregătit.
  
 Pentru a înlănțui comenzi în shellul Bash avem trei operatori disponibili:​ Pentru a înlănțui comenzi în shellul Bash avem trei operatori disponibili:​
  
-<​HTML><​ul></​HTML>​ +Operatorul ''​%%;​%%''​ - este folosit pentru separarea comenzilorUrmăm exemplul de mai jos: 
-<​HTML><​li></​HTML><​HTML><​p></​HTML>​Operatorul ''​%%;​%%''​ - este folosit pentru separarea comenzilor Urmăm exemplul de mai jos:<​HTML></​p></​HTML>​+
 <code bash> <code bash>
 student@uso:​~$ mkdir demo; cd demo; touch Hello; ls student@uso:​~$ mkdir demo; cd demo; touch Hello; ls
 Hello Hello
 </​code>​ </​code>​
-<​HTML><​p></​HTML>​În exemplul de mai sus am creat directorul ''​%%demo%%'',​ am navigat în interiorul său, am creat fișierul ''​%%Hello%%''​ și am afișat conținutul directorului. Am făcut toate acestea înlănțuind comenzile ''​%%mkdir%%'',​ ''​%%cd%%'',​ ''​%%touch%%''​ și ''​%%ls%%''​ cu ajutorul operatorului ''​%%;​%%''​.<​HTML></​p></​HTML>​ + 
-<​HTML><​p></​HTML>​Operatorul ''​%%;​%%''​ este folosit pentru separarea comenzilor, dar nu ține cont dacă comenzile anterioare au fost executate cu succes sau nu. Urmăm exemplul de mai jos:<​HTML></​p></​HTML>​+În exemplul de mai sus am creat directorul ''​%%demo%%'',​ am navigat în interiorul său, am creat fișierul ''​%%Hello%%''​ și am afișat conținutul directorului. Am făcut toate acestea înlănțuind comenzile ''​%%mkdir%%'',​ ''​%%cd%%'',​ ''​%%touch%%''​ și ''​%%ls%%''​ cu ajutorul operatorului ''​%%;​%%''​. 
 + 
 +Operatorul ''​%%;​%%''​ este folosit pentru separarea comenzilor, dar nu ține cont dacă comenzile anterioare au fost executate cu succes sau nu. Urmăm exemplul de mai jos: 
 <code bash> <code bash>
 student@uso:​~$ mkdir operators/​demo;​ cd operators/​demo student@uso:​~$ mkdir operators/​demo;​ cd operators/​demo
Line 166: Line 138:
 -bash: cd: operators/​demo:​ No such file or directory -bash: cd: operators/​demo:​ No such file or directory
 </​code>​ </​code>​
-<​HTML><​p></​HTML>​În exemplul de mai sus, comanda ''​%%mkdir%%''​ a eșuat deoarece nu a găsit directorul ''​%%operators%%''​ în care să creeze directorul ''​%%demo%%''​. Cu toate acestea, operatorul ''​%%;​%%''​ doar separă comenzile între ele, așa că și comanda ''​%%cd operators/​demo%%''​ a fost executată, și și aceasta a eșuat deoarece nu există calea ''​%%operators/​demo%%''​.<​HTML></​p></​HTML>​ + 
-<​HTML><​p></​HTML>​Folosim operatorul ''​%%;​%%''​ pentru a înlănțui comenzi care sunt independente unele de altele, ​și deci execuția lor nu depinde de succesul unei comenzi precedente.<​HTML></​p></​HTML><​HTML></​li></​HTML>​ +În exemplul de mai sus, comanda ''​%%mkdir%%''​ a eșuat deoarece nu a găsit directorul ''​%%operators%%''​ în care să creeze directorul ''​%%demo%%''​. Cu toate acestea, operatorul ''​%%;​%%''​ doar separă comenzile între ele, așa că și comanda ''​%%cd operators/​demo%%''​ a fost executată, și și aceasta a eșuatdeoarece nu există calea ''​%%operators/​demo%%''​. 
-<​HTML><​li></​HTML><​HTML><​p></​HTML>​Operatorul binar ''​%%&&​%%''​ (și logic) - execută a doua comandă doar dacă precedenta s-a executat cu succes. Exemplul anterior devine:<​HTML></​p></​HTML>​+ 
 +Folosim operatorul ''​%%;​%%''​ pentru a înlănțui comenzi care sunt independente unele de altele, deci execuția lor nu depinde de succesul unei comenzi precedente. 
 + 
 +Operatorul binar ''​%%&&​%%''​ (//și// logic) - execută a doua comandă doar dacă precedenta s-a executat cu succes. Exemplul anterior devine: 
 <code bash> <code bash>
 student@uso:​~$ mkdir operators/​demo && cd operators/​demo student@uso:​~$ mkdir operators/​demo && cd operators/​demo
 mkdir: cannot create directory ‘operators/​demo’:​ No such file or directory mkdir: cannot create directory ‘operators/​demo’:​ No such file or directory
 </​code>​ </​code>​
-<​HTML><​p></​HTML>​Observăm că din moment ce comanda ''​%%mkdir%%''​ a eșuat, comanda ''​%%cd%%''​ nu a mai fost executată.<​HTML></​p></​HTML><​HTML></​li></​HTML>​ + 
-<​HTML><​li></​HTML><​HTML><​p></​HTML>​Operatorul binar ''​%%||%%''​ (sau logic) - execută a doua comandă doar dacă prima s-a terminat cu eșec. Urmărim exemplul de mai jos:<​HTML></​p></​HTML>​+Observăm că din moment ce comanda ''​%%mkdir%%''​ a eșuat, comanda ''​%%cd%%''​ nu a mai fost executată. 
 + 
 +Operatorul binar ''​%%||%%''​ (//sau// logic) - execută a doua comandă doar dacă prima s-a terminat cu eșec. Urmărim exemplul de mai jos: 
 <code bash> <code bash>
 student@uso:​~$ (ls -d operators || mkdir operators) && ls -d operators student@uso:​~$ (ls -d operators || mkdir operators) && ls -d operators
Line 183: Line 162:
 operators operators
 </​code>​ </​code>​
-<​HTML><​p></​HTML>​În exemplul de mai sus, prima comandă ''​%%ls%%''​ a eșuat, așa că a fost executată comanda ''​%%mkdir%%''​ și apoi a fost executată ultima comandă ''​%%ls%%''​. La cea de-a doua rulare, a fost executată cu succes prima comandă ''​%%ls%%'',​ așa că comanda ''​%%mkdir%%''​ nu a mai fost executată, și apoi a fost executată ultima comandă ''​%%ls%%''​.<​HTML></​p></​HTML><​HTML></​li></​HTML><​HTML></​ul></​HTML>​+ 
 +În exemplul de mai sus, prima comandă ''​%%ls%%''​ a eșuat, așa că a fost executată comanda ''​%%mkdir%%''​ și apoi a fost executată ultima comandă ''​%%ls%%''​. La cea de-a doua rulare, a fost executată cu succes prima comandă ''​%%ls%%'',​ așa că comanda ''​%%mkdir%%''​ nu a mai fost executată, și apoi a fost executată ultima comandă ''​%%ls%%''​.
  
 Pentru a rezolva scenariul de la care am plecat inițial, putem rula: Pentru a rezolva scenariul de la care am plecat inițial, putem rula:
Line 192: Line 172:
 Comanda de mai sus va actualiza indexul pachetelor sursă, va instala pachetul ''​%%cowsay%%''​ și va rula comanda ''​%%cowsay%%''​ pentru a valida instalarea. O astfel de înlănțuire de comenzi este numită **oneliner**. Comanda de mai sus va actualiza indexul pachetelor sursă, va instala pachetul ''​%%cowsay%%''​ și va rula comanda ''​%%cowsay%%''​ pentru a valida instalarea. O astfel de înlănțuire de comenzi este numită **oneliner**.
  
-=== Exerciții === 
- 
-  - Scrieți un oneliner cu ajutorul căruia descărcați arhiva tar de la adresa TODO, creați directorul ''​%%~/​operators/​demo/​tar%%''​ și apoi dezarhivați conținutul în directorul creat. 
-  - Actualizați onelinerul anterior astfel încât, după dezarhivare,​ să pornească compilarea proiectului folosind comanda ''​%%make build%%''​. 
  
 ==== Înlănțuirea comenzilor folosind operatorul | (pipe) ==== ==== Înlănțuirea comenzilor folosind operatorul | (pipe) ====
Line 224: Line 200:
 </​code>​ </​code>​
  
-Până acum am efectuat procesări text pe rezultatul unor comenzi. Folosind operatorul ''​%%|%%''​ și utilitarul ''​%%xargs%%''​ putem să folosim rezultatul pe post de argument pentru altă comandă, ca în exemplul de mai jos:+Până acumam efectuat procesări text pe rezultatul unor comenzi. Folosind operatorul ''​%%|%%''​ și utilitarul ''​%%xargs%%''​ putem să folosim rezultatul pe post de argument pentru altă comandă, ca în exemplul de mai jos:
  
 <code bash> <code bash>
Line 239: Line 215:
 Comanda din exemplul de mai sus afișează informații în format lung despre toate fișierele din directorul curent, excluzând directoarele. Comanda din exemplul de mai sus afișează informații în format lung despre toate fișierele din directorul curent, excluzând directoarele.
  
-Dacă folosim opțiunea ''​%%-p%%''​ a utilitarului ''​%%xargs%%'',​ acesta o să ne afișeze ce comandă urmează să execute și așteaptă confirmarea noastră prin apăsarea tastei ''​%%y%%''​ (yes) sau ''​%%n%%''​ (no). Este recomandat să folosiți opțiunea ''​%%-p%%''​ atunci când vă scrieți onelinerul pentru a verifica ​că comanda pe care urmează să o executați este corectă. În exemplul următor ne dorim să mutăm toate arhivele ​''​%%.tar%%''​ în directorul ''​%%archives%%'':​+Dacă folosim opțiunea ''​%%-p%%''​ a utilitarului ''​%%xargs%%'',​ acesta o să ne afișeze ce comandă urmează să execute și așteaptă confirmarea noastră prin apăsarea tastei ''​%%y%%''​ (yes) sau ''​%%n%%''​ (no). Este recomandat să folosiți opțiunea ''​%%-p%%''​ atunci când vă scrieți onelinerulpentru a verifica ​dacă comanda pe care urmează să o executați este corectă. În exemplul următor ne dorim să mutăm toate fisierele ​''​%%.c%%''​ în directorul ''​%%părinte%%'':​
  
 <code bash> <code bash>
-student@uso:​~$ ls *.tar | xargs -p mv archives +student@uso:​~/​uso-lab/​labs/​06-scripting/​support/​02-one-liners/​rename/​src$ ls *.| xargs -p mv .. 
-mv archives courses.tar labhidden.tar uso.tar wiki.tar ?...n+mv .. casts.c endian.c ptr.c signed-unsigned-representation.c signed-unsigned.c test-hard-link.c use-__thread.c?...
 </​code>​ </​code>​
-Cu ajutorul opțiunii ''​%%-p%%''​ am putut să observăm că comanda nu are sintaxa dorită și am anulat execuția ei. Problema este că avem destinația (''​%%archives%%''​) înaintea ​arhivelor ​care trebuie mutate.+Cu ajutorul opțiunii ''​%%-p%%''​ am putut să observăm că comanda nu are sintaxa dorită și am anulat execuția ei. Problema este că avem destinația (''​%%..%%''​) înaintea ​fișierelor ​care trebuie mutate, iar destinația pentru ''​%%mv%%''​ trebuie să fie la final.
  
 Pentru a rezolva această problemă folosim opțiunea ''​%%-I str%%'',​ ca mai jos: Pentru a rezolva această problemă folosim opțiunea ''​%%-I str%%'',​ ca mai jos:
  
 <code bash> <code bash>
-student@uso:​~$ ls *.tar | xargs -I str -p mv str archives +student@uso:​~/​uso-lab/​labs/​06-scripting/​support/​02-one-liners/​rename/​src$ ls *.| xargs -I str -p mv str .. 
-mv courses.tar archives ​?...n +mv casts.c ..?...n 
-mv labhidden.tar archives ​?...n +mv endian.c ..?...n 
-mv uso.tar archives ​?...n +mv ptr.c ..?...n 
-mv wiki.tar archives ​?...n+mv signed-unsigned-representation.c ..?...n 
 +mv signed-unsigned.c ..?...n 
 +mv test-hard-link.c ..?...n 
 +mv use-__thread.c ..?​...n ​
 </​code>​ </​code>​
-Opțiunea ''​%%-I%%''​ va înlocui șirul de caractere ''​%%str%%''​ cu numele arhivelor primite din pipe, așa cum observăm mai sus. Șirul de caractere placeholder poate să fie orice, nu neapărat ''​%%str%%'';​ comanda ''​%%ls *.tar | xargs -I {} -p mv {} archives%%''​ produce aceelași rezultat.+Opțiunea ''​%%-I%%''​ va înlocui șirul de caractere ''​%%str%%''​ cu numele arhivelor primite din pipe, așa cum observăm mai sus. Șirul de caractere placeholder poate să fie orice, nu neapărat ''​%%str%%'';​ comanda ''​%%ls *.| xargs -I {} -p mv {} ..%%''​ produce aceelași rezultat.
  
 <​note>​ <​note>​
Line 264: Line 243:
 ==== Redirectări ==== ==== Redirectări ====
  
-Majoritatea utilitarelor pe care le folosim afișează rezultatele operațiilor pe care le aplică la ieșirea standard, adică pe ecran. În continuare vom aprofunda ceea ce am discutat despre redirectări în capitolul ​**Lucrul cu Fișiere**. Anterior am mai menționat și termenul de intrare standard; în această secțiune ne vom clarifica ce înseamnă, ce rol îndeplinesc și cum ne folosim de aceste cunoștințe.+Majoritatea utilitarelor pe care le folosim afișează rezultatele operațiilor pe care le aplică la ieșirea standard, adică pe ecran. În continuare vom aprofunda ceea ce am discutat despre redirectări în laboratorul ​**Lucrul cu Fișiere**. Anterior am mai menționat și termenul de intrare standard; în această secțiune ne vom clarifica ce înseamnă, ce rol îndeplinesc și cum ne folosim de aceste cunoștințe.
  
 Orice proces folosește implicit trei fluxuri (streams) de date: Orice proces folosește implicit trei fluxuri (streams) de date:
Line 272: Line 251:
   * **STDERR** - fluxul de ieșire standard al erorilor. Un program corect scris o să scrie erorile în fluxul de ieșire al erorilor. Acest lucru permite filtrarea erorilor.   * **STDERR** - fluxul de ieșire standard al erorilor. Un program corect scris o să scrie erorile în fluxul de ieșire al erorilor. Acest lucru permite filtrarea erorilor.
  
-În linie de comandă, atât STDOUT cât și STDERR vor apărea pe ecran. Datorită faptului că informațiile sunt scrise în două fluxuri distincte, utilizatorul are posibilitatea de a separa rezultatele de erori. Utilizatorul face aceasta folosind redirectări.+În linia de comandă, atât STDOUT cât și STDERR vor apărea pe ecran. Datorită faptului că informațiile sunt scrise în două fluxuri distincte, utilizatorul are posibilitatea de a separa rezultatele de erori. Utilizatorul face aceasta folosind redirectări.
  
 === Redirectarea ieșirilor standard === === Redirectarea ieșirilor standard ===
Line 317: Line 296:
 student@uso:​~$ cat out student@uso:​~$ cat out
 Desktop: Desktop:
-todos.txt 
  
 Documents: Documents:
 snippets.git snippets.git
-uni 
-uso.tar 
  
 Downloads: Downloads:
-courses.tar 
-uso.tar 
 student@uso:​~$ cat errs student@uso:​~$ cat errs
 ls: cannot access '​F*':​ No such file or directory ls: cannot access '​F*':​ No such file or directory
Line 332: Line 306:
 Observăm că am folosit sintaxa ''​%%2>​ errs%%''​ pentru a redirecta erorile în fișierul **errs**. Observăm că pentru a redirecta ieșirea standard putem omite descriptorul de fișier, așa cum am făcut cu ''​%%>​ out%%''​. Observăm că am folosit sintaxa ''​%%2>​ errs%%''​ pentru a redirecta erorile în fișierul **errs**. Observăm că pentru a redirecta ieșirea standard putem omite descriptorul de fișier, așa cum am făcut cu ''​%%>​ out%%''​.
  
-Atunci când rulăm o comandă, redirectăm erorile într-un fișier pentru că vrem să verificăm că totul s-a executat cu succes. De cele mai multe ori suntem în rumătorul scenariu:+Atunci când rulăm o comandă, redirectăm erorile într-un fișier pentru că vrem să verificăm că totul s-a executat cu succes. De cele mai multe ori suntem în următorul scenariu:
  
   - Urmează să executăm o comandă care durează mai mult timp și pentru care nu putem să ținem pasul, cu ochiul liber, cu fluxul de afișare a datelor pe ecran. Un exemplu este compilarea unui proiect mai mare.   - Urmează să executăm o comandă care durează mai mult timp și pentru care nu putem să ținem pasul, cu ochiul liber, cu fluxul de afișare a datelor pe ecran. Un exemplu este compilarea unui proiect mai mare.
uso/laboratoare/laborator-06/inspect-shell.1667839743.txt.gz · Last modified: 2022/11/07 18:49 by iustina.caramida
CC Attribution-Share Alike 3.0 Unported
www.chimeric.de Valid CSS Driven by DokuWiki do yourself a favour and use a real browser - get firefox!! Recent changes RSS feed Valid XHTML 1.0