blob: 9c90a2df4a34f2602189ba818d5a129d8b03ce98 [file] [log] [blame]
landley4f344e32006-10-05 16:18:03 -04001/* vi: set ts=4 :*/
landley09ea7ac2006-10-30 01:38:00 -05002/* lib.h - header file for lib directory
3 *
4 * Copyright 2006 Rob Landley <rob@landley.net>
5 */
landley4f344e32006-10-05 16:18:03 -04006
Rob Landleyf01503d2012-02-02 07:26:39 -06007// Unfortunately, sizeof() doesn't work in a preprocessor test. TODO.
8
9//#if sizeof(double) <= sizeof(long)
10//typedef double FLOAT;
11//#else
12typedef float FLOAT;
13//#endif
14
Rob Landley1521a9e2006-11-25 16:06:55 -050015// libc generally has this, but the headers are screwed up
16ssize_t getline(char **lineptr, size_t *n, FILE *stream);
17
Rob Landley0a04b3e2006-11-03 00:05:52 -050018// llist.c
Rob Landley0a04b3e2006-11-03 00:05:52 -050019
Rob Landleyeb7ea222012-04-14 22:30:41 -050020// All these list types can be handled by the same code because first element
21// is always next pointer, so next = (mytype *)&struct.
22
Rob Landley0a04b3e2006-11-03 00:05:52 -050023struct string_list {
24 struct string_list *next;
25 char str[0];
26};
27
Rob Landley8324b892006-11-19 02:49:22 -050028struct arg_list {
29 struct arg_list *next;
30 char *arg;
31};
32
Rob Landleybc078652007-12-15 21:47:25 -060033struct double_list {
Rob Landleyeb7ea222012-04-14 22:30:41 -050034 struct double_list *next, *prev;
Rob Landleybc078652007-12-15 21:47:25 -060035 char *data;
36};
37
Rob Landley9e2b6db2012-07-15 17:22:04 -050038void llist_traverse(void *list, void (*using)(void *data));
Rob Landley6ef04ef2008-01-20 17:34:53 -060039void *llist_pop(void *list); // actually void **list, but the compiler's dumb
Rob Landley2c482472012-03-12 00:25:40 -050040void dlist_add_nomalloc(struct double_list **list, struct double_list *new);
Rob Landleybdf037f2008-10-23 16:44:30 -050041struct double_list *dlist_add(struct double_list **list, char *data);
Rob Landley6ef04ef2008-01-20 17:34:53 -060042
Rob Landley103b7e02007-10-04 02:04:10 -050043// args.c
44void get_optflags(void);
45
46// dirtree.c
Rob Landleyeb7ea222012-04-14 22:30:41 -050047
48// Values returnable from callback function (bitfield, or them together)
49// Default with no callback is 0
50
Rob Landley8c4ae8a2012-05-20 15:00:19 -050051// Add this node to the tree
52#define DIRTREE_SAVE 1
53// Recurse into children
54#define DIRTREE_RECURSE 2
55// Call again after handling all children of this directory
56// (Ignored for non-directories, sets linklen = -1 before second call.)
Rob Landleyeb7ea222012-04-14 22:30:41 -050057#define DIRTREE_COMEAGAIN 4
58// Follow symlinks to directories
59#define DIRTREE_SYMFOLLOW 8
Rob Landley8c4ae8a2012-05-20 15:00:19 -050060// Don't look at any more files in this directory.
61#define DIRTREE_ABORT 256
Rob Landleyeb7ea222012-04-14 22:30:41 -050062
63#define DIRTREE_ABORTVAL ((struct dirtree *)1)
64
Rob Landleyd25f7e42007-02-03 14:11:26 -050065struct dirtree {
Rob Landleyeb7ea222012-04-14 22:30:41 -050066 struct dirtree *next, *parent, *child;
67 long extra; // place for user to store their stuff (can be pointer)
Rob Landleyd25f7e42007-02-03 14:11:26 -050068 struct stat st;
Rob Landleyeb7ea222012-04-14 22:30:41 -050069 char *symlink;
Rob Landley2037b832012-07-15 16:56:20 -050070 int data; // dirfd for directory, linklen for symlink, -1 = comeagain
Rob Landleyd25f7e42007-02-03 14:11:26 -050071 char name[];
72};
73
Rob Landley4af1e1d2012-06-09 22:25:49 -050074struct dirtree *dirtree_add_node(int dirfd, char *name, int symfollow);
Rob Landleyeb7ea222012-04-14 22:30:41 -050075char *dirtree_path(struct dirtree *node, int *plen);
Rob Landley8c4ae8a2012-05-20 15:00:19 -050076int dirtree_notdotdot(struct dirtree *catch);
Rob Landley6ec21782012-06-16 15:16:08 -050077int dirtree_parentfd(struct dirtree *node);
Rob Landleyeb7ea222012-04-14 22:30:41 -050078struct dirtree *handle_callback(struct dirtree *new,
79 int (*callback)(struct dirtree *node));
80void dirtree_recurse(struct dirtree *node,
Rob Landley4af1e1d2012-06-09 22:25:49 -050081 int (*callback)(struct dirtree *node), int symfollow);
Rob Landleyeb7ea222012-04-14 22:30:41 -050082struct dirtree *dirtree_read(char *path, int (*callback)(struct dirtree *node));
Rob Landley8324b892006-11-19 02:49:22 -050083
Rob Landley103b7e02007-10-04 02:04:10 -050084// lib.c
Rob Landleye15850a2007-11-19 01:51:00 -060085void xstrcpy(char *dest, char *src, size_t size);
landley09ea7ac2006-10-30 01:38:00 -050086void verror_msg(char *msg, int err, va_list va);
87void error_msg(char *msg, ...);
88void perror_msg(char *msg, ...);
Rob Landleyefa93b92007-11-15 21:12:24 -060089void error_exit(char *msg, ...) noreturn;
90void perror_exit(char *msg, ...) noreturn;
landley4f344e32006-10-05 16:18:03 -040091void *xmalloc(size_t size);
landleycd9dfc32006-10-18 18:38:16 -040092void *xzalloc(size_t size);
Rob Landley0c93f6c2007-04-29 19:55:21 -040093void *xrealloc(void *ptr, size_t size);
Rob Landley1e01cd12010-01-05 10:48:32 -060094char *xstrndup(char *s, size_t n);
95char *xstrdup(char *s);
landley00f87f12006-10-25 18:38:37 -040096char *xmsprintf(char *format, ...);
Rob Landley24d1d452007-01-20 18:04:20 -050097void xprintf(char *format, ...);
Rob Landley5084fea2007-06-18 00:14:03 -040098void xputs(char *s);
Rob Landley24d1d452007-01-20 18:04:20 -050099void xputc(char c);
100void xflush(void);
landley09ea7ac2006-10-30 01:38:00 -0500101void xexec(char **argv);
Rob Landleyd3e9d642007-01-08 03:25:47 -0500102void xaccess(char *path, int flags);
Rob Landleye745d8e2007-12-20 06:30:19 -0600103void xunlink(char *path);
Rob Landley1322beb2007-01-07 22:51:12 -0500104int xcreate(char *path, int flags, int mode);
105int xopen(char *path, int flags);
Rob Landleybc078652007-12-15 21:47:25 -0600106void xclose(int fd);
Rob Landleyeb7ea222012-04-14 22:30:41 -0500107int xdup(int fd);
landley4f344e32006-10-05 16:18:03 -0400108FILE *xfopen(char *path, char *mode);
Rob Landley90163772007-01-18 21:54:08 -0500109ssize_t readall(int fd, void *buf, size_t len);
110ssize_t writeall(int fd, void *buf, size_t len);
111size_t xread(int fd, void *buf, size_t len);
112void xreadall(int fd, void *buf, size_t len);
113void xwrite(int fd, void *buf, size_t len);
Rob Landley52476712009-01-18 16:19:25 -0600114off_t xlseek(int fd, off_t offset, int whence);
Rob Landley2037b832012-07-15 16:56:20 -0500115off_t lskip(int fd, off_t offset);
Rob Landleye824ed12008-07-18 08:43:18 -0500116char *readfile(char *name);
117char *xreadfile(char *name);
landley00f87f12006-10-25 18:38:37 -0400118char *xgetcwd(void);
Rob Landleyd25f7e42007-02-03 14:11:26 -0500119void xstat(char *path, struct stat *st);
Rob Landleyfa98d012006-11-02 02:57:27 -0500120char *xabspath(char *path);
Rob Landleyeec46372012-06-01 13:50:41 -0500121char *xrealpath(char *path);
Rob Landley988abb32008-05-12 00:52:27 -0500122void xchdir(char *path);
Rob Landley35483412007-12-27 21:36:33 -0600123void xmkpath(char *path, int mode);
Rob Landleye0377fb2010-01-05 12:17:05 -0600124void xsetuid(uid_t uid);
Rob Landley0a04b3e2006-11-03 00:05:52 -0500125struct string_list *find_in_path(char *path, char *filename);
landley09ea7ac2006-10-30 01:38:00 -0500126void utoa_to_buf(unsigned n, char *buf, unsigned buflen);
127void itoa_to_buf(int n, char *buf, unsigned buflen);
128char *utoa(unsigned n);
129char *itoa(int n);
Rob Landleyf5757162007-02-16 21:08:22 -0500130long atolx(char *c);
Rob Landleyeb7ea222012-04-14 22:30:41 -0500131int numlen(long l);
Rob Landley2037b832012-07-15 16:56:20 -0500132int stridx(char *haystack, char needle);
Rob Landleye2580db2007-01-23 13:20:38 -0500133off_t fdlength(int fd);
Rob Landley0c93f6c2007-04-29 19:55:21 -0400134char *xreadlink(char *name);
Rob Landleyad63f4b2011-12-12 15:19:52 -0600135void loopfiles_rw(char **argv, int flags, int permissions, int failok,
136 void (*function)(int fd, char *name));
Rob Landley7634b552007-11-29 17:49:50 -0600137void loopfiles(char **argv, void (*function)(int fd, char *name));
Rob Landley3fc4e0f2008-04-13 00:29:00 -0500138char *get_rawline(int fd, long *plen, char end);
Rob Landleybc078652007-12-15 21:47:25 -0600139char *get_line(int fd);
140void xsendfile(int in, int out);
Rob Landley67a069d2012-06-03 00:32:12 -0500141int wfchmodat(int rc, char *name, mode_t mode);
Rob Landley42ecbab2007-12-18 02:02:21 -0600142int copy_tempfile(int fdin, char *name, char **tempname);
143void delete_tempfile(int fdin, int fdout, char **tempname);
144void replace_tempfile(int fdin, int fdout, char **tempname);
Rob Landleyb15b8fa2009-01-05 01:05:43 -0600145void crc_init(unsigned int *crc_table, int little_endian);
Rob Landley26e7b5e2012-02-02 07:27:35 -0600146void terminal_size(unsigned *x, unsigned *y);
Rob Landleyf793d532012-02-27 21:56:49 -0600147int yesno(char *prompt, int def);
Rob Landleyebcf0be2012-02-18 18:53:57 -0600148void for_each_pid_with_name_in(char **names, void (*callback)(pid_t pid));
Rob Landley26e7b5e2012-02-02 07:27:35 -0600149
landley4f344e32006-10-05 16:18:03 -0400150
landleycd9dfc32006-10-18 18:38:16 -0400151// getmountlist.c
landley4f344e32006-10-05 16:18:03 -0400152struct mtab_list {
153 struct mtab_list *next;
landley09ea7ac2006-10-30 01:38:00 -0500154 struct stat stat;
155 struct statvfs statvfs;
landley4f344e32006-10-05 16:18:03 -0400156 char *dir;
157 char *device;
158 char type[0];
159};
160
161struct mtab_list *getmountlist(int die);
162
Rob Landley6000f132007-01-18 22:00:12 -0500163void bunzipStream(int src_fd, int dst_fd);
Rob Landley2dd50ad2012-02-26 13:48:00 -0600164
165// signal
166
Rob Landleyc52db602012-07-30 01:01:33 -0500167void sigatexit(void *handler);
Rob Landley2dd50ad2012-02-26 13:48:00 -0600168int sig_to_num(char *pidstr);
169char *num_to_sig(int sig);
Daniel Walter05744b32012-03-19 19:57:56 -0500170
171mode_t string_to_mode(char *mode_str, mode_t base);
Rob Landley2c917f52012-07-17 08:54:47 -0500172
173// password helper functions
Rob Landley6ba38c22012-07-21 18:38:36 -0500174int read_password(char * buff, int buflen, char* mesg);
175int update_password(char *filename, char* username, char* encrypted);
Rob Landley2c917f52012-07-17 08:54:47 -0500176