/** * 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 . */ #ifndef _STDLIB_H #define _STDLIB_H #include #include #include #define __NEED_size_t #define __NEED_wchar_t #define __NEED_div_t #define __NEED_ldiv_t #define __NEED_lldiv_t #include /** * `NULL`'s canonical header is . */ #ifndef NULL # define NULL ((void*)0) #endif /** * The value a process shall exit with upon * success completion. */ #define EXIT_SUCCESS 0 /** * A standard value a process can exit with * if it terminates because of failure. */ #define EXIT_FAILURE 1 /** * Perform an integer division and return * both the quotient and the remainder. * * @param numerator The numerator. * @param denominator The denominator. * @return The quotient in `.quot`, and * the remainder in `.rem`. */ div_t div(int, int) __GCC_ONLY(__attribute__((const))); /** * Perform an integer division and return * both the quotient and the remainder. * * @param numerator The numerator. * @param denominator The denominator. * @return The quotient in `.quot`, and * the remainder in `.rem`. */ ldiv_t ldiv(long, long) __GCC_ONLY(__attribute__((const))); /** * Perform an integer division and return * both the quotient and the remainder. * * @param numerator The numerator. * @param denominator The denominator. * @return The quotient in `.quot`, and * the remainder in `.rem`. */ lldiv_t lldiv(long long, long long) __GCC_ONLY(__attribute__((const))); /** * Return the absolute value of an integer. * * Be aware, if the value is `INT_MIN` and * `-INT_MAX != -INT_MIN`, the result will * overflow, and `INT_MIN` will (probably) * be returned. * * @param value The integer. * @return The absolute value of the integer. */ int abs(int) __GCC_ONLY(__attribute__((const))); /** * Return the absolute value of an integer. * * Be aware, if the value is `LONG_MIN` and * `-LONG_MAX != -LONG_MIN`, the result will * overflow, and `LONG_MIN` will (probably) * be returned. * * @param value The integer. * @return The absolute value of the integer. */ long int labs(long int) __GCC_ONLY(__attribute__((const))); /** * Return the absolute value of an integer. * * Be aware, if the value is `LLONG_MIN` and * `-LLONG_MAX != -LLONG_MIN`, the result will * overflow, and `LLONG_MIN` will (probably) * be returned. * * @param value The integer. * @return The absolute value of the integer. */ long long int llabs(long long int) __GCC_ONLY(__attribute__((const))); #if !defined(__PORTABLE) /** * Get the absolute path of a file. * It will remove all redundant slashes, all "./":s, * and all "../":s, but not resolve symbolic links. * * This is a slibc extension. * * @param file The file. * @param ref The directory the file's specified path is * relative, `NULL` for the current working directory. * @return The file's absolute pathname. Will end with a slash * if `file` does. (Or if `ref` does but file is empty.) * * @throws ENOMEM The process cannot allocate more memory. */ char* abspath(const char*, const char*) __GCC_ONLY(__attribute__((warn_unused_result, nonnull(1), malloc))); /** * Get the relative path of a file. * * This is a slibc extension. * * @param file The file. * @param ref The file the result shall be relative to, * `NULL` for the current working directory. * If and only if this path ends with a slash, * (or if it is `NULL`,) it will be treated as * a directory in which a symbolic link, with * the result as it target, can be located to * point to `file`. * * @throws ENOMEM The process cannot allocate more memory. */ char* relpath(const char*, const char*) __GCC_ONLY(__attribute__((warn_unused_result, nonnull(1), malloc))); #endif /** * Convert a string to a floating-point value, * without checking for errors. * * The string may being with an arbitrary number * of whitespace characters. Convertion will end * when a character is encountered that is not a * decimal digit, and is not an absolutely leading * '-' or '+', or the first '.'. * * @param string The string to convert. * @return The number encoded by the string. */ double atof(const char*) __GCC_ONLY(__attribute__((warn_unused_result, nonnull, pure))); /** * Convert a string to an integer, * without checking for errors. * * The string may being with an arbitrary number * of whitespace characters. Convertion will end * when a character is encountered that is not a * decimal digit, and is not an absolutely leading * '-' or '+'. * * @param string The string to convert. * @return The integer encoded by the string. */ int atoi(const char*) __GCC_ONLY(__attribute__((warn_unused_result, nonnull, pure))); /** * Convert a string to an integer, * without checking for errors. * * The string may being with an arbitrary number * of whitespace characters. Convertion will end * when a character is encountered that is not a * decimal digit, and is not an absolutely leading * '-' or '+'. * * @param string The string to convert. * @return The integer encoded by the string. */ long int atol(const char*) __GCC_ONLY(__attribute__((warn_unused_result, nonnull, pure))); /** * Convert a string to an integer, * without checking for errors. * * The string may being with an arbitrary number * of whitespace characters. Convertion will end * when a character is encountered that is not a * decimal digit, and is not an absolutely leading * '-' or '+'. * * @param string The string to convert. * @return The integer encoded by the string. */ long long int atoll(const char*) __GCC_ONLY(__attribute__((warn_unused_result, nonnull, pure))); #if !defined(__PORTABLE) /** * This function is identical to `atoll`. * * This is a Linux libc extension. */ long long int atoq(const char*) __deprecated("'atoq' is obsolete and not portable, use 'atoll' instead.") __GCC_ONLY(__attribute__((warn_unused_result, nonnull, pure))); #endif /* TODO implement rand-functions */ #define RAND_MAX 1 int rand(void); int rand_r(unsigned int* seed); void srand(unsigned int seed); /* TODO implement exit-functions */ void abort(void) __noreturn; void _Exit(int) __noreturn; int atexit(void (*)(void)); int on_exit(void (*)(int, void*), void*); void exit(int) __noreturn; int at_quick_exit (void (*) (void)); void quick_exit(int) __noreturn; #endif