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-01 18:59:22 +00:00
|
|
|
#include <stddef.h>
|
|
|
|
|
|
|
|
#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-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
|
|
|
|
|
|
|
/* 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
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|