.\" -*- coding: UTF-8 -*- '\" t .\" Copyright 1991, The Regents of the University of California. .\" Copyright, the authors of the Linux man-pages project .\" .\" SPDX-License-Identifier: BSD-4-Clause-UC .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH exec 3 "17 maja 2025 r." "Linux man\-pages 6.17" .SH NAZWA execl, execlp, execle, execv, execvp, execvpe \- uruchamia plik .SH BIBLIOTEKA Standardowa biblioteka C (\fIlibc\fP,\ \fI\-lc\fP) .SH SKŁADNIA .nf \fB#include \fP .P \fBextern char **environ;\fP .P \fBint execl(const char *\fP\fIpath\fP\fB, const char *\fP\fIarg\fP\fB, ...\fP \fB/*, (char *) NULL */);\fP \fBint execlp(const char *\fP\fIfile\fP\fB, const char *\fP\fIarg\fP\fB, ...\fP \fB/*, (char *) NULL */);\fP \fBint execle(const char *\fP\fIpath\fP\fB, const char *\fP\fIarg\fP\fB, ...\fP \fB /*, (char *) NULL, char *const \fP\fIenvp\fP\fB[] */);\fP \fBint execv(const char *\fP\fIpath\fP\fB, char *const \fP\fIargv\fP\fB[]);\fP \fBint execvp(const char *\fP\fIfile\fP\fB, char *const \fP\fIargv\fP\fB[]);\fP \fBint execvpe(const char *\fP\fIfile\fP\fB, char *const \fP\fIargv\fP\fB[], char *const \fP\fIenvp\fP\fB[]);\fP .fi .P .RS -4 Wymagane ustawienia makr biblioteki glibc (patrz \fBfeature_test_macros\fP(7)): .RE .P \fBexecvpe\fP(): .nf _GNU_SOURCE .fi .SH OPIS Rodzina funkcji \fBexec\fP() zastępuje w pamięci obraz bieżącego procesu obrazem nowego procesu. Funkcje opisane na tej stronie podręcznika są tylko nakładkami dla funkcji \fBexecve\fP(2). (Dodatkowe informacje na temat nadpisywania bieżącego procesu można znaleźć na stronie podręcznika \fBexecve\fP(2)). .P Pierwszym argumentem tych funkcji jest ścieżka do pliku, który ma być uruchomiony. .P .\" Funkcje mogą być pogrupowane na podstawie liter, które następują po przedrostku \[Bq]exec\[rq]. .SS "l \- execl(), execlp(), execle()" Kolejne wyrażenia \fIconst char\ *arg\fP można traktować jako \fIarg0\fP, \fIarg1\fP, \&..., \fIargn\fP. Razem opisują one listę jednego lub więcej wskaźników do zakończonych znakiem NUL łańcuchów, reprezentujących listę argumentów udostępnianych wykonywanemu programowi. Pierwszy argument, zgodnie z konwencją, powinien wskazywać na nazwę pliku powiązaną z wykonywanym plikiem. Lista argumentów \fImusi\fP być zakończona wskaźnikiem null, a ponieważ te funkcje są funkcjami o zmiennej liczbie argumentów, wskaźnik ten musi być rzutowany na \fI(char\ *) NULL\fP. .P .\" W odróżnienie od funkcji zawierających w nazwie \[Bq]l\[rq], poniższe funkcje z \[Bq]v\[rq] określają argumenty wiersza poleceń wykonywanego programu, jako wektor. .SS "v \- execv(), execvp(), execvpe()" Argument \fIchar\ *const argv[]\fP jest tablicą wskaźników do zakończonych znakami NUL łańcuchów reprezentujących listę argumentów dostępnych dla wykonywanego programu. Pierwszy argument, zgodnie z konwencją, powinien wskazywać na nazwę pliku powiązaną z wykonywanym plikiem. Tablica wskaźników \fImusi\fP być zakończona wskaźnikiem null. .SS "e \- execle(), execvpe()" Środowisko nowego obrazu procesu podaje się za pomocą argumentu \fIenvp\fP. Argument \fIenvp\fP jest tablicą wskaźników do zakończonych znakiem NUL łańcuchów znaków i \fImusi\fP być zakończony wskaźnikiem null. .P Wszystkie pozostałe funkcje \fBexec\fP() (które nie zawierają w przyrostku \[Bq]e\[rq]), pobierają środowisko dla obrazu nowego procesu z zewnętrznej zmiennej \fIenviron\fP procesu wywołującego. .SS "p \- execlp(), execvp(), execvpe()" Funkcje te wykonują zadania powłoki, szukając pliku wykonywalnego, jeśli nazwa pliku nie zawiera znaku ukośnika (/). Plik jest wyszukiwany w rozdzielonej dwukropkami liście ścieżek do katalogów podanej w zmiennej środowiskowej \fBPATH\fP. Jeśli ta zmienna nie jest zdefiniowana, lista ścieżek korzysta z listy domyślnej, która zawiera katalogi zwracane przez \fIconfstr(_CS_PATH)\fP (zwykle zwraca wartość \[Bq]/bin:/usr/bin\[rq]) i być może również bieżący katalog roboczy; więcej szczegółów w WERSJACH. .P \fBexecvpe\fP() szuka programu za pomocą wartości zmiennej \fBPATH\fP ze środowiska wywołującego, a nie z argumentu \fIenvp\fP. .P Jeśli podana nazwa pliku zawiera znak ukośnika, to wartość zmiennej \fBPATH\fP jest ignorowana i wykonywany jest plik z podanej lokalizacji. .P Dodatkowo pewne błędy są traktowane w specjalny sposób. .P Jeśli dostęp do pliku został zabroniony (wywołanie \fBexecve\fP(2) zakończyło się błędem \fBEACCES\fP), funkcje te będą przeszukiwać resztę ścieżki. Jeśli jednak nie odnajdą innego pliku, powrócą i ustawią wartość zmiennej \fIerrno\fP na \fBEACCES\fP. .P Jeśli nagłówek nie zostanie rozpoznany (wywołanie \fBexecve\fP(2) zakończy się błędem \fBENOEXEC\fP), funkcje te spróbują uruchomić powłokę (\fI/bin/sh\fP) ze ścieżką do pliku jako pierwszym argumentem. (Jeśli i ta próba się nie powiedzie, przeszukiwanie zostanie zakończone). .P Wszelkie inne funkcje \fBexec\fP() (które nie zawierają \[Bq]p\[rq] w przyrostku) przyjmują jako swój pierwszy argument ścieżkę (względną lub absolutną), która identyfikuje program do wykonania. .SH "WARTOŚĆ ZWRACANA" Funkcje \fBexec\fP() powracają tylko wtedy, gdy wystąpi błąd. Zwracana jest wartość \-1 i ustawiana jest zmienna \fIerrno\fP, określająca rodzaj błędu. .SH BŁĘDY Każda z tych funkcji może zakończyć się niepowodzeniem i ustawić jako wartość \fIerrno\fP dowolny błąd określony dla \fBexecve\fP(2). .SH ATRYBUTY Informacje o pojęciach używanych w tym rozdziale można znaleźć w podręczniku \fBattributes\fP(7). .TS allbox; lbx lb lb l l l. Interfejs Atrybut Wartość T{ .na .nh \fBexecl\fP(), \fBexecle\fP(), \fBexecv\fP() T} Bezpieczeństwo wątkowe MT\-bezpieczne T{ .na .nh \fBexeclp\fP(), \fBexecvp\fP(), \fBexecvpe\fP() T} Bezpieczeństwo wątkowe MT\-bezpieczne env .TE .SH WERSJE .\" glibc commit 1eb8930608705702d5746e5491bab4e4429fcb83 Domyślna ścieżka przeszukiwana (używana, gdy środowisko nie zawiera zmiennej \fBPATH\fP) ukazuje pewne różnice między systemami. Zwykle zawiera \fI/bin\fP i \fI/usr/bin\fP (w tej kolejności), może też zawierać bieżący katalog roboczy. W niektórych innych systemach, bieżący katalog roboczy występuje po \fI/bin\fP i \fI/usr/bin\fP, co ma utrudnić ataki trojanów. Implementacja glibc przez długi czas działała zgodnie z tradycyjnymi wartościami domyślnymi, gdy bieżący katalog roboczy jest umieszczony na początku ścieżki przeszukiwania. Jednak pewien refaktoring kodu, jaki miał miejsce podczas rozwoju glibc 2.24 spowodował zupełne porzucenie bieżącego katalogu roboczego z domyślnej ścieżki przeszukiwania. Ta przypadkowa zmiana zachowania jest uważana za dość pozytywną i nie zostanie odwrócona. .P Zachowanie \fBexeclp\fP() oraz \fBexecvp\fP() w przypadku wystąpienia błędów podczas uruchamiania pliku jest przyjęte jako tradycyjne, ale nie jest udokumentowane przez standard POSIX. BSD (a być może także inne systemy) po napotkaniu błędu \fBETXTBSY\fP czeka przez chwilę i próbuje ponownie. Linux traktuje to jako błąd i powraca natychmiast. .P Tradycyjnie funkcje \fBexeclp\fP() oraz \fBexecvp\fP() ignorowały wszystkie błędy oprócz podanych powyżej oraz \fBENOMEM\fP i \fBE2BIG\fP, po których powracały. Obecnie powracają także wtedy, gdy wystąpi dowolny błąd inny od opisanych powyżej. .SH STANDARDY .TP \fBenviron\fP .TQ \fBexecl\fP() .TQ \fBexeclp\fP() .TQ \fBexecle\fP() .TQ \fBexecv\fP() .TQ \fBexecvp\fP() POSIX.1\-2008. .TP \fBexecvpe\fP() GNU. .SH HISTORIA .TP \fBenviron\fP .TQ \fBexecl\fP() .TQ \fBexeclp\fP() .TQ \fBexecle\fP() .TQ \fBexecv\fP() .TQ \fBexecvp\fP() POSIX.1\-2001. .TP \fBexecvpe\fP() glibc 2.11. .SH USTERKI .\" https://sourceware.org/bugzilla/show_bug.cgi?id=19534 .\" Przed glibc 2.24, \fBexecl\fP() i \fBexecle\fP() korzystały wewnętrznie z \fBrealloc\fP(3) dlatego nie były async\-signal\-safe, co stanowiło naruszenie wymagań POSIX.1. Poprawiono to w glibc 2.24. .SS "Szczegóły typowe dla architektury" Na architekturach sparc i sparc64, \fBexecv\fP() jest udostępnione jako wywołanie systemowe przez jądro (z prototypem ukazanym powyżej) ze względu na kompatybilność z SunOS. Ta funkcja \fInie\fP jest wykorzystywana przez przez funkcję opakowującą \fBexecv\fP() na tych architekturach. .SH "ZOBACZ TAKŻE" \fBsh\fP(1), \fBexecve\fP(2), \fBexecveat\fP(2), \fBfork\fP(2), \fBptrace\fP(2), \fBfexecve\fP(3), \fBsystem\fP(3), \fBenviron\fP(7) .PP .SH TŁUMACZENIE Tłumaczenie niniejszej strony podręcznika: Adam Byrtek , Andrzej Krzysztofowicz , Robert Luberda i Michał Kułach . .PP Niniejsze tłumaczenie jest wolną dokumentacją. Bliższe informacje o warunkach licencji można uzyskać zapoznając się z .UR https://www.gnu.org/licenses/gpl-3.0.html GNU General Public License w wersji 3 .UE lub nowszej. Nie przyjmuje się ŻADNEJ ODPOWIEDZIALNOŚCI. .PP Błędy w tłumaczeniu strony podręcznika prosimy zgłaszać na adres listy dyskusyjnej .MT manpages-pl-list@lists.sourceforge.net .ME .