2016-07-25 22:38:47 +02:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// standard library module: stdlib
|
|
|
|
//
|
|
|
|
// Provides standard functionalities such as dynamic allocation,
|
|
|
|
// string/numeric conversion, and abort calls.
|
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
#ifndef _STDLIB_H
|
|
|
|
#define _STDLIB_H 1
|
|
|
|
|
2016-08-02 07:51:44 +02:00
|
|
|
//---
|
|
|
|
// Common definitions.
|
|
|
|
//---
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
#include <stddef.h>
|
2016-08-02 07:51:44 +02:00
|
|
|
#include <limits.h>
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
// Common exit codes.
|
|
|
|
#define EXIT_SUCCESS 1
|
|
|
|
#define EXIT_FAILURE 0
|
|
|
|
|
2016-08-02 07:51:44 +02:00
|
|
|
// Number of atexit() registrations guaranteed.
|
|
|
|
#define ATEXIT_MAX 16
|
|
|
|
|
|
|
|
// Maximum value returned by rand().
|
|
|
|
#define RAND_MAX INT_MAX
|
|
|
|
|
|
|
|
// Integer division result.
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
int quot, rem;
|
|
|
|
} div_t;
|
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
long quot, rem;
|
|
|
|
} ldiv_t;
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Program exit functions.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
abort()
|
|
|
|
Aborts the program execution without calling the exit handlers.
|
|
|
|
*/
|
|
|
|
void abort(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
exit()
|
|
|
|
Stops the program execution with the given status code, after calling
|
|
|
|
the exit handlers.
|
|
|
|
*/
|
|
|
|
void exit(int status);
|
|
|
|
|
2016-08-02 07:51:44 +02:00
|
|
|
/*
|
|
|
|
atexit()
|
|
|
|
Registers a function to be called at normal program termination.
|
|
|
|
*/
|
|
|
|
int atexit(void (*function)(void));
|
|
|
|
|
2016-05-20 22:04:15 +02:00
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Dynamic storage allocation.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
malloc()
|
2016-07-14 21:10:51 +02:00
|
|
|
Allocates 'size' bytes and returns a pointer to a free memory area.
|
2016-05-20 22:04:15 +02:00
|
|
|
Returns NULL on error.
|
|
|
|
*/
|
|
|
|
void *malloc(size_t size);
|
|
|
|
|
|
|
|
/*
|
|
|
|
calloc()
|
2016-07-14 21:10:51 +02:00
|
|
|
Allocates 'n' elements of size 'size' and wipes the memory area.
|
|
|
|
Returns NULL on error.
|
2016-05-20 22:04:15 +02:00
|
|
|
*/
|
|
|
|
void *calloc(size_t n, size_t size);
|
|
|
|
|
2016-08-02 07:51:44 +02:00
|
|
|
/*
|
|
|
|
realloc()
|
|
|
|
Reallocates a memory block and moves its data.
|
|
|
|
*/
|
|
|
|
void *realloc(void *ptr, size_t size);
|
|
|
|
|
2016-05-20 22:04:15 +02:00
|
|
|
/*
|
|
|
|
free()
|
2016-08-02 07:51:44 +02:00
|
|
|
Frees a memory block allocated by malloc(), calloc() or realloc().
|
2016-05-20 22:04:15 +02:00
|
|
|
*/
|
|
|
|
void free(void *ptr);
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-08-02 07:51:44 +02:00
|
|
|
//---
|
|
|
|
// Random number generation.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
2016-08-14 19:57:58 +02:00
|
|
|
rand()
|
|
|
|
Returns a pseudo-random number.
|
2016-08-02 07:51:44 +02:00
|
|
|
*/
|
2016-08-14 19:57:58 +02:00
|
|
|
int rand(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
srand()
|
|
|
|
Changes the seed used by rand().
|
|
|
|
*/
|
|
|
|
void srand(unsigned int seed);
|
2016-08-02 07:51:44 +02:00
|
|
|
|
2016-07-28 18:12:07 +02:00
|
|
|
//---
|
|
|
|
// Integer arithmetic.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
abs()
|
|
|
|
Returns the absolute value of an integer.
|
|
|
|
*/
|
|
|
|
int abs(int x);
|
|
|
|
// Use a macro instead, when possible.
|
2016-08-02 07:51:44 +02:00
|
|
|
#define abs(x) ((x) < 0 ? -(x) : (x))
|
|
|
|
|
|
|
|
/*
|
|
|
|
labs()
|
|
|
|
Returns the absolute value of a long integer.
|
|
|
|
*/
|
|
|
|
long labs(long x);
|
|
|
|
// Use a macro instead.
|
|
|
|
#define labs(x) ((x) < 0 ? -(x) : (x))
|
2016-07-28 18:12:07 +02:00
|
|
|
|
2016-08-02 07:51:44 +02:00
|
|
|
/*
|
|
|
|
div()
|
|
|
|
Computes the integer division of numerator by denominator.
|
|
|
|
*/
|
|
|
|
div_t div(int numerator, int denominator);
|
2016-07-28 18:12:07 +02:00
|
|
|
|
2016-08-02 07:51:44 +02:00
|
|
|
/*
|
|
|
|
ldiv()
|
|
|
|
Computes the integer division of two long integers.
|
|
|
|
*/
|
|
|
|
ldiv_t ldiv(long numerator, long denominator);
|
2016-07-28 18:12:07 +02:00
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
#endif // _STDLIB_H
|