1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
.TH LIBSIMPLE_STRNCMPNUL 3 libsimple
.SH NAME
libsimple_strncmpnul \- compare two strings
.SH SYNOPSIS
.nf
#include <libsimple.h>
inline int libsimple_strncmpnul(const char *\fIa\fP, const char *\fIb\fP, size_t \fIn\fP);
#ifndef strncmpnul
# define strncmpnul libsimple_strncmpnul
#endif
.fi
.PP
Link with
.IR \-lsimple .
.SH DESCRIPTION
The
.BR libsimple_strncmpnul ()
function compares the strings
.IR a ,
truncated to
.I n
bytes unless it is shorter,
and
.IR b ,
truncated to
.I n
bytes unless it is shorter,
both of which may be
.BR NULL ,
which is treated as less than the empty string.
.PP
If one of the strings begins with the other string
but is longer, the longer string is treated as
greater than the shorter string.
.PP
The comparison is case-sensitive and made as if
the strings were
.BR "unsigned char *" s.
.SH RETURN VALUE
The
.BR libsimple_strncmpnul ()
function returns a negative value if
.I a
is less than
.IR b ,
a positive value if
.I a
is greater than
.IR b ,
and 0 otherwise.
.SH ERRORS
The
.BR libsimple_strncmpnul ()
function cannot fail.
.SH ATTRIBUTES
For an explanation of the terms used in this section, see
.BR attributes (7).
.TS
allbox;
lb lb lb
l l l.
Interface Attribute Value
T{
.BR libsimple_strncmpnul ()
T} Thread safety MT-Safe
T{
.BR libsimple_strncmpnul ()
T} Async-signal safety AS-Safe
T{
.BR libsimple_strncmpnul ()
T} Async-cancel safety AC-Safe
.TE
.SH EXAMPLES
None.
.SH APPLICATION USAGE
None.
.SH RATIONALE
None.
.SH FUTURE DIRECTIONS
None.
.SH NOTES
None.
.SH BUGS
None.
.SH SEE ALSO
.BR libsimple_strncasecmpnul (3),
.BR libsimple_strneqnul (3),
.BR libsimple_strcmpnul (3),
.BR strncmp (3)
|