rulimine/stage23/lib/libc.s2.c

153 lines
2.9 KiB
C
Raw Normal View History

2019-05-31 07:23:23 +03:00
#include <stddef.h>
#include <stdint.h>
#include <lib/libc.h>
2020-11-05 03:37:45 +03:00
#include <stdbool.h>
#include <lib/blib.h>
2019-05-31 07:23:23 +03:00
2020-06-11 13:13:27 +03:00
int toupper(int c) {
if (c >= 'a' && c <= 'z') {
return c - 0x20;
}
return c;
}
int tolower(int c) {
if (c >= 'A' && c <= 'Z') {
return c + 0x20;
}
return c;
}
2021-03-02 12:23:43 +03:00
void *memcpy(void *dest, const void *src, size_t n) {
uint8_t *pdest = dest;
const uint8_t *psrc = src;
for (size_t i = 0; i < n; i++) {
pdest[i] = psrc[i];
}
return dest;
}
void *memset(void *s, int c, size_t n) {
uint8_t *p = s;
for (size_t i = 0; i < n; i++) {
p[i] = (uint8_t)c;
}
return s;
}
void *memmove(void *dest, const void *src, size_t n) {
uint8_t *pdest = dest;
const uint8_t *psrc = src;
if (src > dest) {
for (size_t i = 0; i < n; i++) {
pdest[i] = psrc[i];
}
} else if (src < dest) {
for (size_t i = n; i > 0; i--) {
pdest[i-1] = psrc[i-1];
}
}
return dest;
}
int memcmp(const void *s1, const void *s2, size_t n) {
const uint8_t *p1 = s1;
const uint8_t *p2 = s2;
for (size_t i = 0; i < n; i++) {
if (p1[i] != p2[i])
return p1[i] < p2[i] ? -1 : 1;
}
return 0;
}
2019-05-31 07:23:23 +03:00
char *strcpy(char *dest, const char *src) {
size_t i;
2019-05-31 07:23:23 +03:00
for (i = 0; src[i]; i++)
dest[i] = src[i];
dest[i] = 0;
return dest;
}
char *strncpy(char *dest, const char *src, size_t n) {
size_t i;
2019-05-31 07:23:23 +03:00
for (i = 0; i < n && src[i]; i++)
2019-05-31 07:23:23 +03:00
dest[i] = src[i];
for ( ; i < n; i++)
dest[i] = 0;
2019-05-31 07:23:23 +03:00
return dest;
}
int strcmp(const char *s1, const char *s2) {
for (size_t i = 0; ; i++) {
char c1 = s1[i], c2 = s2[i];
if (c1 != c2)
return c1 < c2 ? -1 : 1;
if (!c1)
return 0;
2019-05-31 07:23:23 +03:00
}
}
int strcasecmp(const char *s1, const char *s2) {
for (size_t i = 0; ; i++) {
char c1 = s1[i], c2 = s2[i];
if (tolower(c1) != tolower(c2))
return c1 < c2 ? -1 : 1;
if (!c1)
return 0;
}
}
int strncmp(const char *s1, const char *s2, size_t n) {
for (size_t i = 0; i < n; i++) {
char c1 = s1[i], c2 = s2[i];
if (c1 != c2)
return c1 < c2 ? -1 : 1;
if (!c1)
return 0;
}
2019-05-31 07:23:23 +03:00
return 0;
}
size_t strlen(const char *str) {
size_t len;
for (len = 0; str[len]; len++);
return len;
}
2020-11-05 03:37:45 +03:00
int inet_pton(const char *src, void *dst) {
uint8_t array[4];
2020-11-05 03:37:45 +03:00
const char *current = src;
for (int i = 0; i < 4; i++) {
const char *newcur;
uint64_t value = strtoui(current, &newcur, 10);
if (current == newcur)
return -1;
current = newcur;
if (*current == 0 && i < 3)
return -1;
if (value > 255)
return -1;
current++;
array[i] = value;
2020-11-05 03:37:45 +03:00
}
memcpy(dst, array, 4);
return 0;
}