summaryrefslogtreecommitdiff
path: root/kernel/src/libk/string.c
blob: 8b2b2c6117ad20e935e1d0b03d7cf0baecfed3ee (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#include <types.h>
#include <libk/string.h>

size_t strlen(const char* s)
{
	if (s == NULL)
		return 0;

	char *p = (char*)s;
	while (*p) p++;
	return (size_t)(p - s);
}

uint64_t stoi(const char *s)
{
	uint64_t num = 0;
	size_t n = strlen(s);

	for (size_t i = 0; i < n; i++) {
		num *= 10;
		num += (uint64_t)(s[i] - '0');
	}

	return num;
}

void strrev(char *s)
{
	size_t n = strlen(s);
	char a[100];
	for (size_t i = 0; i < n; i++) {
		a[i] = s[n - 1 - i];
	}
	for (size_t i = 0; i < n; i++) {
		s[i] = a[i];
	}
}

void itos(uint64_t num, char* s)
{
	if (num == 0) {
		s[0] = '0';
		s[1] = '\0';
		return;
	}

	size_t i;
	for (i = 0; num; num /= 10, i++) {
		s[i] = (char)('0' + num % 10);
	}
	s[i] = '\0';
	strrev(s);
}

void itoh(uint64_t num, char* s)
{
	if (num == 0) {
		s[0] = '0';
		s[1] = '\0';
		return;
	}

	size_t i;
	for (i = 0; num; num /= 16, i++) {
		if (num % 16 < 10)
			s[i] = (char)('0' + num % 16);
		else
			s[i] = (char)('A' + num % 16 - 10);
	}
	s[i] = '\0';
	strrev(s);
}

void memcpy(const void* destptr, const void* srcptr, size_t n)
{
	if (destptr == NULL || srcptr == NULL)
		return;

	uint8_t* dest = (uint8_t*)destptr;
	const uint8_t* src = (const uint8_t*)srcptr;

	for(size_t i = 0; i < n; i++) {
		dest[i] = src[i];
	}
}

void memset(const void* destptr, uint8_t value, size_t n)
{
	uint8_t* dest = (uint8_t*)destptr;

	for (size_t i = 0; i < n; i++) {
		dest[i] = value;
	}
}

int32_t memcmp(const void* aptr, const void* bptr)
{
	const uint8_t* a = (const uint8_t*)aptr;
	const uint8_t* b = (const uint8_t*)bptr;

	const size_t len_a = strlen((char*)a);
	const size_t len_b = strlen((char*)b);

	for (size_t i = 0; i < len_a && i < len_b; i++) {
		if (a[i] != b[i])
			return a[i] - b[i];
	}

	if (len_a < len_b) {
		return -1;
	}
	if (len_a > len_b) {
		return 1;
	}
	return 0;
}