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
|
#include <kstd/cstring>
#include <algorithm>
#include <bit>
#include <cstddef>
#include <iterator>
#include <span>
namespace kstd::libc
{
auto memcpy(void * dest, void const * src, std::size_t size) -> void *
{
auto dest_span = std::span{static_cast<std::byte *>(dest), size};
auto src_span = std::span{static_cast<std::byte const *>(src), size};
for (std::size_t i = 0; i < size; ++i)
{
dest_span[i] = src_span[i];
}
return dest;
}
auto memset(void * dest, int value, std::size_t size) -> void *
{
auto const byte_value = static_cast<std::byte>(static_cast<unsigned char>(value));
auto dest_span = std::span{static_cast<std::byte *>(dest), size};
for (std::size_t i = 0; i < size; ++i)
{
dest_span[i] = byte_value;
}
return dest;
}
auto memcmp(void const * lhs, void const * rhs, std::size_t size) -> std::size_t
{
auto left_span = std::span{static_cast<std::byte const *>(lhs), size};
auto right_span = std::span{static_cast<std::byte const *>(rhs), size};
auto mismatched = std::ranges::mismatch(left_span, right_span);
if (mismatched.in1 == left_span.end())
{
return 0;
}
return std::bit_cast<char>(*mismatched.in1) - std::bit_cast<char>(*mismatched.in2);
}
auto memmove(void * dest, void const * src, std::size_t size) -> void *
{
auto dest_span = std::span{static_cast<std::byte *>(dest), size};
auto src_span = std::span{static_cast<std::byte const *>(src), size};
if (dest < src)
{
for (std::size_t i = 0; i < size; ++i)
{
dest_span[i] = src_span[i];
}
}
else
{
for (std::size_t i = size; i > 0; --i)
{
dest_span[i - 1] = src_span[i - 1];
}
}
return dest;
}
auto strlen(char const * string) -> std::size_t
{
return std::distance(string, std::ranges::find(string, nullptr, '\0'));
}
} // namespace kstd::libc
|