xv6-65oo2/user/ulib.c

148 lines
1.8 KiB
C
Raw Permalink Normal View History

#include "kernel/types.h"
#include "kernel/stat.h"
#include "kernel/fcntl.h"
#include "user/user.h"
//
// wrapper so that it's OK if main() does not call exit().
//
void
_main()
{
extern int main();
main();
exit(0);
}
2006-07-16 16:00:03 +00:00
char*
2018-08-31 13:21:19 +00:00
strcpy(char *s, const char *t)
2006-07-16 16:00:03 +00:00
{
char *os;
2006-09-06 17:27:19 +00:00
os = s;
while((*s++ = *t++) != 0)
;
return os;
2006-07-16 16:00:03 +00:00
}
int
strcmp(const char *p, const char *q)
{
2006-09-06 17:27:19 +00:00
while(*p && *p == *q)
p++, q++;
return (uchar)*p - (uchar)*q;
}
uint
2018-08-31 13:21:19 +00:00
strlen(const char *s)
{
2007-08-10 17:17:42 +00:00
int n;
for(n = 0; s[n]; n++)
;
return n;
}
void*
memset(void *dst, int c, uint n)
{
2019-05-31 15:45:42 +00:00
char *cdst = (char *) dst;
int i;
for(i = 0; i < n; i++){
cdst[i] = c;
}
return dst;
}
char*
strchr(const char *s, char c)
{
2006-09-06 17:27:19 +00:00
for(; *s; s++)
if(*s == c)
return (char*)s;
return 0;
}
char*
gets(char *buf, int max)
{
2007-08-10 17:17:42 +00:00
int i, cc;
char c;
2006-09-06 17:27:19 +00:00
2007-08-10 17:17:42 +00:00
for(i=0; i+1 < max; ){
cc = read(0, &c, 1);
if(cc < 1)
break;
buf[i++] = c;
if(c == '\n' || c == '\r')
break;
}
buf[i] = '\0';
return buf;
}
2006-08-14 03:00:13 +00:00
int
2018-08-31 13:21:19 +00:00
stat(const char *n, struct stat *st)
2006-08-14 03:00:13 +00:00
{
int fd;
2006-08-14 03:00:13 +00:00
int r;
fd = open(n, O_RDONLY);
2006-09-06 17:57:47 +00:00
if(fd < 0)
return -1;
2006-08-14 03:00:13 +00:00
r = fstat(fd, st);
close(fd);
return r;
}
2007-08-08 08:56:09 +00:00
int
atoi(const char *s)
{
int n;
n = 0;
while('0' <= *s && *s <= '9')
n = n*10 + *s++ - '0';
return n;
}
void*
2018-08-31 13:21:19 +00:00
memmove(void *vdst, const void *vsrc, int n)
{
2018-08-31 13:21:19 +00:00
char *dst;
const char *src;
dst = vdst;
src = vsrc;
if (src > dst) {
while(n-- > 0)
*dst++ = *src++;
} else {
dst += n;
src += n;
while(n-- > 0)
*--dst = *--src;
}
return vdst;
}
int
memcmp(const void *s1, const void *s2, uint n)
{
const char *p1 = s1, *p2 = s2;
while (n-- > 0) {
if (*p1 != *p2) {
return *p1 - *p2;
}
p1++;
p2++;
}
return 0;
}
void *
memcpy(void *dst, const void *src, uint n)
{
return memmove(dst, src, n);
}