2022-10-01 18:59:22 +00:00
|
|
|
#ifndef _STDLIB_H
|
|
|
|
#define _STDLIB_H
|
|
|
|
|
2022-10-04 17:11:54 +00:00
|
|
|
#include <bits/macros.h>
|
2022-10-22 19:39:51 +00:00
|
|
|
#include <limits.h>
|
2022-10-01 18:59:22 +00:00
|
|
|
#include <stddef.h>
|
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
#define EXIT_SUCCESS 0 // Value to use when calling exit() to represent successful execution.
|
|
|
|
#define EXIT_FAILURE 1 // Value to use when calling exit() to represent failed execution.
|
2022-10-22 19:39:51 +00:00
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
#define RAND_MAX INT_MAX // Maximum number returned by rand().
|
2022-10-22 19:39:51 +00:00
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
// Return type for an integer division.
|
2022-10-23 10:26:48 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
int quot;
|
|
|
|
int rem;
|
|
|
|
} div_t;
|
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
// Return type for a long integer division.
|
2022-10-23 10:26:48 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
long quot;
|
|
|
|
long rem;
|
|
|
|
} ldiv_t;
|
|
|
|
|
2022-10-25 17:27:24 +00:00
|
|
|
// Return type for a long integer division.
|
2022-10-23 10:26:48 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
long long quot;
|
|
|
|
long long rem;
|
|
|
|
} lldiv_t;
|
|
|
|
|
2022-10-01 18:59:22 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C"
|
|
|
|
{
|
|
|
|
#endif
|
|
|
|
|
2022-10-12 09:30:21 +00:00
|
|
|
/* Aborts the program. */
|
2022-10-15 09:39:13 +00:00
|
|
|
__lc_noreturn void abort(void);
|
2022-10-12 09:30:21 +00:00
|
|
|
|
2022-10-12 18:41:55 +00:00
|
|
|
/* Normally exits the program with the specified status code. */
|
2022-10-15 07:52:37 +00:00
|
|
|
__lc_noreturn void exit(int status);
|
2022-10-12 09:30:21 +00:00
|
|
|
|
2022-10-15 12:02:10 +00:00
|
|
|
/* Abnormally exits the program with the specified status code. */
|
|
|
|
__lc_noreturn void _Exit(int status);
|
|
|
|
|
2022-10-12 18:41:55 +00:00
|
|
|
/* Registers a handler function to be run at normal program termination. */
|
|
|
|
int atexit(void (*handler)(void));
|
2022-10-12 09:30:21 +00:00
|
|
|
|
2022-10-31 11:29:53 +00:00
|
|
|
/* Returns a floating point number parsed from the string str. */
|
|
|
|
float atof(const char* str);
|
|
|
|
|
2022-10-15 12:02:24 +00:00
|
|
|
/* Returns an integer (of type int) parsed from the string str. */
|
|
|
|
int atoi(const char* str);
|
|
|
|
|
|
|
|
/* Returns an integer (of type long) parsed from the string str. */
|
|
|
|
long atol(const char* str);
|
|
|
|
|
|
|
|
/* Returns an integer (of type long long) parsed from the string str. */
|
|
|
|
long long atoll(const char* str);
|
2022-10-12 09:30:21 +00:00
|
|
|
|
2022-10-21 16:32:46 +00:00
|
|
|
/* Returns an integer (of type unsigned long) parsed from the string str. */
|
2022-10-22 10:12:52 +00:00
|
|
|
unsigned long strtoul(const char* str, char** endptr, int base);
|
2022-10-21 16:32:46 +00:00
|
|
|
|
2022-10-23 10:26:48 +00:00
|
|
|
/* Returns an integer (of type long) parsed from the string str. */
|
|
|
|
long strtol(const char* str, char** endptr, int base);
|
|
|
|
|
2022-10-12 09:30:21 +00:00
|
|
|
/* Not implemented. */
|
2022-10-01 18:59:22 +00:00
|
|
|
char* getenv(const char*);
|
2022-10-12 09:30:21 +00:00
|
|
|
|
|
|
|
/* Allocates n bytes of memory and returns a pointer to it. This memory should be freed by calling free() when it is
|
|
|
|
* not in use anymore. */
|
|
|
|
void* malloc(size_t n);
|
|
|
|
|
|
|
|
/* Allocates enough bytes of memory for an array containing nmemb items of size n and returns a pointer to it. This
|
|
|
|
* memory should be freed by calling free() when it is not in use anymore. */
|
|
|
|
void* calloc(size_t nmemb, size_t n);
|
|
|
|
|
|
|
|
/* Resizes memory allocated by malloc() or calloc() to n bytes. Returns a pointer to the new resized region of
|
|
|
|
* memory, which should be used instead of the old one. This memory should be freed by calling free() when it is not
|
|
|
|
* in use anymore. */
|
|
|
|
void* realloc(void* ptr, size_t n);
|
|
|
|
|
|
|
|
/* Frees a pointer to memory allocated by malloc(), calloc() or realloc(). Accessing the contents of ptr afterwards
|
|
|
|
* is undefined behavior. */
|
|
|
|
void free(void* ptr);
|
2022-10-01 18:59:22 +00:00
|
|
|
|
2022-10-15 14:31:08 +00:00
|
|
|
/* Returns a random number. */
|
|
|
|
int rand(void);
|
|
|
|
|
2022-10-15 14:46:54 +00:00
|
|
|
/* Seeds the random number generator with the specified seed. */
|
2022-10-15 14:31:08 +00:00
|
|
|
void srand(unsigned int seed);
|
|
|
|
|
2022-10-23 09:10:26 +00:00
|
|
|
/* Returns the absolute value of an integer. */
|
|
|
|
int abs(int val);
|
|
|
|
|
|
|
|
/* Returns the absolute value of an integer. */
|
|
|
|
long labs(long val);
|
|
|
|
|
|
|
|
/* Returns the absolute value of an integer. */
|
|
|
|
long long llabs(long long val);
|
|
|
|
|
2022-10-23 10:26:48 +00:00
|
|
|
/* Returns the result of dividing a by b. */
|
|
|
|
div_t div(int a, int b);
|
|
|
|
|
|
|
|
/* Returns the result of dividing a by b. */
|
|
|
|
ldiv_t ldiv(long a, long b);
|
|
|
|
|
|
|
|
/* Returns the result of dividing a by b. */
|
|
|
|
lldiv_t lldiv(long long a, long long b);
|
|
|
|
|
2022-10-30 18:43:37 +00:00
|
|
|
/* Runs a shell command. */
|
|
|
|
int system(const char* command);
|
|
|
|
|
2022-11-06 16:16:08 +00:00
|
|
|
/* Sorts the array pointed to by base of nmemb items of the specified size using the comparison function compar. */
|
|
|
|
void qsort(void* base, size_t nmemb, size_t size, int (*compar)(const void*, const void*));
|
2022-10-23 09:19:08 +00:00
|
|
|
|
2022-11-06 16:34:35 +00:00
|
|
|
/* Searches the sorted array base of nmemb items of the specified size for the given key using the comparison
|
|
|
|
* function compar. */
|
|
|
|
void* bsearch(const void* key, const void* base, size_t nmemb, size_t size,
|
|
|
|
int (*compar)(const void*, const void*));
|
2022-10-30 19:02:03 +00:00
|
|
|
|
2022-10-29 07:39:12 +00:00
|
|
|
size_t mbstowcs(wchar_t* dest, const char* src,
|
|
|
|
size_t n); // Not implemented.
|
|
|
|
|
2022-11-05 17:07:45 +00:00
|
|
|
/* Generate a unique filename from the template string str. The last 6 bytes of str must be 'XXXXXX', and they will
|
|
|
|
* be replaced with random characters. This function is deprecated due to race conditions; between the name being
|
|
|
|
* generated and creating a file with that name, that filename could have already been used. */
|
|
|
|
__lc_is_deprecated char* mktemp(char* str);
|
2022-10-29 07:39:12 +00:00
|
|
|
|
2022-10-01 18:59:22 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|