aboutsummaryrefslogtreecommitdiffstats
path: root/man3
AgeCommit message (Collapse)AuthorFilesLines
2022-02-24mode_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+31
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24div_t.3, lldiv_t.3, system_data_types.7: Move lldiv_t to div_t.3Alejandro Colomar2-5/+11
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24div_t.3, ldiv_t.3, system_data_types.7: Move ldiv_t to div_t.3Alejandro Colomar2-5/+11
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24lconv-struct.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+45
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24intN_t.3: Document the [U]INTN_* macrosAlejandro Colomar1-0/+53
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24intN_t.3, uint16_t.3, uint32_t.3, uint64_t.3, uint8_t.3, uintN_t.3, ↵Alejandro Colomar6-24/+50
system_data_types.7: Move uintN_t to intN_t.3 Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24intN_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar5-5/+84
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24intmax_t.3: Document the [U]INTMAX_* macrosAlejandro Colomar1-13/+28
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24intmax_t.3, uintmax_t.3, system_data_types.7: Move uintmax_t to intmax_t.3Alejandro Colomar2-9/+31
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24intmax_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+50
I also reworded the text slightly to talk about 'basic integer types', not 'integer types', to more clearly exclude 'extended integer types'. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24div_t.3, imaxdiv_t.3, system_data_types.7: Move imaxdiv_t to div_t.3Alejandro Colomar2-4/+18
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24id_t.3, uid_t.3, system_data_types.7: Move uid_t to id_t.3Alejandro Colomar2-2/+22
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24id_t.3, pid_t.3, system_data_types.7: Move pid_t to id_t.3Alejandro Colomar2-4/+40
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24gid_t.3, id_t.3, system_data_types.7: Move gid_t to id_t.3Alejandro Colomar2-5/+31
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24id_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+25
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24FILE.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+25
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24fenv_t.3, system_data_types.7: Move fexcept_t to fenv_t.3Alejandro Colomar2-4/+11
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24fenv_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+17
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24double_t.3, float_t.3, system_data_types.7: Move float_t to double_t.3Alejandro Colomar2-23/+26
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24double_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+41
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24div_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+20
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24dev_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+23
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24clockid_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+24
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24clock_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+26
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24cc_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+17
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24blksize_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+20
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24blkcnt_t.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+20
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24aiocb-struct.3, system_data_types.7: Move text to a separate pageAlejandro Colomar1-1/+31
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24usleep.3: Remove incorrect portability noteAlejandro Colomar1-18/+1
That note against using useconds_t if portability is important was probably true before POSIX, but since POSIX specifies the type in <sys/types.h>, as recently documented in useconds_t(3), the type should be fine to use portably. Moreover, using it helps document the code, so we better completely remove that warning. Add a SEE ALSO entry for useconds_t(3). Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24useconds_t.3: New link to system_data_types(7)Alejandro Colomar1-0/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-02-24aiocb-struct.3, lconv-struct.3, sigevent-struct.3, sigval-union.3, ↵Alejandro Colomar7-0/+1
sockaddr-struct.3, timespec-struct.3, timeval-struct.3: Rename some links to system_data_types.7 to add -{struct,union} suffix This avoids shadowing other pages, and clearly differentiates function pages from type pages (both are in man3). Do this for struct/union types, and not for typedefs. This makes sense because typedefs in C are in the same namespace as function identifiers, but struct and union (and enum) tags are in a different one, and can have the same name as a function. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Cc: G. Branden Robinson <g.branden.robinson@gmail.com>
2022-02-24stat-struct.3: New link to system_data_types(7)Alejandro Colomar1-0/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Cc: G. Branden Robinson <g.branden.robinson@gmail.com>
2022-02-04fmemopen.3: wfixAlejandro Colomar1-1/+1
Fix incorrect identifier. Reported-by: Lucien Gentis <lucien.gentis@waika9.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-01-25termios.3: Clarify ONLRETSimon Branch1-1/+3
While perusing various termios(3) and termios(4) manpages, I noticed the following inconsistency for ONLRET. FreeBSD and NetBSD say this: If ONLRET is set, the NL character is assumed to do the carriage-return function; the column pointer will be set to 0. OpenBSD says this: If ONLRET is set, NL also performs CR on output, and reset current column to 0. POSIX says this: NL performs CR function. The current Linux manpage says this (!): Don't output CR. Here's a snippet that demonstrates Linux's behavior (tl;dr it's just like the other operating systems): $ stty -icanon -onlcr -icrnl -echo onlret onocr; cat this is some text (^J pressed) and some more (^M pressed before additional text) The first flags (-icanon -onlcr -icrnl -echo), combined with cat, ensure that our keys are sent directly back to the terminal emulator without any translation or buffering. The last two (ONLRET and ONOCR) are the important ones: ONLRET makes Linux think that the cursor is at column 0 after the ^J, and ONOCR makes Linux ignore the following ^M. Signed-off-by: Simon Branch <simonmbranch@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Cc: Pali Rohár <pali@kernel.org>
2022-01-25strsep.3: Minor tweaks to наб's patchAlejandro Colomar1-2/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-01-25strsep.3: port strtok(3) exampleнаб1-0/+50
Each time I use strsep I want something like this; this serves to snappily highlight the programming model, esp. in contrast to strtok_r ‒ I elided the long (and, frankly, gratuitous, even there) argv explanation ‒ if you need it, you can read the original (or the usage string, or the seven-line main) Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-01-25strtok.3: fix \t literal instead of \et in exampleнаб1-1/+1
Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-01-25strsep.3: tfixнаб1-1/+1
Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-01-11glob.3: srcfixнаб1-1/+2
For consistency: this is the only non-false-positive for ", and", which now reads: $ git grep '", and"' man2/ioctl_tty.2:.BR "#include <termios.h>" " /* Definition of " CLOCAL ", and" Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-01-08strtok.3: Fix j/str1 declarationStephen Kitt1-1/+2
for (int j = 1, str1 = argv[1]; ... declares two variables of type int, j and str1; the pre-existing char * str1 isn't used. This causes compiler warnings. Declaring j outside the loop fixes everything. Signed-off-by: Stephen Kitt <steve@sk2.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-01-08mq_notify.3: Add signal.h for SIGEV_ constantsStephen Kitt1-0/+2
The example program needs signal.h to build correctly, since the SIGEV_ constants are defined through signal.h; also document that in the synopsis. Signed-off-by: Stephen Kitt <steve@sk2.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2022-01-08newlocale.3: Use LC_GLOBAL_LOCALE, not ..._HANDLEStephen Kitt1-1/+1
LC_GLOBAL_HANDLE has never existed; the locale object handle to use to refer to the global locale determined by setlocale(3) is LC_GLOBAL_LOCALE. See uselocale(3) for details. [Jakub]: $ cc -Wall newlocale-example.c newlocale-example.c: In function 'main': newlocale-example.c:67:15: error: 'LC_GLOBAL_HANDLE' undeclared (first use in this function); did you mean 'LC_GLOBAL_LOCALE'? 67 | uselocale(LC_GLOBAL_HANDLE); /* So 'loc' is no longer in use */ | ^~~~~~~~~~~~~~~~ | LC_GLOBAL_LOCALE newlocale-example.c:67:15: note: each undeclared identifier is reported only once for each function it appears in Signed-off-by: Stephen Kitt <steve@sk2.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Cc: Jakub Wilk <jwilk@jwilk.net>
2022-01-08inet.3: Switch to _DEFAULT_SOURCE in the exampleStephen Kitt1-1/+1
_BSD_SOURCE has been obsolete for long enough that it seems reasonable to update the example program to use _DEFAULT_SOURCE instead. Signed-off-by: Stephen Kitt <steve@sk2.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-12-31encrypt.3: encrypt/encrypt_r, not crypt/crypt_r were deleted from 2.28Huang Pei1-2/+2
See sysdeps/unix/sysv/linux/riscv/rv{32,64}/libcrypt.abilist from glibc [alx]: Confirmed. See the following: $ git checkout glibc-2.28 Previous HEAD position was 23158b08a0 Update for 2.27 release HEAD is now at 3c03baca37 Update NEWS, version.h, and features.h for glibc 2.28. $ $ grep_glibc_prototype crypt crypt/crypt.h:36: extern char *crypt (const char *__phrase, const char *__salt) __THROW __nonnull ((1, 2)); posix/unistd.h:1124: extern char *crypt (const char *__key, const char *__salt) __THROW __nonnull ((1, 2)); $ $ grep_glibc_prototype encrypt $ $ git checkout glibc-2.27 Previous HEAD position was 3c03baca37 Update NEWS, version.h, and features.h for glibc 2.28. HEAD is now at 23158b08a0 Update for 2.27 release $ $ grep_glibc_prototype crypt crypt/crypt.h:32: extern char *crypt (const char *__key, const char *__salt) __THROW __nonnull ((1, 2)); posix/unistd.h:1126: extern char *crypt (const char *__key, const char *__salt) __THROW __nonnull ((1, 2)); $ $ grep_glibc_prototype encrypt crypt/crypt.h:40: extern void encrypt (char *__glibc_block, int __edflag) __THROW __nonnull ((1)); posix/unistd.h:1131: extern void encrypt (char *__glibc_block, int __edflag) __THROW __nonnull ((1)); $ Signed-off-by: Huang Pei <huangpei@loongson.cn> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-12-22printf.3: Add VERSIONSAlejandro Colomar1-40/+40
CONFORMING TO contained info that should be in VERSIONS. Add a new VERSIONS section and move that text. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-12-22printf.3: Document %#m as strerrorname_np(errno)Alejandro Colomar1-1/+22
Reported-by: Adhemerval Zanella <adhemerval.zanella@linaro.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Cc: libc-alpha@sourceware.org Cc: Florian Weimer <fweimer@redhat.com> Cc: Michael Kerrisk <mtk.manpages@gmail.com>
2021-12-18pthread_cancel.3, pthread_cleanup_push_defer_np.3, pthread_setcancelstate.3, ↵Samanta Navarro9-60/+60
pthread_testcancel.3, pthreads.7: tfix Changed cancellation to cancelation. Signed-off-by: Samanta Navarro <ferivoz@riseup.net> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-12-06Many pages: replace in-line struct timespec declarations with "timespec(3) ↵наб4-42/+17
structure" references Also stripped "as specified in <time.h>" from clock_getres.2, as it already lives in <time.h>. Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-11-23getpwnam.3: EXAMPLES: Fix signednessAlejandro Colomar1-1/+1
sysconf(3) returns a long. Since it can return -1 (and we're making use of that value), we can't use size_t for bufsize. Use long. Link: <https://bugzilla.kernel.org/show_bug.cgi?id=215097> Reported-by: Fabian <fabian@ritter-vogt.de> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-11-22pthread_atfork.3: wfix.Elliott Hughes1-6/+6
Clarify that the pthread_atfork() callback list is a global, not per-thread. The use of "this thread" implied to some readers that pthread_atfork() maintained per-thread lists of callbacks. Given that the next sentence already explains that the callbacks are run in the context of the thread that calls fork(), I actually think it would be fine not to mention threads at all in the earlier sentence, but for now I've gone with what I think was intended to be written. This patch also attempts to clarify other references to "thread", and fixes a trivial typo "form" instead of "fork". Signed-off-by: Elliott Hughes <enh@google.com> Cc: Florian Weimer <fweimer@redhat.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-11-02system.3: It doesn't call fork anymoreAlejandro Colomar1-2/+2
Reported-by: Michael Kearney <mikekearney85@hotmail.com> Cc: Adhemerval Zanella <zatrazz@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-10-27pow.3: RETURN VALUE: Clarify that -0.0 is a valid underflow resultAlejandro Colomar1-1/+1
The standards are a bit unclear (or I couldn't find it), but Joseph confirmed that glibc documents this behavior, and M. Welinder tested that Solaris also behaves in the same way. Reported-by: M. Welinder <mwelinder@gmail.com> Bug: 214815 <https://bugzilla.kernel.org/show_bug.cgi?id=214815> Cc: Joseph Myers <joseph@codesourcery.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-10-27pow.3: RETURN VALUE: Reorder special cases as in the standardAlejandro Colomar1-44/+63
Use the following order: - Success - Over/Underflow - Special cases specified by the standard (in the same order) - Other special cases not specified by the standard. This way it's easier to compare this document against the standard to check for any mistakes or differences. I also added a comment at the beginning of each case, to more clearly delimit special cases, with a syntax that is easy to read (a mix of C, mathematical language, ...). We may want to use those as tagged paragraphs. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Cc: M. Welinder <mwelinder@gmail.com>
2021-10-25getgrouplist.3: wfixAlejandro Colomar1-1/+1
Reported-by: Tobias Stoeckmann <tobias@stoeckmann.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-10-25getgrouplist.3: Place variable definitions on top of functionAlejandro Colomar1-1/+2
Reported-by: Tobias Stoeckmann <tobias@stoeckmann.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-10-07tzset.3: tfixAlejandro Colomar1-1/+1
Reported-by: Stefan Puiu <stefan.puiu@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-10-07tzset.3: ffixJakub Wilk1-1/+1
Use \- for minus sign Signed-off-by: Jakub Wilk <jwilk@jwilk.net> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-10-02rpmatch.3: clarify availability to glibc, Fx, and AIXнаб1-3/+2
"On a few other systems" is misleading, implying that it's available on /this/ system; this is not strictly true, seeing as musl doesn't have it Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-10-02rpmatch.3: clarify first-character-only FUDнаб1-12/+8
It's plain not true as-written ‒ locales can and do provide longer matches (Aramaic has a "አዎን" alternative, for example) ‒ but it's important to note that (a) this may be an issue and (b) nonetheless this is the right way to process this Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-09-19alloca.3: simplfy malloc(3) suite comparison, note VLAsнаб1-5/+9
alloca() is, ex definitione, always faster than any allocator that actually, well, allocates Like Alejandro noted, VLAs can provide a less-flexible but sometimes better-suited solution to the same problem class Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-09-19alloca.3: remove GCC faffling from NOTESнаб1-37/+15
Chunks of glibc headers have no place in documenting an interface, and (__builtin_)alloca() is an intrinsic, not code; those days are, thankfully, long gone Also, clarify standards behaviour (and remove the (outdated!) list of cc(1) switches) regarding when alloca() is allowed to not be ODR-usable Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-09-19alloca.3: clarify reasoning for no error return in BUGSнаб1-3/+4
A stack lasts from some high point until it runs off the back of the pages allocated, making detecting errors impossible, save for actually trying to access said unallocated page Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-09-15alloca.3: clarify origins in CONFORMING TOнаб1-4/+1
alloca() is supported by PWB/UNIX[1] (V6) and UNIX/32V[2] (V7), for the PDP-11 and VAX, respectively; the former trickles into UNIX System III[3], and the latter into 3BSD[4] and later[5] 1: https://ftp.okass.net/pub/mirror/minnie.tuhs.org/Distributions/USDL/spencer_pwb.tar.gz sys/source/s4/util/alloca.s 2: https://ftp.okass.net/pub/mirror/minnie.tuhs.org/Distributions/USDL/32V/32v_usr.tar.gz usr/src/libc/sys/alloca.s 3: https://vetusware.com/download/UNIX%20System%20III%20Source%20Code%20SYSIII/?id=11576 4: https://ftp.okass.net/pub/mirror/minnie.tuhs.org/Distributions/UCB/ 5: https://archive.org/details/The_CSRG_Archives_CD-ROM_3_August_1998_Marshall_Kirk_McKusick Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-09-15strdup.3: drop mention of "the GNU GCC suite"наб1-3/+0
str[n]dupa() are available on every modern compiler platform, incl. Clang, ICC, &c. By shortening the third paragraph, it now reads strdupa() and strndupa() are similar, but use alloca(3) to allocate the buffer. pointing squarely to alloca(3), which is scary enough, so drop the extraneous warning, too ‒ this clearly points to "see alloca(3) for the limitations of that allocator". Plus, it's not like malloc(3) doesn't have its problems, too, but I don't see those being touted in the first paragraph; reducing these to the bare minimum, strdup() copies into malloc(3) and you can free it with free(3), strndup() likewise, but up to n, and str[n]dupa() use alloca(3) instead ‒ be wary of what alloca(3) does! doesn't really make sense ‒ it's obvious that, ex definitione, alloca(3) suffers from alloca(3) problems and input limits, just like malloc(3) from the malloc(3) suite's. Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz>
2021-09-11termios.3: srcfixAlejandro Colomar1-50/+76
Replace a list with .nf,.ft,.fi requests and hardcoded tabs, by commonly used (some not so common, such as TQ, but simple) macros: .RS,.RE,.TP,.TQ,.B Reported-by: G. Branden Robinson <g.branden.robinson@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-09-10termios.3: CIBAUD and IBSHIFT are implemented on Linux, just unsupported by ↵Pali Rohár1-1/+6
glibc Signed-off-by: Pali Rohár <pali@kernel.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com>
2021-08-31malloc.3: Clarify that realloc() may move the memory blockMichael Kerrisk1-1/+2
Make it clearer, early in the discussion, that realloc() may move the block. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-31malloc.3: wfixMichael Kerrisk1-1/+2
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-31malloc.3: ffixMichael Kerrisk1-1/+3
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-31malloc.3: Add some structuring to improve readabilityMichael Kerrisk1-6/+11
Add some subsection (.SS) headings and paragraph breaks in DESCRIPTION, to make the page more easily readable. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-31malloc_hook.3: Modernize for glibc 2.34Paul Eggert1-3/+10
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-31malloc.3: Modernize for glibc 2.34Paul Eggert1-84/+79
glibc has tightened up its rules for replacing the memory allocator. I went through the malloc man page and looked for how it documented malloc() and related functions, and fixed discrepancies with glibc malloc() documentation and/or implementation. I also reorganized the portability discussion so that portability issues can be seen more clearly. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-31termios.3: Use bold style for B0Pali Rohár1-1/+3
Signed-off-by: Pali Rohár <pali@kernel.org> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-31termios.3: wfixMichael Kerrisk1-1/+1
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-31termios.3: Clarify zero argument for cfsetispeed()Pali Rohár1-1/+5
Zero in this case refers to literal constant 0 and not symbolic constant B0. Signed-off-by: Pali Rohár <pali@kernel.org> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-27iconv.1, ldd.1, accept.2, access.2, add_key.2, arch_prctl.2, bpf.2, chmod.2, ↵Michael Kerrisk20-20/+20
chown.2, close_range.2, copy_file_range.2, execve.2, execveat.2, fanotify_mark.2, futex.2, futimesat.2, getpriority.2, intro.2, ioctl_tty.2, keyctl.2, link.2, membarrier.2, mkdir.2, mknod.2, mlock.2, mount.2, mount_setattr.2, open.2, open_by_handle_at.2, perf_event_open.2, pidfd_open.2, readlink.2, readv.2, rename.2, request_key.2, seccomp.2, sigaction.2, stat.2, statx.2, symlink.2, syscalls.2, umount.2, unlink.2, utimensat.2, wait.2, bsearch.3, fflush.3, getaddrinfo.3, getauxval.3, getopt.3, getsubopt.3, mkfifo.3, pthread_mutex_consistent.3, pthread_setname_np.3, pthread_tryjoin_np.3, scandir.3, sem_wait.3, stailq.3, strlen.3, strstr.3, termios.3, tsearch.3, wcslen.3, wcstok.3, wordexp.3, proc.5, capabilities.7, cgroups.7, fanotify.7, mount_namespaces.7, namespaces.7, path_resolution.7, pipe.7, posixoptions.7, user_namespaces.7, vdso.7, iconvconfig.8, ld.so.8: tstamp Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-27getaddrinfo.3: Note that 'errno' is set in parallel with EAI_SYSTEMAlejandro Colomar1-2/+2
The previous wording wasn't very explicit, leaving room for believing that 'errno' may be 0 after returning EAI_SYSTEM. Use a wording similar to other pages, for added consistency. [mtk: edited commit message title; also, POSIX notes that 'errno' is set in this case.] Reported-by: Cristian Morales Vega <christian.morales.vega@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-20getumask.3: Remove pageMichael Kerrisk1-67/+0
This function was never implemented on Linux. It seems pointless to retain such a page 20 years after it was written.
2021-08-18strsignal.3: wfixMichael Kerrisk1-1/+1
In NAME line, one of the instances of "sigdescr_np" should be "sigabbrev_np". Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-18strsignal.3: tfixMichael Kerrisk1-2/+2
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-18tsearch.3: NAME: add twalk_rMichael Kerrisk1-1/+1
This function is described in the page. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-18sigqueue.3: tfixMichael Kerrisk1-1/+1
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-18readv.2, pthread_tryjoin_np.3, stailq.3, strlen.3, wcslen.3: Arrange .SH ↵Michael Kerrisk4-25/+25
sections in correct order Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-18intro.2, mount_setattr.2, seccomp_unotify.2, fflush.3, ↵Michael Kerrisk2-2/+2
pthread_mutex_consistent.3: Place SEE ALSO entries in correct order Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-18chmod.2, chown.2, open.2, mkdir.2, mknod.2, readlink.2, stat.2, symlink.2, ↵Michael Kerrisk3-35/+30
mkfifo.3, scandir.3, sem_wait.3: ERRORS: combine errors into a single alphabetic list These pages split out extra errors for some APIs into a separate list. Probably, the pages are easier to ready if all errors are combined into a single list. Note that there still remain a few pages where the errors are listed separately for different APIs. For the moment, it seems best to leave those pages as is, since the error lists are largely distinct in those pages. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-18arch_prctl.2, perf_event_open.2, pthread_tryjoin_np.3: ERRORS: correct ↵Michael Kerrisk1-5/+5
alphabetic order Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-18getpass.3: wfixMichael Kerrisk1-1/+0
Remove redundant phrase. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-12fanotify_mark.2, futimesat.2, mount_setattr.2, statx.2, symlink.2, mkfifo.3: ↵Michael Kerrisk1-0/+5
Refer the reader to openat(2) for explanation of why 'dirfd' is useful Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-12scandir.3: wfixMichael Kerrisk1-1/+1
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-12mkfifo.3: wfixMichael Kerrisk1-1/+1
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-12access.2, chmod.2, chown.2, execveat.2, futimesat.2, link.2, mkdir.2, ↵Michael Kerrisk2-2/+10
mknod.2, mount_setattr.2, open.2, open_by_handle_at.2, readlink.2, rename.2, stat.2, statx.2, symlink.2, unlink.2, utimensat.2, mkfifo.3, scandir.3: Fix EBADF error description Make the description of the EBADF error for invalid 'dirfd' more uniform. In particular, note that the error only occurs when the pathname is relative, and that it occurs when the 'dirfd' is neither valid *nor* has the value AT_FDCWD. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-10pthread_setname_np.3: EXAMPLES: remove a bug by simplify the codeMichael Kerrisk1-2/+1
From an email conversation with Alexis: Hello Alexis, On 8/6/21 7:06 PM, Alexis Wilke wrote: > Hi guys, > > The pthread_setname_np(3) manual page has an example where the second > argument is used to get a size of the thread name. > > https://man7.org/linux/man-pages/man3/pthread_setname_np.3.html#EXAMPLES > > The current code: > > rc = pthread_getname_np(thread, thread_name, > (argc > 2) ? atoi(argv[1]) : NAMELEN); > > The suggested code: > > rc = pthread_getname_np(thread, thread_name, > (argc > 2) ? atoi(argv[2]) : NAMELEN); I agree that there's a problem, but I think we could go even simpler: rc = pthread_getname_np(thread, thread_name, NAMELEN); > I'm thinking that maybe the author meant to compute the length like so: > > rc = pthread_getname_np(thread, thread_name, > (argc > 2) ? strlen(argv[1]) + 1 : > NAMELEN); > > But I think that the atoi() points to using argv[2] as a number > representing the length. > > (Of course, it should be tested against NAMELEN as a maximum, but I > understand that examples do not always show how to verify each possible > error). I imagine that the author's intention was to allow the user to do experiments where argv[2] specified a number less than NAMELEN, in order to see the resulting ERANGE error. But, that experiment is of limited value, and complicates the code unnecessarily, IMO, so that's why I made the change above. -- Michael Kerrisk Linux man-pages maintainer; http://www.kernel.org/doc/man-pages/ Linux/UNIX System Programming Training: http://man7.org/training/ Reported-by: Alexis Wilke <alexis@m2osw.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-10wcstok.3: Fix type mismatch in the exampleJakub Wilk1-2/+2
Signed-off-by: Jakub Wilk <jwilk@jwilk.net> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09localedef.1, access.2, ioctl_console.2, ioctl_fslabel.2, openat2.2, write.2, ↵Michael Kerrisk5-8/+14
dlsym.3, getopt.3, nl_langinfo.3, termios.3, xcrypt.3, hosts.equiv.5, nsswitch.conf.5, cgroups.7, man-pages.7, netlink.7, system_data_types.7: srcfix: semantic newlines Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09nl_langinfo.3: wfixMichael Kerrisk1-1/+1
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09getopt.3: Minor tweak to James's patchAlejandro Colomar1-1/+1
Cc: James O. D. Hunt <jamesodhunt@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09getopt.3: Further clarification of optstringJames O. D. Hunt1-1/+9
Explain that `optstring` cannot contain a semi-colon (`;`) character. [mtk: verified with a small test program; see also posix/getopt.c in the glibc sources: if (temp == NULL || c == ':' || c == ';') { if (print_errors) fprintf (stderr, _("%s: invalid option -- '%c'\n"), argv[0], c); d->optopt = c; return '?'; } ] Also explain that `optstring` can include `+` as an option character, possibly in addition to that character being used as the first character in `optstring` to denote `POSIXLY_CORRECT` behaviour. [mtk: verified with a small test program.] Test program below. Example runs: $ ./a.out -+ opt = 43 (+); optind = 2 Got plus $ ./a.out -';' ./a.out: invalid option -- ';' opt = 63 (?); optind = 2; optopt = 59 (;) Unrecognized option (-;) Usage: ./a.out [-p arg] [-x] Signed-off-by: James O. D. Hunt <jamesodhunt@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com> 8x---8x---8x---8x---8x---8x---8x---8x---8x---8x---8x--- #include <ctype.h> #include <sys/types.h> #include <stdio.h> #include <stdlib.h> #include <unistd.h> #define printable(ch) (isprint((unsigned char) ch) ? ch : '#') static void /* Print "usage" message and exit */ usageError(char *progName, char *msg, int opt) { if (msg != NULL && opt != 0) fprintf(stderr, "%s (-%c)\n", msg, printable(opt)); fprintf(stderr, "Usage: %s [-p arg] [-x]\n", progName); exit(EXIT_FAILURE); } int main(int argc, char *argv[]) { int opt, xfnd; char *pstr; xfnd = 0; pstr = NULL; while ((opt = getopt(argc, argv, "p:x+;")) != -1) { printf("opt =%3d (%c); optind = %d", opt, printable(opt), optind); if (opt == '?' || opt == ':') printf("; optopt =%3d (%c)", optopt, printable(optopt)); printf("\n"); switch (opt) { case 'p': pstr = optarg; break; case 'x': xfnd++; break; case ';': printf("Got semicolon\n"); break; case '+': printf("Got plus\n"); break; case ':': usageError(argv[0], "Missing argument", optopt); case '?': usageError(argv[0], "Unrecognized option", optopt); default: printf("Unexpected case in switch()\n"); exit(EXIT_FAILURE); } } if (xfnd != 0) printf("-x was specified (count=%d)\n", xfnd); if (pstr != NULL) printf("-p was specified with the value \"%s\"\n", pstr); if (optind < argc) printf("First nonoption argument is \"%s\" at argv[%d]\n", argv[optind], optind); exit(EXIT_SUCCESS); }
2021-08-09termios.3: wfixMichael Kerrisk1-3/+3
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09termios.3: SPARC architecture has 4 different Bnnn constantsPali Rohár1-0/+23
SPARC is special, it does not have Bnnn constants for baud rates above 2000000. Instead it defines 4 Bnnn constants with smaller baud rates. This difference between SPARC and non-SPARC architectures is present in both glibc API (termios.h) and also kernel ioctl API (asm/termbits.h). Signed-off-by: Pali Rohár <pali@kernel.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09termios.3: ffixAlejandro Colomar1-7/+17
Format variable parts of words referring to a group of identifiers in italics, following groff_man(7) recommendations. Also srcfix surrounding uses of \f escape sequences to use macros Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09termios.3: Add information how to set baud rate to any other valuePali Rohár1-0/+7
Signed-off-by: Pali Rohár <pali@kernel.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09termios.3: Use bold style for Bnn and EXTn macro constantsPali Rohár1-2/+8
Signed-off-by: Pali Rohár <pali@kernel.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09termios.3: Document missing baud-rate constantsPali Rohár1-0/+12
These baud-rate macro constants are defined in bits/termios.h and are already supported. Signed-off-by: Pali Rohár <pali@kernel.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-09regex.3: wfixнаб1-2/+2
"address of regcomp() initialized buffer" -> "address of regcomp()-initialized buffer" Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-08strlen.3, wcslen.3: Recommend alternatives where input buffer might not be ↵Michael Kerrisk2-0/+10
null-terminated Reported-by: Jonny Grant <jg@jguk.org> Reported-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-08getauxval.3: SEE ALSO: add execve(2)Michael Kerrisk1-0/+1
Since this page discusses program execution, a link to execve(2) seems appropriate. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-08strstr.3: wfixMichael Kerrisk1-1/+0
Remove text that is probably redundant. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-08strstr.3: Document special case for empty needleAlejandro Colomar1-0/+8
Reported-by: Stefan Kanthak <stefan.kanthak@nexgo.de> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-08printf.3: tfixMichael Kerrisk1-1/+1
Reported-by: Sergey Petrakov <kr@spmail.info> Reported-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-08-07Various pages: Consistently use '*argv[]'Thomas Voss5-5/+5
Scripted change: $ find man? -type f \ | sed -i 's/int argc, char \*\*argv/int argc, char \*argv\[\]/'; Signed-off-by: Thomas Voss <thomasavoss@protonmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-07-26crypt.3: ffixMichael Kerrisk1-12/+17
Reported-by: Helge Kreutzmann <debian@helgefjell.de> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-07-25bzero.3: wfixMichael Kerrisk1-1/+1
Reported-by: Helge Kreutzmann <debian@helgefjell.de> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-07-25atanh.3: tfixMichael Kerrisk1-1/+1
Reported-by: Helge Kreutzmann <debian@helgefjell.de> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-22exit_group.2, ioprio_set.2, process_madvise.2, seccomp_unotify.2, ↵Michael Kerrisk1-1/+1
set_mempolicy.2, set_tid_address.2, bswap.3, kernel_lockdown.7: tstamp Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-20strcmp.3: tfixAlejandro Colomar1-1/+1
With a simple backslash, '\0' ended up as ' ' in the man output. Reported-by: Štěpán Němec <stepnem@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-20ferror.3: tfixthomasavoss1-1/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-20getline.3: !*lineptr is sufficientнаб1-3/+1
No implementation or spec requires *n to be 0 to allocate a new buffer: * musl checks for !*lineptr (and sets *n=0 for later allocations) * glibc checks for !*lineptr || !*n (but only because it allocates early) * NetBSD checks for !*lineptr (and sets *n=0 for later allocations) (but specifies *n => mlen(*lineptr) >= *n as a precondition, to which this appears to be an exception) * FreeBSD checks for !*lineptr and sets *n=0 (and specifies !*lineptr as sufficient) * Lastly, POSIX.1-2017 specifies: > If *n is non-zero, the application shall ensure that *lineptr > either points to an object of size at least *n bytes, > or is a null pointer. The new wording matches POSIX, even if it arrives at the point slightly differently Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-20MIN.3: New link to MIN.3Michael Kerrisk1-0/+1
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-20MAX.3: New page to document MAX() and MIN()Alejandro Colomar1-0/+90
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Cc: Paul Eggert <eggert@cs.ucla.edu> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-10cmsg.3, unix.7: Refer to seccomp_unotify(2) for an example of SCM_RIGHTS usageMichael Kerrisk1-0/+4
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-10mode_t.3: New link to system_data_types(7)Alejandro Colomar1-0/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-10blksize_t.3: New link to system_data_types(7)Alejandro Colomar1-0/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-10cc_t.3: New link to system_data_types(7)Alejandro Colomar1-0/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-06-10blkcnt_t.3: New link to system_data_types(7)Alejandro Colomar1-0/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-17ctime.3: Restore documentation of 'tm_gmtoff' fieldMichael Kerrisk1-0/+1
Accidentally deleted in commit ba39b288ab0714941786. Reported-by: Katsuhiro Numata <byakkomon@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-12expm1.3: tfixAkihiro Motoki1-1/+1
Signed-off-by: Akihiro Motoki <amotoki@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-12sigvec.3: tfixAkihiro Motoki1-1/+1
Signed-off-by: Akihiro Motoki <amotoki@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-12ttyslot.3: tfixAkihiro Motoki1-1/+1
Signed-off-by: Akihiro Motoki <amotoki@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-12tgamma.3: tfixAkihiro Motoki1-1/+0
Signed-off-by: Akihiro Motoki <amotoki@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-11fflush.3: SEE ALSO: Add fpurge(3)Alejandro Colomar1-0/+1
fpurge(i_stream) does the same as fflush(i_stream), AFAIK. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10basename.3: wfixMichael Kerrisk1-2/+2
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10bswap.3: bswap_*() are implemented using functionsAlejandro Colomar1-7/+7
See <bits/byteswap.h> in glibc. These macros call functions of the form __bswap_N(), which use uintN_t. Even though it's true that they are macros, it's transparent to the user. The user will see their results casted to unsigned types after the conversion due to the underlying functions, so it's better to document these as the underlying functions, specifying the types. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10pthread_attr_setschedparam.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-4/+4
Both POSIX and glibc use 'restrict' in pthread_attr_getschedparam(), pthread_attr_setschedparam(). Let's use it here too. .../glibc$ grep_glibc_prototype pthread_attr_getschedparam sysdeps/htl/pthread.h:102: extern int pthread_attr_getschedparam (const pthread_attr_t *__restrict __attr, struct sched_param *__restrict __param) __THROW __nonnull ((1, 2)); sysdeps/nptl/pthread.h:294: extern int pthread_attr_getschedparam (const pthread_attr_t *__restrict __attr, struct sched_param *__restrict __param) __THROW __nonnull ((1, 2)); .../glibc$ grep_glibc_prototype pthread_attr_setschedparam sysdeps/htl/pthread.h:107: extern int pthread_attr_setschedparam (pthread_attr_t *__restrict __attr, const struct sched_param *__restrict __param) __THROW __nonnull ((1, 2)); sysdeps/nptl/pthread.h:299: extern int pthread_attr_setschedparam (pthread_attr_t *__restrict __attr, const struct sched_param *__restrict __param) __THROW __nonnull ((1, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10pthread_attr_setinheritsched.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-2/+2
Both POSIX and glibc use 'restrict' in pthread_attr_getinheritsched(). Let's use it here too. .../glibc$ grep_glibc_prototype pthread_attr_getinheritsched sysdeps/htl/pthread.h:90: extern int pthread_attr_getinheritsched (const pthread_attr_t *__restrict __attr, int *__restrict __inheritsched) __THROW __nonnull ((1, 2)); sysdeps/nptl/pthread.h:313: extern int pthread_attr_getinheritsched (const pthread_attr_t *__restrict __attr, int *__restrict __inherit) __THROW __nonnull ((1, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10xdr.3: SYNOPSIS: Fix prototype typesAlejandro Colomar1-2/+2
Use the same types glibc uses, and add a missing 'const'. .../glibc$ grep_glibc_prototype xdr_union sunrpc/rpc/xdr.h:315: extern bool_t xdr_union (XDR *__xdrs, enum_t *__dscmp, char *__unp, const struct xdr_discrim *__choices, xdrproc_t __dfault) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10rpc.3: SYNOPSIS: Fix prototypes (misc.)Alejandro Colomar1-12/+13
Fix the types for the following functions: authunix_create(), callrpc(), clnt_create(), clnt_pcreateerror(), clnt_perror(), clnt_spcreateerror(), clnt_sperror(), pmap_set(), svc_register(), svcerr_progvers(). .../glibc$ grep_glibc_prototype authunix_create sunrpc/rpc/auth.h:158: extern AUTH *authunix_create (char *__machname, __uid_t __uid, __gid_t __gid, int __len, __gid_t *__aup_gids); .../glibc$ grep_glibc_prototype callrpc sunrpc/rpc/clnt.h:359: extern int callrpc (const char *__host, const u_long __prognum, const u_long __versnum, const u_long __procnum, const xdrproc_t __inproc, const char *__in, const xdrproc_t __outproc, char *__out) __THROW; .../glibc$ grep_glibc_prototype clnt_create sunrpc/rpc/clnt.h:291: extern CLIENT *clnt_create (const char *__host, const u_long __prog, const u_long __vers, const char *__prot) __THROW; .../glibc$ grep_glibc_prototype clnt_pcreateerror sunrpc/rpc/clnt.h:368: extern void clnt_pcreateerror (const char *__msg); /* stderr */ .../glibc$ grep_glibc_prototype clnt_perror sunrpc/rpc/clnt.h:379: extern void clnt_perror (CLIENT *__clnt, const char *__msg); .../glibc$ grep_glibc_prototype clnt_spcreateerror sunrpc/rpc/clnt.h:369: extern char *clnt_spcreateerror(const char *__msg) __THROW; /* string */ .../glibc$ grep_glibc_prototype clnt_sperror sunrpc/rpc/clnt.h:381: extern char *clnt_sperror (CLIENT *__clnt, const char *__msg) __THROW; .../glibc$ grep_glibc_prototype pmap_set sunrpc/rpc/pmap_clnt.h:69: extern bool_t pmap_set (const u_long __program, const u_long __vers, int __protocol, u_short __port) __THROW; .../glibc$ grep_glibc_prototype svc_register sunrpc/rpc/svc.h:188: extern bool_t svc_register (SVCXPRT *__xprt, rpcprog_t __prog, rpcvers_t __vers, __dispatch_fn_t __dispatch, rpcprot_t __protocol) __THROW; .../glibc$ grep_glibc_prototype svcerr_progvers sunrpc/rpc/svc.h:253: extern void svcerr_progvers (SVCXPRT *__xprt, rpcvers_t __low_vers, rpcvers_t __high_vers) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10cpow.3: Use 'complex' after the type consistentlyAlejandro Colomar1-3/+3
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10dladdr.3: SYNOPSIS: Add missing 'const'Alejandro Colomar1-3/+3
Glibc uses 'const' for the 1st parameter of these functions. Fix the prototypes. ...... .../glibc$ grep_glibc_prototype dladdr dlfcn/dlfcn.h:98: extern int dladdr (const void *__address, Dl_info *__info) __THROW __nonnull ((2)); .../glibc$ grep_glibc_prototype dladdr1 dlfcn/dlfcn.h:102: extern int dladdr1 (const void *__address, Dl_info *__info, void **__extra_info, int __flags) __THROW __nonnull ((2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10sched_get_priority_max.2, open_memstream.3: tfixAlejandro Colomar1-1/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10pthread_getattr_default_np.3: SYNOPSIS: Add missing 'const'Alejandro Colomar1-1/+1
glibc uses 'const' in pthread_setattr_default_np(). Let's use it here too. .../glibc$ grep_glibc_prototype pthread_setattr_default_np sysdeps/nptl/pthread.h:406: extern int pthread_setattr_default_np (const pthread_attr_t *__attr) __THROW __nonnull ((1)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10pthread_mutexattr_setrobust.3: SYNOPSIS: Remove incorrect 'const'Alejandro Colomar1-1/+1
Neither POSIX or glibc use 'const' in pthread_mutexattr_setrobust(). Remove it. .../glibc$ grep_glibc_prototype pthread_mutexattr_setrobust sysdeps/htl/pthread.h:355: extern int pthread_mutexattr_setrobust (pthread_mutexattr_t *__attr, int __robustness) __THROW __nonnull ((1)); sysdeps/nptl/pthread.h:888: extern int pthread_mutexattr_setrobust (pthread_mutexattr_t *__attr, int __robustness) __THROW __nonnull ((1)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10tzset.3: ffixAlejandro Colomar1-1/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10strsignal.3: SYNOPSIS: Add missing 'const'Alejandro Colomar1-2/+2
glibc uses 'const' in sigdescr_np(), sigabbrev_np(). Let's use it here too. .../glibc$ grep_glibc_prototype sigdescr_np string/string.h:469: extern const char *sigdescr_np (int __sig) __THROW; .../glibc$ grep_glibc_prototype sigabbrev_np string/string.h:466: extern const char *sigabbrev_np (int __sig) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10strsignal.3: ffixAlejandro Colomar1-1/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10__ppc_get_timebase.3: ffixAlejandro Colomar1-1/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10perror.3: ffixAlejandro Colomar1-1/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10on_exit.3: ffixAlejandro Colomar1-1/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10getutmp.3: ffixAlejandro Colomar1-2/+2
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10malloc_usable_size.3: ffixAlejandro Colomar1-1/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10getopt.3: Minor tweaks to James' patchAlejandro Colomar1-1/+1
The rest of the page writes the characters without naming them. Follow that convention. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10getopt.3: Clarify behaviourJames O. D. Hunt1-0/+23
Improved the `getopt(3)` man page in the following ways: 1) Defined the existing term "legitimate option character". 2) Added an additional NOTE stressing that arguments are parsed in strict order and the implications of this when numeric options are utilised. Signed-off-by: James O. D. Hunt <jamesodhunt@gmail.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10setbuf.3: tfixAlejandro Colomar1-1/+1
Reported-by: Zhiheng Li <phoenix_lzh@sina.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10Various pages: Remove unused <sys/ipc.h> (and <sys/types.h>)Alejandro Colomar1-1/+0
In b0b19983d9a2001ce94b908a99f4c05a50fd47ee we removed <sys/types.h>. For the same reasons there, remove now <sys/ipc.h> from many pages. If someone wonders why <sys/ipc.h> was needed, the reason was to get all the definitions of IPC_* constants. However, that header is now included by <sys/msg.h>, so it's not needed anymore to explicitly include it. Quoting POSIX: "In addition, the <sys/msg.h> header shall include the <sys/ipc.h> header." There were some remaining cases where I forgot to remove <sys/types.h>; remove them now too. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10pthread_yield.3: Note that this function is deprecated since glibc 2.34Michael Kerrisk1-0/+5
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10pthread_mutexattr_setrobust.3: Note that the *_np() APIs are deprecated ↵Michael Kerrisk1-1/+2
since glibc 2.34 Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10pthread_mutex_consistent.3: Note that pthread_mutexattr_setrobust() is now ↵Michael Kerrisk1-1/+2
deprecated Deprecated since glibc 2.34. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-05-10pthread_mutex_consistent.3: tfixMichael Kerrisk1-1/+1
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-04-05scanf.3: Clarify that %n supports type modifiersAlyssa Ross1-1/+3
My initial reading of this was that type modifiers were probably not supported. But they are, and this is actually documented further up, in the type modifiers documentation. But to make it clearer, let's copy the language that printf(3) has in its %n section. Signed-off-by: Alyssa Ross <hi@alyssa.is> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-04-05shm_open.3: wfixMichael Kerrisk1-1/+1
Reported-by: Jon Murphy <jonmurphy1618@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-04-05socklen_t.3: New link to system_data_types(7)Alejandro Colomar1-0/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-04-05sockaddr.3: New link to system_data_types(7)Alejandro Colomar1-0/+1
Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-04-04errno.3: Fix ENODATA textAlejandro Colomar1-1/+7
ENODATA is an XSI STREAMS extension (not base POSIX). Linux reused the name for extended attributes. The current manual pages don't use ENODATA with its POSIX meaning, so use the xattr(7) specific text, and leave the POSIX meaning for a secondary paragraph. Reported-by: Mark Kettenis <kettenis@openbsd.org> Reported-by: Florian Weimer <fw@deneb.enyo.de> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-04-04exec.3: Clarify that execvpe uses PATH from the caller, not envpJosh Triplett1-0/+7
Checked via the latest glibc source. execvpe calls getenv("PATH") and searches that; the PATH in envp does not affect the search. Signed-off-by: Josh Triplett <josh@joshtriplett.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-04-04exec.3: Fix description of 'e' variantsJosh Triplett1-1/+1
The envp argument specifies the environment of the new process image, not "the environment of the caller". Signed-off-by: Josh Triplett <josh@joshtriplett.org> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-04-04printf.3: Minor wording tweaks to Utkarsh's patchAlejandro Colomar1-1/+1
The format string refers to the whole string passed in 'format'. The syntax referred to is that of a conversion specification, as called in the manual page. Use specific language. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-04-04printf.3: Add overall structure of format stringUtkarsh Singh1-0/+8
Can we add a small syntax structure for format string in printf(3) manual. I personally find if easier to remember and scan. This has been taken from OpenBSD printf(3) manual. Signed-off-by: Utkarsh Singh <utkarsh190601@gmail.com> [ alx: ffix ] Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-22getent.1, ldd.1, locale.1, localedef.1, memusage.1, memusagestat.1, ↵Michael Kerrisk562-562/+562
mtrace.1, _exit.2, _syscall.2, accept.2, access.2, acct.2, add_key.2, adjtimex.2, alloc_hugepages.2, arch_prctl.2, bdflush.2, bind.2, bpf.2, brk.2, cacheflush.2, capget.2, chdir.2, chmod.2, chown.2, chroot.2, clock_getres.2, clock_nanosleep.2, clone.2, close.2, close_range.2, connect.2, copy_file_range.2, create_module.2, delete_module.2, dup.2, epoll_create.2, epoll_ctl.2, epoll_wait.2, eventfd.2, execve.2, execveat.2, fanotify_init.2, fanotify_mark.2, fcntl.2, flock.2, fork.2, fsync.2, futex.2, get_kernel_syms.2, get_mempolicy.2, get_robust_list.2, getcpu.2, getdents.2, getdomainname.2, getgid.2, getgroups.2, gethostname.2, getitimer.2, getpagesize.2, getpeername.2, getpid.2, getpriority.2, getrandom.2, getresuid.2, getrlimit.2, getrusage.2, getsid.2, getsockname.2, getsockopt.2, gettid.2, gettimeofday.2, getuid.2, getunwind.2, getxattr.2, idle.2, init_module.2, inotify_add_watch.2, inotify_rm_watch.2, io_cancel.2, io_destroy.2, io_getevents.2, io_setup.2, io_submit.2, ioctl.2, ioctl_console.2, ioctl_fat.2, ioctl_ficlonerange.2, ioctl_fideduperange.2, ioctl_fslabel.2, ioctl_getfsmap.2, ioctl_ns.2, ioctl_tty.2, ioctl_userfaultfd.2, ioperm.2, iopl.2, ipc.2, kcmp.2, kexec_load.2, keyctl.2, kill.2, link.2, listen.2, listxattr.2, llseek.2, lookup_dcookie.2, lseek.2, madvise.2, mbind.2, membarrier.2, memfd_create.2, migrate_pages.2, mincore.2, mkdir.2, mknod.2, mlock.2, mmap.2, mmap2.2, modify_ldt.2, mount.2, move_pages.2, mprotect.2, mq_getsetattr.2, mremap.2, msgctl.2, msgget.2, msgop.2, msync.2, nanosleep.2, nfsservctl.2, nice.2, open.2, open_by_handle_at.2, openat2.2, pause.2, pciconfig_read.2, perf_event_open.2, perfmonctl.2, personality.2, pidfd_getfd.2, pidfd_open.2, pidfd_send_signal.2, pipe.2, pivot_root.2, pkey_alloc.2, poll.2, posix_fadvise.2, prctl.2, pread.2, process_vm_readv.2, ptrace.2, query_module.2, quotactl.2, read.2, readahead.2, readdir.2, readlink.2, readv.2, reboot.2, recv.2, remap_file_pages.2, removexattr.2, rename.2, request_key.2, restart_syscall.2, rmdir.2, rt_sigqueueinfo.2, s390_guarded_storage.2, s390_pci_mmio_write.2, s390_runtime_instr.2, s390_sthyi.2, sched_get_priority_max.2, sched_rr_get_interval.2, sched_setaffinity.2, sched_setattr.2, sched_setparam.2, sched_setscheduler.2, sched_yield.2, seccomp.2, select.2, select_tut.2, semctl.2, semget.2, semop.2, send.2, sendfile.2, set_thread_area.2, seteuid.2, setfsgid.2, setfsuid.2, setgid.2, setpgid.2, setresuid.2, setreuid.2, setsid.2, setuid.2, setup.2, setxattr.2, sgetmask.2, shmctl.2, shmget.2, shmop.2, shutdown.2, sigaction.2, sigaltstack.2, signal.2, signalfd.2, sigpending.2, sigprocmask.2, sigreturn.2, sigsuspend.2, sigwaitinfo.2, socket.2, socketcall.2, socketpair.2, splice.2, spu_create.2, spu_run.2, stat.2, statfs.2, statx.2, stime.2, subpage_prot.2, swapon.2, symlink.2, sync.2, sync_file_range.2, syscall.2, syscalls.2, sysctl.2, sysfs.2, sysinfo.2, syslog.2, time.2, timer_create.2, timer_delete.2, timer_getoverrun.2, timer_settime.2, timerfd_create.2, times.2, tkill.2, truncate.2, umask.2, umount.2, uname.2, unimplemented.2, unlink.2, unshare.2, uselib.2, userfaultfd.2, ustat.2, utime.2, utimensat.2, vfork.2, vhangup.2, vm86.2, vmsplice.2, wait.2, wait4.2, write.2, CPU_SET.3, __ppc_get_timebase.3, __ppc_set_ppr_med.3, __ppc_yield.3, __setfpucw.3, a64l.3, abort.3, abs.3, acos.3, acosh.3, addseverity.3, adjtime.3, aio_cancel.3, aio_error.3, aio_fsync.3, aio_read.3, aio_return.3, aio_suspend.3, aio_write.3, alloca.3, argz_add.3, asin.3, asinh.3, asprintf.3, assert.3, assert_perror.3, atan.3, atan2.3, atanh.3, atexit.3, atof.3, atoi.3, backtrace.3, basename.3, bcmp.3, bcopy.3, bindresvport.3, bsd_signal.3, bsearch.3, bstring.3, btowc.3, byteorder.3, bzero.3, cabs.3, cacos.3, cacosh.3, canonicalize_file_name.3, carg.3, casin.3, casinh.3, catan.3, catanh.3, catgets.3, catopen.3, cbrt.3, ccos.3, ccosh.3, ceil.3, cexp.3, cexp2.3, cfree.3, cimag.3, circleq.3, clearenv.3, clock.3, clock_getcpuclockid.3, clog.3, clog10.3, clog2.3, closedir.3, cmsg.3, confstr.3, conj.3, copysign.3, cos.3, cosh.3, cpow.3, cproj.3, creal.3, crypt.3, csin.3, csinh.3, csqrt.3, ctan.3, ctanh.3, ctermid.3, ctime.3, daemon.3, des_crypt.3, difftime.3, dirfd.3, div.3, dl_iterate_phdr.3, dladdr.3, dlerror.3, dlinfo.3, dlopen.3, dlsym.3, drand48.3, drand48_r.3, duplocale.3, dysize.3, ecvt.3, ecvt_r.3, encrypt.3, endian.3, envz_add.3, erf.3, erfc.3, err.3, errno.3, error.3, ether_aton.3, euidaccess.3, exec.3, exit.3, exp.3, exp10.3, exp2.3, expm1.3, fabs.3, fclose.3, fcloseall.3, fdim.3, fenv.3, ferror.3, fexecve.3, fflush.3, ffs.3, fgetc.3, fgetgrent.3, fgetpwent.3, fgetwc.3, fgetws.3, fileno.3, finite.3, flockfile.3, floor.3, fma.3, fmax.3, fmemopen.3, fmin.3, fmod.3, fmtmsg.3, fnmatch.3, fopen.3, fopencookie.3, fpathconf.3, fpclassify.3, fpurge.3, fputwc.3, fputws.3, fread.3, frexp.3, fseek.3, fseeko.3, ftime.3, ftok.3, fts.3, ftw.3, futimes.3, fwide.3, gamma.3, gcvt.3, get_nprocs_conf.3, get_phys_pages.3, getaddrinfo.3, getaddrinfo_a.3, getauxval.3, getcontext.3, getcwd.3, getdate.3, getdirentries.3, getdtablesize.3, getentropy.3, getenv.3, getfsent.3, getgrent.3, getgrent_r.3, getgrnam.3, getgrouplist.3, gethostbyname.3, gethostid.3, getifaddrs.3, getipnodebyname.3, getline.3, getloadavg.3, getlogin.3, getmntent.3, getnameinfo.3, getnetent.3, getnetent_r.3, getopt.3, getpass.3, getprotoent.3, getprotoent_r.3, getpt.3, getpw.3, getpwent.3, getpwent_r.3, getpwnam.3, getrpcent.3, getrpcent_r.3, getrpcport.3, gets.3, getservent.3, getservent_r.3, getspnam.3, getsubopt.3, getttyent.3, getumask.3, getusershell.3, getutent.3, getutmp.3, getw.3, getwchar.3, glob.3, gnu_get_libc_version.3, grantpt.3, group_member.3, gsignal.3, hsearch.3, hypot.3, iconv.3, iconv_close.3, iconv_open.3, if_nameindex.3, if_nametoindex.3, ilogb.3, index.3, inet.3, inet_net_pton.3, inet_ntop.3, inet_pton.3, initgroups.3, insque.3, isalpha.3, isatty.3, isfdtype.3, isgreater.3, iswalnum.3, iswalpha.3, iswblank.3, iswcntrl.3, iswctype.3, iswdigit.3, iswgraph.3, iswlower.3, iswprint.3, iswpunct.3, iswspace.3, iswupper.3, iswxdigit.3, j0.3, key_setsecret.3, killpg.3, ldexp.3, lgamma.3, lio_listio.3, list.3, localeconv.3, lockf.3, log.3, log10.3, log1p.3, log2.3, logb.3, login.3, lrint.3, lround.3, lsearch.3, lseek64.3, makecontext.3, makedev.3, mallinfo.3, malloc.3, malloc_get_state.3, malloc_hook.3, malloc_info.3, malloc_stats.3, malloc_trim.3, malloc_usable_size.3, mallopt.3, matherr.3, mblen.3, mbrlen.3, mbrtowc.3, mbsinit.3, mbsnrtowcs.3, mbsrtowcs.3, mbstowcs.3, mbtowc.3, mcheck.3, memccpy.3, memchr.3, memcmp.3, memcpy.3, memfrob.3, memmem.3, memmove.3, mempcpy.3, memset.3, mkdtemp.3, mkfifo.3, mkstemp.3, mktemp.3, modf.3, mpool.3, mq_close.3, mq_getattr.3, mq_notify.3, mq_open.3, mq_receive.3, mq_send.3, mq_unlink.3, mtrace.3, nan.3, newlocale.3, nextafter.3, nextup.3, nl_langinfo.3, ntp_gettime.3, on_exit.3, open_memstream.3, opendir.3, openpty.3, perror.3, popen.3, posix_fallocate.3, posix_madvise.3, posix_memalign.3, posix_openpt.3, posix_spawn.3, pow.3, pow10.3, printf.3, profil.3, psignal.3, pthread_attr_init.3, pthread_attr_setaffinity_np.3, pthread_attr_setdetachstate.3, pthread_attr_setguardsize.3, pthread_attr_setinheritsched.3, pthread_attr_setschedparam.3, pthread_attr_setschedpolicy.3, pthread_attr_setscope.3, pthread_attr_setsigmask_np.3, pthread_attr_setstack.3, pthread_attr_setstackaddr.3, pthread_attr_setstacksize.3, pthread_cancel.3, pthread_cleanup_push.3, pthread_cleanup_push_defer_np.3, pthread_create.3, pthread_detach.3, pthread_equal.3, pthread_exit.3, pthread_getattr_default_np.3, pthread_getattr_np.3, pthread_getcpuclockid.3, pthread_join.3, pthread_kill.3, pthread_kill_other_threads_np.3, pthread_mutex_consistent.3, pthread_mutexattr_getpshared.3, pthread_mutexattr_setrobust.3, pthread_rwlockattr_setkind_np.3, pthread_self.3, pthread_setaffinity_np.3, pthread_setcancelstate.3, pthread_setconcurrency.3, pthread_setname_np.3, pthread_setschedparam.3, pthread_setschedprio.3, pthread_sigmask.3, pthread_sigqueue.3, pthread_spin_init.3, pthread_spin_lock.3, pthread_testcancel.3, pthread_tryjoin_np.3, pthread_yield.3, ptsname.3, putenv.3, putgrent.3, putpwent.3, puts.3, putwchar.3, qecvt.3, qsort.3, raise.3, rand.3, random.3, random_r.3, rcmd.3, re_comp.3, readdir.3, readdir_r.3, realpath.3, regex.3, remainder.3, remove.3, remquo.3, resolver.3, rewinddir.3, rexec.3, rint.3, round.3, rpc.3, rpmatch.3, rtime.3, rtnetlink.3, scalb.3, scalbln.3, scandir.3, scanf.3, sched_getcpu.3, seekdir.3, sem_close.3, sem_destroy.3, sem_getvalue.3, sem_init.3, sem_open.3, sem_post.3, sem_unlink.3, sem_wait.3, setaliasent.3, setbuf.3, setenv.3, setjmp.3, setlocale.3, setlogmask.3, setnetgrent.3, shm_open.3, siginterrupt.3, signbit.3, significand.3, sigpause.3, sigqueue.3, sigset.3, sigsetops.3, sigvec.3, sigwait.3, sin.3, sincos.3, sinh.3, sleep.3, slist.3, sockatmark.3, sqrt.3, stailq.3, statvfs.3, stdarg.3, stdio.3, stdio_ext.3, stpcpy.3, stpncpy.3, strcasecmp.3, strcat.3, strchr.3, strcmp.3, strcoll.3, strcpy.3, strdup.3, strerror.3, strfmon.3, strfromd.3, strfry.3, strftime.3, string.3, strlen.3, strnlen.3, strpbrk.3, strptime.3, strsep.3, strsignal.3, strspn.3, strstr.3, strtod.3, strtoimax.3, strtok.3, strtol.3, strtoul.3, strverscmp.3, strxfrm.3, swab.3, sysconf.3, syslog.3, system.3, sysv_signal.3, tailq.3, tan.3, tanh.3, tcgetpgrp.3, tcgetsid.3, telldir.3, tempnam.3, termios.3, tgamma.3, timegm.3, timeradd.3, tmpfile.3, tmpnam.3, toascii.3, toupper.3, towctrans.3, towlower.3, towupper.3, trunc.3, tsearch.3, ttyname.3, ttyslot.3, tzset.3, ualarm.3, ulimit.3, undocumented.3, ungetwc.3, unlocked_stdio.3, unlockpt.3, updwtmp.3, uselocale.3, usleep.3, wcpcpy.3, wcpncpy.3, wcrtomb.3, wcscasecmp.3, wcscat.3, wcschr.3, wcscmp.3, wcscpy.3, wcscspn.3, wcsdup.3, wcslen.3, wcsncasecmp.3, wcsncat.3, wcsncmp.3, wcsncpy.3, wcsnlen.3, wcsnrtombs.3, wcspbrk.3, wcsrchr.3, wcsrtombs.3, wcsspn.3, wcsstr.3, wcstoimax.3, wcstok.3, wcstombs.3, wcswidth.3, wctob.3, wctomb.3, wctrans.3, wctype.3, wcwidth.3, wmemchr.3, wmemcmp.3, wmemcpy.3, wmemmove.3, wmemset.3, wordexp.3, wprintf.3, xcrypt.3, xdr.3, y0.3, cciss.4, console_codes.4, dsp56k.4, hpsa.4, initrd.4, loop.4, lp.4, msr.4, random.4, rtc.4, smartpqi.4, veth.4, wavelan.4, acct.5, core.5, elf.5, hosts.5, locale.5, proc.5, resolv.conf.5, rpc.5, slabinfo.5, sysfs.5, tmpfs.5, utmp.5, address_families.7, aio.7, attributes.7, bootparam.7, capabilities.7, cgroups.7, complex.7, ddp.7, environ.7, epoll.7, fanotify.7, feature_test_macros.7, hier.7, inode.7, inotify.7, ip.7, ipv6.7, keyrings.7, locale.7, man-pages.7, man.7, math_error.7, mount_namespaces.7, namespaces.7, netdevice.7, netlink.7, numa.7, packet.7, pkeys.7, pthreads.7, queue.7, raw.7, rtnetlink.7, sched.7, session-keyring.7, shm_overview.7, sigevent.7, signal-safety.7, signal.7, sock_diag.7, socket.7, spufs.7, symlink.7, system_data_types.7, tcp.7, time_namespaces.7, udp.7, udplite.7, unicode.7, unix.7, uri.7, user_namespaces.7, vdso.7, vsock.7, x25.7, iconvconfig.8, ld.so.8, ldconfig.8, sln.8, tzselect.8: tstamp Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wprintf.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-8/+10
POSIX uses 'restrict' in *wprintf() (see [v]fwprintf(3p)). Let's use it here too. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14scandir.3: ffixMichael Kerrisk1-2/+4
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14rcmd.3: ffixMichael Kerrisk1-11/+13
In SYNOPSIS, shift arguments right a little to make the function names stand out a little more. Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wordexp.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+2
Both POSIX and glibc use 'restrict' in wordexp(). Let's use it here too. .../glibc$ grep_glibc_prototype wordexp posix/wordexp.h:62: extern int wordexp (const char *__restrict __words, wordexp_t *__restrict __pwordexp, int __flags); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wmemcpy.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+3
Both POSIX and glibc use 'restrict' in wmemcpy(). Let's use it here too. .../glibc$ grep_glibc_prototype wmemcpy wcsmbs/wchar.h:262: extern wchar_t *wmemcpy (wchar_t *__restrict __s1, const wchar_t *__restrict __s2, size_t __n) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcstombs.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+2
Both POSIX and glibc use 'restrict' in wcstombs(). Let's use it here too. .../glibc$ grep_glibc_prototype wcstombs stdlib/stdlib.h:937: extern size_t wcstombs (char *__restrict __s, const wchar_t *__restrict __pwcs, size_t __n) __THROW __attr_access ((__write_only__, 1, 3)) __attr_access ((__read_only__, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcstok.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-2/+3
Both POSIX and glibc use 'restrict' in wcstok(). Let's use it here too. .../glibc$ grep_glibc_prototype wcstok wcsmbs/wchar.h:217: extern wchar_t *wcstok (wchar_t *__restrict __s, const wchar_t *__restrict __delim, wchar_t **__restrict __ptr) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcstoimax.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-4/+4
Both POSIX and glibc use 'restrict' in wcstoimax(), wcstoumax(). Let's use it here too. .../glibc$ grep_glibc_prototype wcstoimax stdlib/inttypes.h:305: extern intmax_t wcstoimax (const __gwchar_t *__restrict __nptr, __gwchar_t **__restrict __endptr, int __base) __THROW; .../glibc$ grep_glibc_prototype wcstoumax stdlib/inttypes.h:310: extern uintmax_t wcstoumax (const __gwchar_t *__restrict __nptr, __gwchar_t ** __restrict __endptr, int __base) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcsrtombs.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-2/+2
Both POSIX and glibc use 'restrict' in wcsrtombs(). Let's use it here too. .../glibc$ grep_glibc_prototype wcsrtombs wcsmbs/wchar.h:343: extern size_t wcsrtombs (char *__restrict __dst, const wchar_t **__restrict __src, size_t __len, mbstate_t *__restrict __ps) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcsnrtombs.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-2/+3
Both POSIX and glibc use 'restrict' in wcsnrtombs(). Let's use it here too. .../glibc$ grep_glibc_prototype wcsnrtombs wcsmbs/wchar.h:357: extern size_t wcsnrtombs (char *__restrict __dst, const wchar_t **__restrict __src, size_t __nwc, size_t __len, mbstate_t *__restrict __ps) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcsncpy.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+3
Both POSIX and glibc use 'restrict' in wcsncpy(). Let's use it here too. .../glibc$ grep_glibc_prototype wcsncpy wcsmbs/wchar.h:92: extern wchar_t *wcsncpy (wchar_t *__restrict __dest, const wchar_t *__restrict __src, size_t __n) __THROW __nonnull ((1, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcsncat.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+3
Both POSIX and glibc use 'restrict' in wcsncat(). Let's use it here too. .../glibc$ grep_glibc_prototype wcsncat wcsmbs/wchar.h:101: extern wchar_t *wcsncat (wchar_t *__restrict __dest, const wchar_t *__restrict __src, size_t __n) __THROW __nonnull ((1, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcscpy.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+2
Both POSIX and glibc use 'restrict' in wcscpy(). Let's use it here too. .../glibc$ grep_glibc_prototype wcscpy wcsmbs/wchar.h:87: extern wchar_t *wcscpy (wchar_t *__restrict __dest, const wchar_t *__restrict __src) __THROW __nonnull ((1, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcscat.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+2
Both POSIX and glibc use 'restrict' in wcscat(). Let's use it here too. .../glibc$ grep_glibc_prototype wcscat wcsmbs/wchar.h:97: extern wchar_t *wcscat (wchar_t *__restrict __dest, const wchar_t *__restrict __src) __THROW __nonnull ((1, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcrtomb.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+2
Both POSIX and glibc use 'restrict' in wcrtomb(). Let's use it here too. .../glibc$ grep_glibc_prototype wcrtomb wcsmbs/wchar.h:301: extern size_t wcrtomb (char *__restrict __s, wchar_t __wc, mbstate_t *__restrict __ps) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcpncpy.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+3
Both POSIX and glibc use 'restrict' in wcpncpy(). Let's use it here too. .../glibc$ grep_glibc_prototype wcpncpy wcsmbs/wchar.h:556: extern wchar_t *wcpncpy (wchar_t *__restrict __dest, const wchar_t *__restrict __src, size_t __n) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14wcpcpy.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+2
Both POSIX and glibc use 'restrict' in wcpcpy(). Let's use it here too. .../glibc$ grep_glibc_prototype wcpcpy wcsmbs/wchar.h:551: extern wchar_t *wcpcpy (wchar_t *__restrict __dest, const wchar_t *__restrict __src) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14unlocked_stdio.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-8/+12
glibc uses 'restrict' in fread_unlocked(), fwrite_unlocked(), fgets_unlocked(), fputs_unlocked(), fgetws_unlocked(), fputws_unlocked(). Let's use it here too. .../glibc$ grep_glibc_prototype fread_unlocked libio/stdio.h:678: extern size_t fread_unlocked (void *__restrict __ptr, size_t __size, size_t __n, FILE *__restrict __stream) __wur; .../glibc$ grep_glibc_prototype fwrite_unlocked libio/stdio.h:680: extern size_t fwrite_unlocked (const void *__restrict __ptr, size_t __size, size_t __n, FILE *__restrict __stream); .../glibc$ grep_glibc_prototype fgets_unlocked libio/stdio.h:591: extern char *fgets_unlocked (char *__restrict __s, int __n, FILE *__restrict __stream) __wur __attr_access ((__write_only__, 1, 2)); .../glibc$ grep_glibc_prototype fputs_unlocked libio/stdio.h:667: extern int fputs_unlocked (const char *__restrict __s, FILE *__restrict __stream); .../glibc$ grep_glibc_prototype fgetws_unlocked wcsmbs/wchar.h:820: extern wchar_t *fgetws_unlocked (wchar_t *__restrict __ws, int __n, __FILE *__restrict __stream); .../glibc$ grep_glibc_prototype fputws_unlocked wcsmbs/wchar.h:829: extern int fputws_unlocked (const wchar_t *__restrict __ws, __FILE *__restrict __stream); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14tsearch.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-2/+2
Both POSIX and glibc use 'restrict' in tdelete(). Let's use it here too. .../glibc$ grep_glibc_prototype tdelete misc/search.h:138: extern void *tdelete (const void *__restrict __key, void **__restrict __rootp, __compar_fn_t __compar); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14scanf.3: SYNOPSIS: Use 'restrict' in prototypes; ffix too.Alejandro Colomar1-6/+10
Both POSIX and glibc use 'restrict' in scanf(), fscanf(), sscanf(), vscanf(), vfscanf(), vsscanf(). Let's use it here too. .../glibc$ grep_glibc_prototype scanf libio/stdio.h:397: extern int scanf (const char *__restrict __format, ...) __wur; .../glibc$ grep_glibc_prototype fscanf libio/stdio.h:391: extern int fscanf (FILE *__restrict __stream, const char *__restrict __format, ...) __wur; .../glibc$ grep_glibc_prototype sscanf libio/stdio.h:399: extern int sscanf (const char *__restrict __s, const char *__restrict __format, ...) __THROW; .../glibc$ grep_glibc_prototype vscanf libio/stdio.h:443: extern int vscanf (const char *__restrict __format, __gnuc_va_list __arg) __attribute__ ((__format__ (__scanf__, 1, 0))) __wur; .../glibc$ grep_glibc_prototype vfscanf libio/stdio.h:435: extern int vfscanf (FILE *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg) __attribute__ ((__format__ (__scanf__, 2, 0))) __wur; .../glibc$ grep_glibc_prototype vsscanf libio/stdio.h:447: extern int vsscanf (const char *__restrict __s, const char *__restrict __format, __gnuc_va_list __arg) __THROW __attribute__ ((__format__ (__scanf__, 2, 0))); .../glibc$ Also reorder v* functions to match the order of non-v functions. Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14sigwait.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+1
Both POSIX and glibc use 'restrict' in sigwait(). Let's use it here too. .../glibc$ grep_glibc_prototype sigwait signal/signal.h:255: extern int sigwait (const sigset_t *__restrict __set, int *__restrict __sig) __nonnull ((1, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14sigwait.3: ffixMichael Kerrisk1-1/+1
Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14swab.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+2
Both POSIX and glibc use 'restrict' in swab(). Let's use it here too. .../glibc$ grep_glibc_prototype swab posix/unistd.h:1147: extern void swab (const void *__restrict __from, void *__restrict __to, ssize_t __n) __THROW __nonnull ((1, 2)) __attr_access ((__read_only__, 1, 3)) __attr_access ((__write_only__, 2, 3)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14strxfrm.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+2
Both POSIX and glibc use 'restrict' in strxfrm(). Let's use it here too. .../glibc$ grep_glibc_prototype strxfrm string/string.h:150: extern size_t strxfrm (char *__restrict __dest, const char *__restrict __src, size_t __n) __THROW __nonnull ((2)) __attr_access ((__write_only__, 1, 3)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14strtol.3, strtoul.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar2-7/+8
Both POSIX and glibc use 'restrict' in strtol(), strtoll(), strtoul(), strtoull(). Let's use it here too. .../glibc$ grep_glibc_prototype strtol stdlib/stdlib.h:176: extern long int strtol (const char *__restrict __nptr, char **__restrict __endptr, int __base) __THROW __nonnull ((1)); .../glibc$ grep_glibc_prototype strtoll stdlib/stdlib.h:199: __extension__ extern long long int strtoll (const char *__restrict __nptr, char **__restrict __endptr, int __base) __THROW __nonnull ((1)); .../glibc$ grep_glibc_prototype strtoul stdlib/stdlib.h:180: extern unsigned long int strtoul (const char *__restrict __nptr, char **__restrict __endptr, int __base) __THROW __nonnull ((1)); .../glibc$ grep_glibc_prototype strtoull stdlib/stdlib.h:204: __extension__ extern unsigned long long int strtoull (const char *__restrict __nptr, char **__restrict __endptr, int __base) __THROW __nonnull ((1)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14strtok.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-2/+3
Both POSIX and glibc use 'restrict' in strtok(), strtok_r(). Let's use it here too. .../glibc$ grep_glibc_prototype strtok string/string.h:340: extern char *strtok (char *__restrict __s, const char *__restrict __delim) __THROW __nonnull ((2)); .../glibc$ grep_glibc_prototype strtok_r string/string.h:350: extern char *strtok_r (char *__restrict __s, const char *__restrict __delim, char **__restrict __save_ptr) __THROW __nonnull ((2, 3)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14strtoimax.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-2/+4
Both POSIX and glibc use 'restrict' in strtoimax(), strtoumax(). Let's use it here too. .../glibc$ grep_glibc_prototype strtoimax stdlib/inttypes.h:297: extern intmax_t strtoimax (const char *__restrict __nptr, char **__restrict __endptr, int __base) __THROW; .../glibc$ grep_glibc_prototype strtoumax stdlib/inttypes.h:301: extern uintmax_t strtoumax (const char *__restrict __nptr, char ** __restrict __endptr, int __base) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14strtod.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-3/+4
Both POSIX and glibc use 'restrict' in strtod(), strtof(), strtold(). Let's use it here too. .../glibc$ grep_glibc_prototype strtod stdlib/stdlib.h:117: extern double strtod (const char *__restrict __nptr, char **__restrict __endptr) __THROW __nonnull ((1)); .../glibc$ grep_glibc_prototype strtof stdlib/stdlib.h:123: extern float strtof (const char *__restrict __nptr, char **__restrict __endptr) __THROW __nonnull ((1)); .../glibc$ grep_glibc_prototype strtold stdlib/stdlib.h:126: extern long double strtold (const char *__restrict __nptr, char **__restrict __endptr) __THROW __nonnull ((1)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14strsep.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+1
glibc uses 'restrict' in strsep(). Let's use it here too. .../glibc$ grep_glibc_prototype strsep string/string.h:455: extern char *strsep (char **__restrict __stringp, const char *__restrict __delim) __THROW __nonnull ((1, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14strptime.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+2
Both POSIX and glibc use 'restrict' in strptime(). However, glibc doesn't specify 'restrict' for the last parameter. Let's use the most restrictive form here (although I believe both to be equivalent). .../glibc$ grep_glibc_prototype strptime time/time.h:95: extern char *strptime (const char *__restrict __s, const char *__restrict __fmt, struct tm *__tp) __THROW; .../glibc$ Cc: <libc-alpha@sourceware.org> Cc: Ulrich Drepper <drepper@redhat.com> Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14string.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-1/+1
glibc uses 'restrict' in strsep(). Let's use it here too. .../glibc$ grep_glibc_prototype strsep string/string.h:455: extern char *strsep (char **__restrict __stringp, const char *__restrict __delim) __THROW __nonnull ((1, 2)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14string.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-8/+11
Both POSIX and glibc use 'restrict' in stpcpy(), strcat(), strcpy(), strncat(), strncpy(), strtok(), strxfrm(). Let's use it here too. .../glibc$ grep_glibc_prototype stpcpy string/string.h:475: extern char *stpcpy (char *__restrict __dest, const char *__restrict __src) __THROW __nonnull ((1, 2)); .../glibc$ grep_glibc_prototype strcat string/string.h:133: extern char *strcat (char *__restrict __dest, const char *__restrict __src) __THROW __nonnull ((1, 2)); .../glibc$ grep_glibc_prototype strcpy string/string.h:125: extern char *strcpy (char *__restrict __dest, const char *__restrict __src) __THROW __nonnull ((1, 2)); .../glibc$ grep_glibc_prototype strncat string/string.h:136: extern char *strncat (char *__restrict __dest, const char *__restrict __src, size_t __n) __THROW __nonnull ((1, 2)); .../glibc$ grep_glibc_prototype strncpy string/string.h:128: extern char *strncpy (char *__restrict __dest, const char *__restrict __src, size_t __n) __THROW __nonnull ((1, 2)); .../glibc$ grep_glibc_prototype strtok string/string.h:340: extern char *strtok (char *__restrict __s, const char *__restrict __delim) __THROW __nonnull ((2)); .../glibc$ grep_glibc_prototype strxfrm string/string.h:150: extern size_t strxfrm (char *__restrict __dest, const char *__restrict __src, size_t __n) __THROW __nonnull ((2)) __attr_access ((__write_only__, 1, 3)); .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>
2021-03-14strftime.3: SYNOPSIS: Use 'restrict' in prototypesAlejandro Colomar1-2/+3
Both POSIX and glibc use 'restrict' in strftime(). Let's use it here too. .../glibc$ grep_glibc_prototype strftime timezone/private.h:506: size_t strftime(char *restrict, size_t, char const *restrict, struct tm const *restrict); time/time.h:88: extern size_t strftime (char *__restrict __s, size_t __maxsize, const char *__restrict __format, const struct tm *__restrict __tp) __THROW; .../glibc$ Signed-off-by: Alejandro Colomar <alx.manpages@gmail.com> Signed-off-by: Michael Kerrisk <mtk.manpages@gmail.com>