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-01 18:59:22 +00:00
|
|
|
noreturn void abort();
|
2022-10-12 09:30:21 +00:00
|
|
|
|
|
|
|
/* Exits the program with the specified status code. */
|
|
|
|
noreturn void exit(int status);
|
|
|
|
|
|
|
|
/* Not implemented. */
|
2022-10-01 18:59:22 +00:00
|
|
|
int atexit(void (*)(void));
|
2022-10-12 09:30:21 +00:00
|
|
|
|
|
|
|
/* Not implemented.*/
|
2022-10-01 18:59:22 +00:00
|
|
|
int atoi(const char*);
|
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
|