2016-07-25 22:38:47 +02:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// standard library module: string
|
|
|
|
//
|
|
|
|
// String manipulation using NUL-terminated byte arrays, without extended
|
|
|
|
// characters.
|
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
#ifndef _STRING_H
|
2017-03-26 18:38:32 +02:00
|
|
|
#define _STRING_H
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
#include <stddef.h>
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Memory manipulation.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
2017-01-22 18:35:02 +01:00
|
|
|
memcpy() O(byte_count)
|
2016-05-05 11:49:05 +02:00
|
|
|
Copies a memory area. The two areas must not overlap (if they do, use
|
|
|
|
memmove()). A smart copy is performed when possible. To enhance
|
|
|
|
performance, make sure than destination and source are both 4-aligned.
|
|
|
|
*/
|
2017-01-22 18:35:02 +01:00
|
|
|
void *memcpy(void *destination, const void *source, size_t byte_count);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
/*
|
2017-01-22 18:35:02 +01:00
|
|
|
memset() O(byte_count)
|
2016-05-05 11:49:05 +02:00
|
|
|
Sets the contents of a memory area. A smart copy is performed.
|
|
|
|
*/
|
2017-01-22 18:35:02 +01:00
|
|
|
void *memset(void *destination, int byte, size_t byte_count);
|
|
|
|
|
|
|
|
/*
|
|
|
|
memchr() O(byte_count)
|
|
|
|
Looks for a byte in a memory area. Returns the address of the first
|
|
|
|
occurrence if found, NULL otherwise.
|
|
|
|
*/
|
|
|
|
void *memchr(const void *area, int byte, size_t byte_count);
|
|
|
|
|
|
|
|
/*
|
|
|
|
memcmp() O(byte_count)
|
|
|
|
Compares two memory areas. Returns 0 if all bytes are equal in both
|
|
|
|
areas, a negative number if the first unequal byte is lower in the
|
|
|
|
first area, and a positive number otherwise.
|
|
|
|
A smart comparison is performed when possible.
|
|
|
|
*/
|
|
|
|
int memcmp(const void *area1, const void *area2, size_t byte_count);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2016-07-25 09:04:22 +02:00
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// String manipulation.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
2016-07-25 22:38:47 +02:00
|
|
|
strlen() O(len(str))
|
2016-07-25 09:04:22 +02:00
|
|
|
Returns the length of a string.
|
|
|
|
*/
|
|
|
|
size_t strlen(const char *str);
|
|
|
|
|
2017-01-22 18:35:02 +01:00
|
|
|
/*
|
|
|
|
strnlen() O(len(str))
|
|
|
|
Returns the minimum of the length of the string and n. This function
|
|
|
|
never access more than n bytes at the beginning of the string.
|
|
|
|
*/
|
|
|
|
size_t strnlen(const char *str, size_t n);
|
|
|
|
|
2016-07-25 22:38:47 +02:00
|
|
|
/*
|
|
|
|
strcpy() O(len(source))
|
|
|
|
Copies a string to another.
|
|
|
|
*/
|
|
|
|
char *strcpy(char *destination, const char *source);
|
|
|
|
|
2017-01-22 18:35:02 +01:00
|
|
|
/*
|
|
|
|
strncpy() O(min(len(source), size))
|
|
|
|
Copies part of a string to another.
|
|
|
|
*/
|
|
|
|
char *strncpy(char *destination, const char *source, size_t size);
|
|
|
|
|
2016-07-25 22:38:47 +02:00
|
|
|
/*
|
|
|
|
strchr() O(len(str))
|
|
|
|
Searches a character in a string.
|
|
|
|
*/
|
|
|
|
const char *strchr(const char *str, int value);
|
|
|
|
|
|
|
|
/*
|
2017-01-22 18:35:02 +01:00
|
|
|
strcmp() O(max(len(str1), len(str2)))
|
|
|
|
Compares two strings. Returns 0 if they are identical, a negative
|
|
|
|
number if the first unequal byte is lower in str1 than in str2, and a
|
|
|
|
positive number otherwise.
|
2016-07-25 22:38:47 +02:00
|
|
|
*/
|
2017-01-22 18:35:02 +01:00
|
|
|
int strcmp(const char *str1, const char *str2);
|
2016-07-25 22:38:47 +02:00
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
#endif // _STRING_H
|