blob: 2b8cdfba637bd119c3e4e1502e63e924db7b4685 (
plain) (
blame)
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
|
#include <stddef.h>
size_t strlen(const char *str) {
size_t len = 0;
while (str[len])
len++;
return len;
}
size_t strcmp(const char *s1, const char *s2) {
while (*s1 && (*s1 == *s2)) {
s1++;
s2++;
}
return *(const unsigned char *) s1 - *(const unsigned char *) s2;
}
char *strcat(char *dst, const char *src) {
unsigned int i = 0;
unsigned int j = 0;
for (i = 0; dst[i] != 0; i++) {}
for (j = 0; src[j] != 0; j++) {
dst[i + j] = src[j];
}
dst[i + j] = 0;
return dst;
}
char *strcpy(char *dst, const char *src) {
unsigned int i = 0;
for (i = 0; src[i] != 0; i++) {
dst[i] = src[i];
}
dst[i] = 0;
return dst;
}
char *itoa(int i, char b[]) {
char const digit[] = "0123456789";
char *p = b;
if (i < 0) {
*p++ = '-';
i *= -1;
}
int shifter = i;
do {
++p;
shifter = shifter / 10;
} while (shifter);
*p = '\0';
do {
*--p = digit[i % 10];
i = i / 10;
} while (i);
return b;
}
|