.\" Copyright (C) 2005, 2013 Michael Kerrisk .\" a few fragments from an earlier (1996) version by .\" Andries Brouwer (aeb@cwi.nl) remain. .\" .\" %%%LICENSE_START(VERBATIM) .\" Permission is granted to make and distribute verbatim copies of this .\" manual provided the copyright notice and this permission notice are .\" preserved on all copies. .\" .\" Permission is granted to copy and distribute modified versions of this .\" manual under the conditions for verbatim copying, provided that the .\" entire resulting derived work is distributed under the terms of a .\" permission notice identical to this one. .\" .\" Since the Linux kernel and libraries are constantly changing, this .\" manual page may be incorrect or out-of-date. The author(s) assume no .\" responsibility for errors or omissions, or for damages resulting from .\" the use of the information contained herein. The author(s) may not .\" have taken the same level of care in the production of this manual, .\" which is licensed free of charge, as they might when working .\" professionally. .\" .\" Formatted or processed versions of this manual, if unaccompanied by .\" the source, must acknowledge the copyright and authors of this work. .\" %%%LICENSE_END .\" .\" Rewritten old page, 960210, aeb@cwi.nl .\" Updated, added strtok_r. 2000-02-13 Nicolás Lichtmaier .\" 2005-11-17, mtk: Substantial parts rewritten .\" 2013-05-19, mtk: added much further detail on the operation of strtok() .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .\" This file is distributed under the same license as original manpage .\" Copyright of the original manpage: .\" Copyright © 1996 Andries Brouwer, 2005,2013 Michael Kerrisk .\" Copyright © of Polish translation: .\" Paweł Wilk (PTM) , 1999. .\" Andrzej Krzysztofowicz (PTM) , 2002. .\" Robert Luberda , 2014. .\" Michał Kułach , 2016. .TH STRTOK 3 2016\-03\-15 GNU "Podręcznik programisty Linuksa" .SH NAZWA strtok, strtok_r \- wydzielanie słów z łańcuchów .SH SKŁADNIA .nf \fB#include \fP .sp \fBchar *strtok(char *\fP\fIstr\fP\fB, const char *\fP\fIdelim\fP\fB);\fP .sp \fBchar *strtok_r(char *\fP\fIstr\fP\fB, const char *\fP\fIdelim\fP\fB, char **\fP\fIsaveptr\fP\fB);\fP .fi .sp .in -4n Wymagane ustawienia makr biblioteki glibc (patrz \fBfeature_test_macros\fP(7)): .in .sp .ad l \fBstrtok_r\fP(): _POSIX_C_SOURCE || /* Glibc w wersji <= 2.19: */ _BSD_SOURCE || _SVID_SOURCE .ad b .SH OPIS Funkcja \fBstrtok\fP() dzieli łańcuch na sekwencję\ zera lub więcej niepustych słów. Przy pierwszym wywołaniu funkcji \fBstrtok\fP(), łańcuch do przetworzenia powinien być podany w \fIstr\fP. W każdym kolejnym wywołaniu, które powinno przetworzyć ten sam łańcuch, \fIstr\fP musi być NULL. Argument \fIdelim\fP określa zbiór bajtów służących do oddzielania słów w przetwarzanym łańcuchu. Program wywołujący może podawać różne argumenty \fIdelim\fP w kolejnych wywołaniach przetwarzających ten sam łańcuch znaków. Każde wywołanie funkcji \fBstrtok\fP() zwraca wskaźnik do zakończonego znakiem null łańcuch zawierającego następne słowo. Łańcuch ten nie zawiera znaku separatora. Jeśli nie ma więcej słów, to \fBstrtok\fP() zwraca NULL. Sekwencja wywołań \fBstrtok\fP() działająca na tym samym łańcuchu znaków przechowuje wskaźnik określający punkt, od którego należy szukać kolejnego słowa. Pierwsze wywołanie \fBstrtok\fP() ustawia ten wskaźnik na pierwszy bajt łańcucha. Początek kolejnego słowa jest określany przez szukanie kolejnego bajtu niebędącego ogranicznikiem w \fIstr\fP. Jeśli taki bajt zostanie znaleziony, to jest uważany za początek kolejnego słowa. Jeśli nie ma takiego bajtu, to nie ma więcej słów i \fBstrtok\fP() zwraca NULL (Łańcuch, który jest pusty, lub taki, który zawiera tylko znaki ogranicznika, spowoduje, że pierwsze wywołanie \fBstrtok\fP() także zwróci NULL). Koniec każdego słowa jest określany przez wyszukanie albo następnego bajtu ogranicznika albo napotkanie kończącego bajtu null (\(aq\e0\(aq). Jeśli zostanie znaleziony bajt ogranicznika, to jest nadpisywany znakiem null, tak aby zakończyć bieżące słowo, a \fBstrtok\fP() zachowuje wskaźnik do kolejnego bajtu; wskaźnik ten będzie użyty jako punkt startowy wyszukiwania kolejnego słowa. W takim przypadku \fBstrtok\fP() zwraca wskaźnik do początku znalezionego słowa. Z powyższego opisu wynika, że sekwencja dwóch lub więcej następujących po sobie bajtów ogranicznika w przetwarzanym łańcuchu jest uważana za pojedynczy ogranicznik i że ograniczniki na początku i końcu łańcucha są zawsze ignorowane. Innymi słowy: słowa zwracane przez \fBstrtok\fP() są zawsze niepustymi łańcuchami znaków. Dlatego na przykład kolejne wywołanie \fBstrtok\fP() dla łańcucha "\fIaaa;;bbb,\fP" z łańcuchem ograniczników "\fI;,\fP" zwrócą słowa "\fIaaa\fP" oraz "\fIbbb\fP", a następnie zwrócą wskaźnik null. Funkcja \fBstrtok_r\fP() jest wielowątkową wersją \fBstrtok\fP(). Argument \fIsaveptr\fP jest wskaźnikiem do zmiennej typu \fIchar\ *\fP, używanej wewnętrznie przez \fBstrtok_r\fP() do zachowania kontekstu pomiędzy kolejnymi wywołaniami przetwarzającymi ten sam łańcuch znaków. Podczas pierwszego wywołania \fBstrtok_r\fP() argument \fIstr\fP powinien wskazywać na łańcuch do przetworzenia, a wartość \fIsaveptr\fP jest ignorowana. W kolejnych wywołaniach \fIstr\fP powinien być równy NULL, a \fIsaveptr\fP nie powinien być zmieniony od poprzedniego wywołania. Różne łańcuchy znaków mogą być przetwarzane równocześnie przy użyciu sekwencji wywołań \fBstrtok_r\fP(), różniących się argumentami \fIsaveptr\fP. .SH "WARTOŚĆ ZWRACANA" Funkcje \fBstrtok\fP() i \fBstrtok_r\fP() zwracają wskaźnik do następnego słowa lub NULL, jeśli nie ma już więcej słów. .SH ATRYBUTY Informacje o pojęciach używanych w tym rozdziale można znaleźć w podręczniku \fBattributes\fP(7). .TS allbox; lb lb lb l l l. Interfejs Atrybut Wartość T{ \fBstrtok\fP() T} Bezpieczeństwo wątkowe MT\-Unsafe race:strtok T{ \fBstrtok_r\fP() T} Bezpieczeństwo wątkowe MT\-Safe .TE .SH "ZGODNE Z" .TP \fBstrtok\fP() POSIX.1\-2001, POSIX.1\-2008, C89, C99, SVr4, 4.3BSD. .TP \fBstrtok_r\fP() POSIX.1\-2001, POSIX.1\-2008. .SH "BŁĘDY IMPLEMENTACJI" Nigdy nie należy używać tych funkcji. Jeśli jednak zostaną użyte, to należy zauważyć, że: .IP * 2 Funkcje te modyfikują swój pierwszy argument. .IP * Funkcje ta nie mogą być stosowana z ciągami stałymi. .IP * Tożsamość bajtu separatora jest tracona. .IP * Funkcja \fBstrtok\fP() korzysta ze statycznego bufora, więc nie jest przystosowana do wielowątkowości. Jeśli ma to znaczenie, należy używać \fBstrtok_r\fP(). .SH PRZYKŁAD Poniższy program używa zagnieżdżonych pętli, stosując \fBstrtok_r\fP() do podzielenia łańcucha na dwupoziomową hierarchię słów. Pierwszy argument linii poleceń określa łańcuch do przetworzenia. Drugi argument podaje bajty ograniczające używane do dzielenia łańcucha na "główne" słowa. Trzeci argument określa bajty służące do dzielenia "głównych" słów na podsłowa. .PP Przykładowe wyjście programu jest następujące: .PP .in +4n .nf $\fB ./a.out \(aqa/bbb///cc;xxx:yyy:\(aq \(aq:;\(aq \(aq/\(aq\fP 1: a/bbb///cc \-\-> a \-\-> bbb \-\-> cc 2: xxx \-\-> xxx 3: yyy \-\-> yyy .fi .in .SS "Żródło programu" \& .nf #include #include #include int main(int argc, char *argv[]) { char *str1, *str2, *token, *subtoken; char *saveptr1, *saveptr2; int j; if (argc != 4) { fprintf(stderr, "Użycie: %s string delim subdelim\en", argv[0]); exit(EXIT_FAILURE); } for (j = 1, str1 = argv[1]; ; j++, str1 = NULL) { token = strtok_r(str1, argv[2], &saveptr1); if (token == NULL) break; printf("%d: %s\en", j, token); for (str2 = token; ; str2 = NULL) { subtoken = strtok_r(str2, argv[3], &saveptr2); if (subtoken == NULL) break; printf("\t \-\-> %s\en", subtoken); } } exit(EXIT_SUCCESS); } .fi .PP Inny przykładowy program używający \fBstrtok\fP() można znaleźć w \fBgetaddrinfo_a\fP(3). .SH "ZOBACZ TAKŻE" \fBindex\fP(3), \fBmemchr\fP(3), \fBrindex\fP(3), \fBstrchr\fP(3), \fBstring\fP(3), \fBstrpbrk\fP(3), \fBstrsep\fP(3), \fBstrspn\fP(3), \fBstrstr\fP(3), \fBwcstok\fP(3) .SH "O STRONIE" Angielska wersja tej strony pochodzi z wydania 4.07 projektu Linux \fIman\-pages\fP. Opis projektu, informacje dotyczące zgłaszania błędów oraz najnowszą wersję oryginału można znaleźć pod adresem \%https://www.kernel.org/doc/man\-pages/. .SH TŁUMACZENIE Autorami polskiego tłumaczenia niniejszej strony podręcznika man są: Paweł Wilk (PTM) , Andrzej Krzysztofowicz (PTM) , Robert Luberda i Michał Kułach . .PP Polskie tłumaczenie jest częścią projektu manpages-pl; uwagi, pomoc, zgłaszanie błędów na stronie http://sourceforge.net/projects/manpages-pl/. Jest zgodne z wersją \fB 4.07 \fPoryginału.