summaryrefslogtreecommitdiff
path: root/src/libc/include/unistd.h
blob: 750d6e290478ab53615107f7b5f41cdfca493d7f (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
#pragma once
#include <camellia/types.h> // TODO only needed because of hid_t
#include <sys/types.h>
#include <getopt.h>

// TODO custom stdint.h, ssize_t doesn't belong here
typedef long long ssize_t;

extern char **environ;

int fork(void);
pid_t vfork(void);
int close(hid_t h);
_Noreturn void _exit(int);

ssize_t readlink(const char *restrict path, char *restrict buf, size_t bufsize);
int link(const char *path1, const char *path2);
int unlink(const char *path);
int rmdir(const char *path);
int symlink(const char *path1, const char *path2);
int isatty(int fd);

int execv(const char *path, char *const argv[]);
int execvp(const char *path, char *const argv[]);
int execvpe(const char *path, char *const argv[], char *const envp[]);
int execve(const char *path, char *const argv[], char *const envp[]);

int chdir(const char *path);
char *getcwd(char *buf, size_t size);

uid_t getuid(void);
uid_t geteuid(void);
gid_t getgid(void);
gid_t getegid(void);

int access(const char *path, int mode);
int chown(const char *path, uid_t owner, gid_t group);

int setpgid(pid_t pid, pid_t pgid);
pid_t tcgetpgrp(int fd);
int tcsetpgrp(int fd, pid_t pgrp);
pid_t getpgrp(void);
pid_t getpid(void);
pid_t getppid(void);

int getgroups(int size, gid_t list[]);

ssize_t read(int fd, void *buf, size_t count);
ssize_t write(int fd, const void *buf, size_t count);
int pipe(int pipefd[2]);
int dup(int oldfd);
int dup2(int oldfd, int newfd);

unsigned int sleep(unsigned int seconds);

/* Converts a relative path to an absolute one, simplifying it if possible.
 * If in == NULL - return the length of cwd. Doesn't include the trailing slash,
 *                 except for the root dir. Includes the null byte.
 * If size isn't enough to fit the path, returns the amount of bytes needed to fit
 * it, including the null byte.
 *
 * Note that some errors are only detected if *out != NULL, so you must check the return
 * value twice.
 * @return 0 on failure, length of the path otherwise */
size_t absolutepath(char *out, const char *in, size_t size);

// TODO put in an internal libc header
void __setinitialcwd(const char *c);

void intr_set(void (*fn)(void));
void intr_default(void);