summaryrefslogtreecommitdiff
path: root/newlib/libc/string/strrchr.c
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2017-12-15 09:38:53 -0500
committerPikalaxALT <pikalaxalt@gmail.com>2017-12-15 09:39:34 -0500
commitf95a4a932476be2ba99e2fd081e8d2bc6ea12813 (patch)
tree75f67192cb2d7b7b575c94edda318e475239b63c /newlib/libc/string/strrchr.c
parentf60aca96985e68c7d8a52eb7bc955fb80e132f73 (diff)
Import newlib and create makefile
Diffstat (limited to 'newlib/libc/string/strrchr.c')
-rw-r--r--newlib/libc/string/strrchr.c61
1 files changed, 61 insertions, 0 deletions
diff --git a/newlib/libc/string/strrchr.c b/newlib/libc/string/strrchr.c
new file mode 100644
index 0000000..65160f5
--- /dev/null
+++ b/newlib/libc/string/strrchr.c
@@ -0,0 +1,61 @@
+/*
+FUNCTION
+ <<strrchr>>---reverse search for character in string
+
+INDEX
+ strrchr
+
+ANSI_SYNOPSIS
+ #include <string.h>
+ char * strrchr(const char *<[string]>, int <[c]>);
+
+TRAD_SYNOPSIS
+ #include <string.h>
+ char * strrchr(<[string]>, <[c]>);
+ char *<[string]>;
+ int *<[c]>;
+
+DESCRIPTION
+ This function finds the last occurence of <[c]> (converted to
+ a char) in the string pointed to by <[string]> (including the
+ terminating null character).
+
+RETURNS
+ Returns a pointer to the located character, or a null pointer
+ if <[c]> does not occur in <[string]>.
+
+PORTABILITY
+<<strrchr>> is ANSI C.
+
+<<strrchr>> requires no supporting OS subroutines.
+
+QUICKREF
+ strrchr ansi pure
+*/
+
+#include <string.h>
+
+char *
+_DEFUN (strrchr, (s, i),
+ _CONST char *s _AND
+ int i)
+{
+ _CONST char *last = NULL;
+ char c = i;
+
+ while (*s)
+ {
+ if (*s == c)
+ {
+ last = s;
+ }
+ s++;
+ }
+
+ if (*s == c)
+ {
+ last = s;
+ }
+
+ return (char *) last;
+}