From 896026a8991aa4f55c2e7a20efc22f1a8c52ee80 Mon Sep 17 00:00:00 2001 From: Mattias Andrée Date: Tue, 17 Nov 2015 03:31:32 +0100 Subject: move strerror*.c to new dir: strerror/ MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Signed-off-by: Mattias Andrée --- src/string/strerror/strerror.c | 44 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 44 insertions(+) create mode 100644 src/string/strerror/strerror.c (limited to 'src/string/strerror/strerror.c') diff --git a/src/string/strerror/strerror.c b/src/string/strerror/strerror.c new file mode 100644 index 0000000..315e40d --- /dev/null +++ b/src/string/strerror/strerror.c @@ -0,0 +1,44 @@ +/** + * slibc — Yet another C library + * Copyright © 2015 Mattias Andrée (maandree@member.fsf.org) + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + */ +#include + + + +/** + * Return a textual representation of an error code. + * This error code must from `errno`. + * + * This implementation of `strerror` cannot fail. however + * POSIX specifies that it can fail, any may only set `errno` + * if it does fail. You should therefore, set `errno` to + * zero before calling this function, and inspect `errno` + * when it returns, as there is no reserved return value + * that indicates and error. + * + * The returned value must not be modified or freed. + * + * As a slibc-specific modification, this function is MT-Safe. + * + * @param errnum The error code. + * @return A description of the error. + */ +char* strerror(int errnum) +{ + return strerror_l(errnum, 0 /* TODO CURRENT_LOCALE, not defined */); +} + -- cgit v1.2.3-70-g09d2