aboutsummaryrefslogtreecommitdiffstats
path: root/man
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--man3/libsimple_memchr_inv.385
-rw-r--r--man3/libsimple_memrelem.31
-rw-r--r--man3/libsimple_memrelem_inv.31
-rw-r--r--man3/libsimple_rawmemelem.387
-rw-r--r--man3/libsimple_rawmemelem_inv.388
-rw-r--r--man3/libsimple_rawmemrelem.388
-rw-r--r--man3/libsimple_rawmemrelem_inv.389
-rw-r--r--man3/libsimple_strcasechr.31
-rw-r--r--man3/libsimple_strcasechr_inv.383
-rw-r--r--man3/libsimple_strchr_inv.383
-rw-r--r--man3/libsimple_strncasechr.31
-rw-r--r--man3/libsimple_strncasechr_inv.388
-rw-r--r--man3/libsimple_strnchr.35
-rw-r--r--man3/libsimple_strnchr_inv.388
-rw-r--r--man3/libsimple_strrcasechr.31
-rw-r--r--man3/libsimple_strrcasechr_inv.382
-rw-r--r--man3/libsimple_strrchr_inv.382
-rw-r--r--man3/libsimple_strrncasechr.31
-rw-r--r--man3/libsimple_strrncasechr_inv.387
-rw-r--r--man3/libsimple_strrnchr.35
-rw-r--r--man3/libsimple_strrnchr_inv.387
21 files changed, 1129 insertions, 4 deletions
diff --git a/man3/libsimple_memchr_inv.3 b/man3/libsimple_memchr_inv.3
new file mode 100644
index 0000000..23c8271
--- /dev/null
+++ b/man3/libsimple_memchr_inv.3
@@ -0,0 +1,85 @@
+.TH LIBSIMPLE_MEMCHR_INV 3 2018-11-24 libsimple
+.SH NAME
+libsimple_memchr_inv \- find different byte in memory
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+void *libsimple_memchr_inv(const void *\fIs\fP, int \fIc\fP, size_t \fIn\fP);
+
+#ifndef memchr_inv
+# define memchr_inv libsimple_memchr_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_memchr_inv ()
+function scans the memory segment
+.IR s ,
+with the size
+.IR n ,
+for the first occurence of any byte
+other than
+.I c
+(it is converted to a
+.BR char ).
+.PP
+The comparison is case-sensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_memchr_inv ()
+function returns the pointer
+.I s
+with a minimal offset such that
+.IR *r!=c ,
+where
+.I r
+is the returned pointer.
+If no such offset exists,
+.B NULL
+is returned.
+.SH ERRORS
+The
+.BR libsimple_memchr_inv ()
+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_memchr_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_memchr_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_memchr_inv ()
+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_memcasechr_inv (3),
+.BR libsimple_memrchr_inv (3),
+.BR libsimple_rawmemchr_inv (3),
+.BR libsimple_memscan_inv (3),
+.BR libsimple_strnchr_inv (3),
+.BR libsimple_strchr_inv (3),
+.BR memchr (3)
diff --git a/man3/libsimple_memrelem.3 b/man3/libsimple_memrelem.3
index 3718b19..f6681e9 100644
--- a/man3/libsimple_memrelem.3
+++ b/man3/libsimple_memrelem.3
@@ -80,6 +80,7 @@ None.
None.
.SH SEE ALSO
.BR libsimple_memrelem_inv (3),
+.BR libsimple_rawmemrelem (3),
.BR libsimple_memelem (3),
.BR libsimple_memrmem (3),
.BR libsimple_memrchr (3)
diff --git a/man3/libsimple_memrelem_inv.3 b/man3/libsimple_memrelem_inv.3
index 71618c2..02b4be7 100644
--- a/man3/libsimple_memrelem_inv.3
+++ b/man3/libsimple_memrelem_inv.3
@@ -81,6 +81,7 @@ None.
None.
.SH SEE ALSO
.BR libsimple_memrelem (3),
+.BR libsimple_rawmemrelem_inv (3),
.BR libsimple_memelem_inv (3),
.BR libsimple_memrmem_inv (3),
.BR libsimple_memrchr_inv (3)
diff --git a/man3/libsimple_rawmemelem.3 b/man3/libsimple_rawmemelem.3
new file mode 100644
index 0000000..4e83ed0
--- /dev/null
+++ b/man3/libsimple_rawmemelem.3
@@ -0,0 +1,87 @@
+.TH LIBSIMPLE_RAWMEMELEM 3 2018-11-24 libsimple
+.SH NAME
+libsimple_rawmemelem \- find aligned byte string in memory
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+void *libsimple_rawmemelem(const void *\fIhaystack\fP, const void *\fIneedle\fP, size_t \fInneedle\fP);
+
+#ifndef rawmemelem
+# define rawmemelem libsimple_rawmemelem
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_rawmemelem ()
+function scans the memory segment
+.IR haystack ,
+for the first occurence of the byte string
+.I needle
+with the size
+.IR nneedle ,
+and with an offset equivalent to zero modulo
+.IR nneedle .
+.PP
+The
+.BR libsimple_rawmemelem ()
+function assumes there is at least one
+occurence, its behaviour is undefined
+if this is not the case.
+.PP
+The comparison is case-sensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_rawmemelem ()
+function returns the pointer
+.I s
+with a minimal offset such that
+.IR !memcmp(r,needle,nneedle) ,
+where
+.I r
+is the returned pointer, and such that
+the offset is equivalent to zero modulo
+.IR nneedle .
+If no such offset exists, the behaviour is undefined.
+.SH ERRORS
+The
+.BR libsimple_rawmemelem ()
+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_rawmemelem ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_rawmemelem ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_rawmemelem ()
+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_rawmemelem_inv (3),
+.BR libsimple_rawmemrelem (3),
+.BR libsimple_memelem (3),
+.BR libsimple_rawmemchr (3)
diff --git a/man3/libsimple_rawmemelem_inv.3 b/man3/libsimple_rawmemelem_inv.3
new file mode 100644
index 0000000..20ed595
--- /dev/null
+++ b/man3/libsimple_rawmemelem_inv.3
@@ -0,0 +1,88 @@
+.TH LIBSIMPLE_RAWMEMELEM_INV 3 2018-11-24 libsimple
+.SH NAME
+libsimple_rawmemelem_inv \- find different aligned byte string in memory
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+void *libsimple_rawmemelem_inv(const void *\fIhaystack\fP, const void *\fIneedle\fP, size_t \fInneedle\fP);
+
+#ifndef rawmemelem_inv
+# define rawmemelem_inv libsimple_rawmemelem_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_rawmemelem_inv ()
+function scans the memory segment
+.IR haystack ,
+for the first occurence of a byte string
+different from
+.I needle
+with the size
+.IR nneedle ,
+and with an offset equivalent to zero modulo
+.IR nneedle .
+.PP
+The
+.BR libsimple_rawmemchr ()
+function assumes there is at least one
+occurence, its behaviour is undefined
+if this is not the case.
+.PP
+The comparison is case-sensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_rawmemelem_inv ()
+function returns the pointer
+.I s
+with a minimal offset such that
+.IR memcmp(r,needle,nneedle) ,
+where
+.I r
+is the returned pointer, and such that
+the offset is equivalent to zero modulo
+.IR nneedle .
+If no such offset exists, the behaviour is undefined.
+.SH ERRORS
+The
+.BR libsimple_rawmemelem_inv ()
+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_rawmemelem_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_rawmemelem_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_rawmemelem_inv ()
+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_rawmemelem (3),
+.BR libsimple_rawmemrelem_inv (3),
+.BR libsimple_memelem_inv (3),
+.BR libsimple_rawmemchr_inv (3)
diff --git a/man3/libsimple_rawmemrelem.3 b/man3/libsimple_rawmemrelem.3
new file mode 100644
index 0000000..0a179a8
--- /dev/null
+++ b/man3/libsimple_rawmemrelem.3
@@ -0,0 +1,88 @@
+.TH LIBSIMPLE_RAWMEMRELEM 3 2018-11-24 libsimple
+.SH NAME
+libsimple_rawmemrelem \- find aligned byte string in memory
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+void *libsimple_rawmemrelem(const void *\fIhaystack\fP, size_t \fInhaystack\fP, const void *\fIneedle\fP, size_t \fInneedle\fP);
+
+#ifndef rawmemrelem
+# define rawmemrelem libsimple_rawmemrelem
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_rawmemrelem ()
+function scans the memory segment
+.IR haystack ,
+with the size
+.IR nhaystack*nneedle ,
+for the last occurence of the byte string
+.I needle
+with the size
+.IR nneedle ,
+and with an offset equivalent to zero modulo
+.IR nneedle .
+The
+.BR libsimple_rawmemrelem ()
+function assumes there is at least one
+occurence, its behaviour is undefined
+if this is not the case.
+.PP
+The comparison is case-sensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_rawmemrelem ()
+function returns the pointer
+.I s
+with a maximal offset such that
+.IR !memcmp(r,needle,nneedle) ,
+where
+.I r
+is the returned pointer, and such that
+the offset is equivalent to zero modulo
+.IR nneedle .
+If no such offset exists, the behaviour is undefined.
+.SH ERRORS
+The
+.BR libsimple_rawmemrelem ()
+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_rawmemrelem ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_rawmemrelem ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_rawmemrelem ()
+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_rawmemrelem_inv (3),
+.BR libsimple_memrelem (3),
+.BR libsimple_rawmemelem (3),
+.BR libsimple_rawmemrchr (3)
diff --git a/man3/libsimple_rawmemrelem_inv.3 b/man3/libsimple_rawmemrelem_inv.3
new file mode 100644
index 0000000..d2d1acf
--- /dev/null
+++ b/man3/libsimple_rawmemrelem_inv.3
@@ -0,0 +1,89 @@
+.TH LIBSIMPLE_RAWMEMRELEM_INV 3 2018-11-24 libsimple
+.SH NAME
+libsimple_rawmemrelem_inv \- find different aligned byte string in memory
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+void *libsimple_rawmemrelem_inv(const void *\fIhaystack\fP, size_t \fInhaystack\fP, const void *\fIneedle\fP, size_t \fInneedle\fP);
+
+#ifndef rawmemrelem_inv
+# define rawmemrelem_inv libsimple_rawmemrelem_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_rawmemrelem_inv ()
+function scans the memory segment
+.IR haystack ,
+with the size
+.IR nhaystack*nneedle ,
+for the last occurence of a byte string
+different from
+.I needle
+with the size
+.IR nneedle ,
+and with an offset equivalent to zero modulo
+.IR nneedle .
+The
+.BR libsimple_rawmemrelem_inv ()
+function assumes there is at least one
+occurence, its behaviour is undefined
+if this is not the case.
+.PP
+The comparison is case-sensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_rawmemrelem_inv ()
+function returns the pointer
+.I s
+with a maximal offset such that
+.IR memcmp(r,needle,nneedle) ,
+where
+.I r
+is the returned pointer, and such that
+the offset is equivalent to zero modulo
+.IR nneedle .
+If no such offset exists, the behaviour is undefined.
+.SH ERRORS
+The
+.BR libsimple_rawmemrelem_inv ()
+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_rawmemrelem_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_rawmemrelem_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_rawmemrelem_inv ()
+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_rawmemrelem (3),
+.BR libsimple_memrelem_inv (3),
+.BR libsimple_rawmemelem_inv (3),
+.BR libsimple_rawmemrchr_inv (3)
diff --git a/man3/libsimple_strcasechr.3 b/man3/libsimple_strcasechr.3
index 8d644a1..0f1a7f3 100644
--- a/man3/libsimple_strcasechr.3
+++ b/man3/libsimple_strcasechr.3
@@ -74,6 +74,7 @@ None.
.SH BUGS
None.
.SH SEE ALSO
+.BR libsimple_strcasechr_inv (3),
.BR libsimple_strcasechrnul (3),
.BR libsimple_strrcasechr (3),
.BR libsimple_strncasechr (3),
diff --git a/man3/libsimple_strcasechr_inv.3 b/man3/libsimple_strcasechr_inv.3
new file mode 100644
index 0000000..baf5574
--- /dev/null
+++ b/man3/libsimple_strcasechr_inv.3
@@ -0,0 +1,83 @@
+.TH LIBSIMPLE_STRCASECHR_INV 3 2018-11-25 libsimple
+.SH NAME
+libsimple_strcasechr_inv \- find a different character in a string
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+char *libsimple_strcasechr_inv(const char *\fIs\fP, int \fIc\fP);
+
+#ifndef strcasechr_inv
+# define strcasechr_inv libsimple_strcasechr_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_strcasechr_inv ()
+function scans the string
+.I s
+for the first occurence of any character
+other than
+.I c
+(it is converted to a
+.BR char ).
+If no such character exist in the string,
+the string's end is returned.
+.PP
+The comparison is case-insensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_strcasechr_inv ()
+function returns the pointer
+.I s
+with a minimal offset such that
+.IR tolower(*r)!=tolower(c) ,
+where
+.I r
+is the returned pointer, if no such
+offset exists, it returns
+.BR NULL .
+.SH ERRORS
+The
+.BR libsimple_strcasechr_inv ()
+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_strcasechr_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_strcasechr_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_strcasechr_inv ()
+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_strcasechr (3),
+.BR libsimple_strchr_inv (3),
+.BR libsimple_strcasechrnul_inv (3),
+.BR libsimple_strrcasechr_inv (3),
+.BR libsimple_strncasechr_inv (3),
+.BR libsimple_memcasechr_inv (3)
diff --git a/man3/libsimple_strchr_inv.3 b/man3/libsimple_strchr_inv.3
new file mode 100644
index 0000000..e1cdf53
--- /dev/null
+++ b/man3/libsimple_strchr_inv.3
@@ -0,0 +1,83 @@
+.TH LIBSIMPLE_STRCHR_INV 3 2018-11-25 libsimple
+.SH NAME
+libsimple_strchr_inv \- find a different character in a string
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+char *libsimple_strchr_inv(const char *\fIs\fP, int \fIc\fP);
+
+#ifndef strchr_inv
+# define strchr_inv libsimple_strchr_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_strchr_inv ()
+function scans the string
+.I s
+for the first occurence of any character
+other than
+.I c
+(it is converted to a
+.BR char ).
+If no such character exist in the string,
+the string's end is returned.
+.PP
+The comparison is case-sensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_strchr_inv ()
+function returns the pointer
+.I s
+with a minimal offset such that
+.IR *r!=c ,
+where
+.I r
+is the returned pointer, if no such
+offset exists, it returns
+.BR NULL .
+.SH ERRORS
+The
+.BR libsimple_strchr_inv ()
+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_strchr_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_strchr_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_strchr_inv ()
+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_strcasechr_inv (3),
+.BR libsimple_strchrnul_inv (3),
+.BR libsimple_strrchr_inv (3),
+.BR libsimple_strnchr_inv (3),
+.BR libsimple_memchr_inv (3),
+.BR strchr (3)
diff --git a/man3/libsimple_strncasechr.3 b/man3/libsimple_strncasechr.3
index 1a7716f..b0a1c96 100644
--- a/man3/libsimple_strncasechr.3
+++ b/man3/libsimple_strncasechr.3
@@ -79,6 +79,7 @@ None.
.SH BUGS
None.
.SH SEE ALSO
+.BR libsimple_strncasechr_inv (3),
.BR libsimple_strncasechrnul (3),
.BR libsimple_strrncasechr (3),
.BR libsimple_strnchr (3),
diff --git a/man3/libsimple_strncasechr_inv.3 b/man3/libsimple_strncasechr_inv.3
new file mode 100644
index 0000000..c23fe84
--- /dev/null
+++ b/man3/libsimple_strncasechr_inv.3
@@ -0,0 +1,88 @@
+.TH LIBSIMPLE_STRNCASECHR_INV 3 2018-11-25 libsimple
+.SH NAME
+libsimple_strncasechr_inv \- find a different character in a string
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+char *libsimple_strncasechr_inv(const char *\fIs\fP, int \fIc\fP, size_t \fIn\fP);
+
+#ifndef strncasechr_inv
+# define strncasechr_inv libsimple_strncasechr_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_strncasechr_inv ()
+function scans the string
+.IR s ,
+truncated to
+.I n
+bytes unless it is shorter,
+for the first occurence of any character
+other than
+.I c
+(it is converted to a
+.BR char ).
+If no such character exist in the string,
+the string's end is returned.
+.PP
+The comparison is case-insensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_strncasechr_inv ()
+function returns the pointer
+.I s
+with a minimal offset such that
+.IR tolower(*r)!=tolower(c) ,
+where
+.I r
+is the returned pointer, if no such
+offset less than
+.I n
+exists, it returns
+.BR NULL .
+.SH ERRORS
+The
+.BR libsimple_strncasechr_inv ()
+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_strncasechr_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_strncasechr_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_strncasechr_inv ()
+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_strncasechr (3),
+.BR libsimple_strncasechrnul_inv (3),
+.BR libsimple_strrncasechr_inv (3),
+.BR libsimple_strnchr_inv (3),
+.BR libsimple_strcasechr_inv (3),
+.BR libsimple_memcasechr_inv (3)
diff --git a/man3/libsimple_strnchr.3 b/man3/libsimple_strnchr.3
index 2af62c3..bdb2787 100644
--- a/man3/libsimple_strnchr.3
+++ b/man3/libsimple_strnchr.3
@@ -79,8 +79,9 @@ None.
.SH BUGS
None.
.SH SEE ALSO
+.BR libsimple_strnchr_inv (3),
.BR libsimple_strnchrnul (3),
.BR libsimple_strncasechr (3),
-.BR libsimple_strrnchr (3)
+.BR libsimple_strrnchr (3),
.BR strchr (3),
-.BR memchr (3),
+.BR memchr (3)
diff --git a/man3/libsimple_strnchr_inv.3 b/man3/libsimple_strnchr_inv.3
new file mode 100644
index 0000000..594021f
--- /dev/null
+++ b/man3/libsimple_strnchr_inv.3
@@ -0,0 +1,88 @@
+.TH LIBSIMPLE_STRNCHR_INV 3 2018-11-25 libsimple
+.SH NAME
+libsimple_strnchr_inv \- find a different character in a string
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+char *libsimple_strnchr_inv(const char *\fIs\fP, int \fIc\fP, size_t \fIn\fP);
+
+#ifndef strnchr_inv
+# define strnchr_inv libsimple_strnchr_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_strnchr_inv ()
+function scans the string
+.IR s ,
+truncated to
+.I n
+bytes unless it is shorter,
+for the first occurence of any character
+other than
+.I c
+(it is converted to a
+.BR char ).
+If no such character exist in the string,
+the string's end is returned.
+.PP
+The comparison is case-sensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_strnchr_inv ()
+function returns the pointer
+.I s
+with a minimal offset such that
+.IR *r!=c ,
+where
+.I r
+is the returned pointer, if no such
+offset less than
+.I n
+exists, it returns
+.BR NULL .
+.SH ERRORS
+The
+.BR libsimple_strnchr_inv ()
+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_strnchr_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_strnchr_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_strnchr_inv ()
+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_strnchr (3),
+.BR libsimple_strnchrnul_inv (3),
+.BR libsimple_strncasechr_inv (3),
+.BR libsimple_strrnchr_inv (3),
+.BR libsimple_strchr_inv (3),
+.BR libsimple_memchr_inv (3)
diff --git a/man3/libsimple_strrcasechr.3 b/man3/libsimple_strrcasechr.3
index 34475b6..62ff883 100644
--- a/man3/libsimple_strrcasechr.3
+++ b/man3/libsimple_strrcasechr.3
@@ -74,6 +74,7 @@ None.
.SH BUGS
None.
.SH SEE ALSO
+.BR libsimple_strrcasechr_inv (3),
.BR libsimple_strcasechr (3),
.BR libsimple_strrncasechr (3),
.BR libsimple_memrcasechr (3),
diff --git a/man3/libsimple_strrcasechr_inv.3 b/man3/libsimple_strrcasechr_inv.3
new file mode 100644
index 0000000..66f9df4
--- /dev/null
+++ b/man3/libsimple_strrcasechr_inv.3
@@ -0,0 +1,82 @@
+.TH LIBSIMPLE_STRRCASECHR_INV 3 2018-11-25 libsimple
+.SH NAME
+libsimple_strrcasechr_inv \- find a different character in a string
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+char *libsimple_strrcasechr_inv(const char *\fIs\fP, int \fIc\fP);
+
+#ifndef strrcasechr_inv
+# define strrcasechr_inv libsimple_strrcasechr_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_strrcasechr_inv ()
+function scans the string
+.I s
+for the last occurence of any character
+other than
+.I c
+(it is converted to a
+.BR char ).
+If no such character exist in the string,
+the string's end is returned.
+.PP
+The comparison is case-insensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_strrcasechr_inv ()
+function returns the pointer
+.I s
+with a maximal offset such that
+.IR tolower(*r)!=tolower(c) ,
+where
+.I r
+is the returned pointer, if no such
+offset exists, it returns
+.BR NULL .
+.SH ERRORS
+The
+.BR libsimple_strrcasechr_inv ()
+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_strrcasechr_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_strrcasechr_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_strrcasechr_inv ()
+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_strrcasechr (3),
+.BR libsimple_strrchr_inv (3),
+.BR libsimple_strcasechr_inv (3),
+.BR libsimple_strrncasechr_inv (3),
+.BR libsimple_memrcasechr_inv (3)
diff --git a/man3/libsimple_strrchr_inv.3 b/man3/libsimple_strrchr_inv.3
new file mode 100644
index 0000000..71059fa
--- /dev/null
+++ b/man3/libsimple_strrchr_inv.3
@@ -0,0 +1,82 @@
+.TH LIBSIMPLE_STRRCHR_INV 3 2018-11-25 libsimple
+.SH NAME
+libsimple_strrchr_inv \- find a different character in a string
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+char *libsimple_strrchr_inv(const char *\fIs\fP, int \fIc\fP);
+
+#ifndef strrchr_inv
+# define strrchr_inv libsimple_strrchr_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_strrchr_inv ()
+function scans the string
+.I s
+for the last occurence of any character
+other than
+.I c
+(it is converted to a
+.BR char ).
+If no such character exist in the string,
+the string's end is returned.
+.PP
+The comparison is case-sensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_strrchr_inv ()
+function returns the pointer
+.I s
+with a maximal offset such that
+.IR *r!=c ,
+where
+.I r
+is the returned pointer, if no such
+offset exists, it returns
+.BR NULL .
+.SH ERRORS
+The
+.BR libsimple_strrchr_inv ()
+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_strrchr_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_strrchr_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_strrchr_inv ()
+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_strrchr (3),
+.BR libsimple_strrcasechr_inv (3),
+.BR libsimple_strchr_inv (3),
+.BR libsimple_strrnchr_inv (3),
+.BR libsimple_memrchr_inv (3)
diff --git a/man3/libsimple_strrncasechr.3 b/man3/libsimple_strrncasechr.3
index 9d70548..7e3ae4e 100644
--- a/man3/libsimple_strrncasechr.3
+++ b/man3/libsimple_strrncasechr.3
@@ -79,6 +79,7 @@ None.
.SH BUGS
None.
.SH SEE ALSO
+.BR libsimple_strrncasechr_inv (3),
.BR libsimple_strncasechr (3),
.BR libsimple_strrnchr (3),
.BR libsimple_strrcasechr (3),
diff --git a/man3/libsimple_strrncasechr_inv.3 b/man3/libsimple_strrncasechr_inv.3
new file mode 100644
index 0000000..40426d6
--- /dev/null
+++ b/man3/libsimple_strrncasechr_inv.3
@@ -0,0 +1,87 @@
+.TH LIBSIMPLE_STRRNCASECHR_INV 3 2018-11-25 libsimple
+.SH NAME
+libsimple_strrncasechr_inv \- find a different character in a string
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+char *libsimple_strrncasechr_inv(const char *\fIs\fP, int \fIc\fP, size_t \fIn\fP);
+
+#ifndef strrncasechr_inv
+# define strrncasechr_inv libsimple_strrncasechr_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_strrncasechr_inv ()
+function scans the string
+.IR s ,
+truncated to
+.I n
+bytes unless it is shorter,
+for the last occurence of any character
+other than
+.I c
+(it is converted to a
+.BR char ).
+If no such character exist in the string,
+the string's end is returned.
+.PP
+The comparison is case-insensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_strrncasechr_inv ()
+function returns the pointer
+.I s
+with a maximal offset such that
+.IR tolower(*r)!=tolower(c) ,
+where
+.I r
+is the returned pointer, if no such
+offset less than
+.I n
+exists, it returns
+.BR NULL .
+.SH ERRORS
+The
+.BR libsimple_strrncasechr_inv ()
+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_strrncasechr_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_strrncasechr_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_strrncasechr_inv ()
+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_strrncasechr (3),
+.BR libsimple_strncasechr_inv (3),
+.BR libsimple_strrnchr_inv (3),
+.BR libsimple_strrcasechr_inv (3),
+.BR libsimple_memrcasechr_inv (3)
diff --git a/man3/libsimple_strrnchr.3 b/man3/libsimple_strrnchr.3
index f01025d..a677bfe 100644
--- a/man3/libsimple_strrnchr.3
+++ b/man3/libsimple_strrnchr.3
@@ -79,7 +79,8 @@ None.
.SH BUGS
None.
.SH SEE ALSO
+.BR libsimple_strrnchr_inv (3),
.BR libsimple_strrncasechr (3),
.BR libsimple_strnchr (3),
-.BR libsimple_strrchr (3),
-.BR libsimple_memrchr (3)
+.BR libsimple_memrchr (3),
+.BR strrchr (3)
diff --git a/man3/libsimple_strrnchr_inv.3 b/man3/libsimple_strrnchr_inv.3
new file mode 100644
index 0000000..3cfdac9
--- /dev/null
+++ b/man3/libsimple_strrnchr_inv.3
@@ -0,0 +1,87 @@
+.TH LIBSIMPLE_STRRNCHR_INV 3 2018-11-25 libsimple
+.SH NAME
+libsimple_strrnchr_inv \- find a different character in a string
+.SH SYNOPSIS
+.nf
+#include <libsimple.h>
+
+char *libsimple_strrnchr_inv(const char *\fIs\fP, int \fIc\fP, size_t \fIn\fP);
+
+#ifndef strrnchr_inv
+# define strrnchr_inv libsimple_strrnchr_inv
+#endif
+.fi
+.PP
+Link with
+.IR \-lsimple .
+.SH DESCRIPTION
+The
+.BR libsimple_strrnchr_inv ()
+function scans the string
+.IR s ,
+truncated to
+.I n
+bytes unless it is shorter,
+for the last occurence of any character
+other than
+.I c
+(it is converted to a
+.BR char ).
+If no such character exist in the string,
+the string's end is returned.
+.PP
+The comparison is case-sensitive.
+.SH RETURN VALUE
+The
+.BR libsimple_strrnchr_inv ()
+function returns the pointer
+.I s
+with a maximal offset such that
+.IR *r!=c ,
+where
+.I r
+is the returned pointer, if no such
+offset less than
+.I n
+exists, it returns
+.BR NULL .
+.SH ERRORS
+The
+.BR libsimple_strrnchr_inv ()
+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_strrnchr_inv ()
+T} Thread safety MT-Safe
+T{
+.BR libsimple_strrnchr_inv ()
+T} Async-signal safety AS-Safe
+T{
+.BR libsimple_strrnchr_inv ()
+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_strrnchr (3),
+.BR libsimple_strrncasechr_inv (3),
+.BR libsimple_strnchr_inv (3),
+.BR libsimple_strrchr_inv (3),
+.BR libsimple_memrchr_inv (3)