c83cb7e7c0051fef183603f651a3e7d5aab3a3ec
[oweals/busybox.git] / include / libbb.h
1 /* vi: set sw=4 ts=4: */
2 /*
3  * Busybox main internal header file
4  *
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14  * General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with this program; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19  *
20  * Based in part on code from sash, Copyright (c) 1999 by David I. Bell 
21  * Permission has been granted to redistribute this code under the GPL.
22  *
23  */
24 #ifndef __LIBBB_H__
25 #define __LIBBB_H__    1
26
27 #include <stdio.h>
28 #include <stdarg.h>
29 #include <sys/stat.h>
30 #include <sys/types.h>
31
32 #include <netdb.h>
33
34 #ifdef DMALLOC
35 #include "dmalloc.h"
36 #endif
37
38 #include <features.h>
39
40 #ifndef _BB_INTERNAL_H_
41 #include "../busybox.h"
42 #endif
43
44 #if __GNU_LIBRARY__ < 5
45 /* libc5 doesn't define socklen_t */
46 typedef unsigned int socklen_t;
47 /* libc5 doesn't implement BSD 4.4 daemon() */
48 extern int daemon (int nochdir, int noclose);
49 #endif  
50
51 /* Some useful definitions */
52 #define FALSE   ((int) 0)
53 #define TRUE    ((int) 1)
54 #define SKIP    ((int) 2)
55
56 /* for mtab.c */
57 #define MTAB_GETMOUNTPT '1'
58 #define MTAB_GETDEVICE  '2'
59
60 #define BUF_SIZE        8192
61 #define EXPAND_ALLOC    1024
62
63 static inline int is_decimal(int ch) { return ((ch >= '0') && (ch <= '9')); }
64 static inline int is_octal(int ch)   { return ((ch >= '0') && (ch <= '7')); }
65
66 /* Macros for min/max.  */
67 #ifndef MIN
68 #define MIN(a,b) (((a)<(b))?(a):(b))
69 #endif
70
71 #ifndef MAX
72 #define MAX(a,b) (((a)>(b))?(a):(b))
73 #endif
74
75
76
77 extern void show_usage(void) __attribute__ ((noreturn));
78 extern void error_msg(const char *s, ...) __attribute__ ((format (printf, 1, 2)));
79 extern void error_msg_and_die(const char *s, ...) __attribute__ ((noreturn, format (printf, 1, 2)));
80 extern void perror_msg(const char *s, ...);
81 extern void perror_msg_and_die(const char *s, ...) __attribute__ ((noreturn));
82 extern void vherror_msg(const char *s, va_list p);
83 extern void herror_msg(const char *s, ...);
84 extern void herror_msg_and_die(const char *s, ...) __attribute__ ((noreturn));
85
86 /* These two are used internally -- you shouldn't need to use them */
87 extern void verror_msg(const char *s, va_list p);
88 extern void vperror_msg(const char *s, va_list p);
89
90 const char *mode_string(int mode);
91 const char *time_string(time_t timeVal);
92 int is_directory(const char *name, int followLinks, struct stat *statBuf);
93 int isDevice(const char *name);
94
95 int remove_file(const char *path, int flags);
96 int copy_file(const char *source, const char *dest, int flags);
97 int copy_file_chunk(FILE *src_file, FILE *dst_file, unsigned long long chunksize);
98 char *buildName(const char *dirName, const char *fileName);
99 int makeString(int argc, const char **argv, char *buf, int bufLen);
100 char *getChunk(int size);
101 char *chunkstrdup(const char *str);
102 void freeChunks(void);
103 ssize_t safe_read(int fd, void *buf, size_t count);
104 int full_write(int fd, const char *buf, int len);
105 int full_read(int fd, char *buf, int len);
106 int recursive_action(const char *fileName, int recurse, int followLinks, int depthFirst,
107           int (*fileAction) (const char *fileName, struct stat* statbuf, void* userData),
108           int (*dirAction) (const char *fileName, struct stat* statbuf, void* userData),
109           void* userData);
110
111 extern int create_path (const char *name, int mode);
112 extern int parse_mode( const char* s, mode_t* theMode);
113
114 extern int get_kernel_revision(void);
115
116 extern int get_console_fd(char* tty_name);
117 extern struct mntent *find_mount_point(const char *name, const char *table);
118 extern void write_mtab(char* blockDevice, char* directory, 
119         char* filesystemType, long flags, char* string_flags);
120 extern void erase_mtab(const char * name);
121 extern long atoi_w_units (const char *cp);
122 extern pid_t* find_pid_by_name( char* pidName);
123 extern char *find_real_root_device_name(const char* name);
124 extern char *get_line_from_file(FILE *file);
125 extern void print_file(FILE *file);
126 extern int copyfd(int fd1, int fd2);
127 extern int print_file_by_name(char *filename);
128 extern char process_escape_sequence(const char **ptr);
129 extern char *get_last_path_component(char *path);
130 extern FILE *wfopen(const char *path, const char *mode);
131 extern FILE *xfopen(const char *path, const char *mode);
132 extern void chomp(char *s);
133 extern void trim(char *s);
134 extern struct BB_applet *find_applet_by_name(const char *name);
135 void run_applet_by_name(const char *name, int argc, char **argv);
136
137 #ifndef DMALLOC
138 extern void *xmalloc (size_t size);
139 extern void *xrealloc(void *old, size_t size);
140 extern void *xcalloc(size_t nmemb, size_t size);
141 extern char *xstrdup (const char *s);
142 #endif
143 extern char *xstrndup (const char *s, int n);
144 extern char * safe_strncpy(char *dst, const char *src, size_t size);
145
146 struct suffix_mult {
147         const char *suffix;
148         int mult;
149 };
150
151 extern unsigned long parse_number(const char *numstr,
152                 const struct suffix_mult *suffixes);
153
154
155 /* These parse entries in /etc/passwd and /etc/group.  This is desirable
156  * for BusyBox since we want to avoid using the glibc NSS stuff, which
157  * increases target size and is often not needed embedded systems.  */
158 extern long my_getpwnam(const char *name);
159 extern long my_getgrnam(const char *name);
160 extern void my_getpwuid(char *name, long uid);
161 extern void my_getgrgid(char *group, long gid);
162 extern long my_getpwnamegid(const char *name);
163
164 extern int device_open(char *device, int mode);
165
166 extern int del_loop(const char *device);
167 extern int set_loop(const char *device, const char *file, int offset, int *loopro);
168 extern char *find_unused_loop_device (void);
169
170
171 #if (__GLIBC__ < 2)
172 extern int vdprintf(int d, const char *format, va_list ap);
173 #endif
174
175 int nfsmount(const char *spec, const char *node, int *flags,
176              char **extra_opts, char **mount_opts, int running_bg);
177
178 void syslog_msg_with_name(const char *name, int facility, int pri, const char *msg);
179 void syslog_msg(int facility, int pri, const char *msg);
180
181 /* Include our own copy of struct sysinfo to avoid binary compatability
182  * problems with Linux 2.4, which changed things.  Grumble, grumble. */
183 struct sysinfo {
184         long uptime;                    /* Seconds since boot */
185         unsigned long loads[3];         /* 1, 5, and 15 minute load averages */
186         unsigned long totalram;         /* Total usable main memory size */
187         unsigned long freeram;          /* Available memory size */
188         unsigned long sharedram;        /* Amount of shared memory */
189         unsigned long bufferram;        /* Memory used by buffers */
190         unsigned long totalswap;        /* Total swap space size */
191         unsigned long freeswap;         /* swap space still available */
192         unsigned short procs;           /* Number of current processes */
193         unsigned short pad;                     /* Padding needed for m68k */
194         unsigned long totalhigh;        /* Total high memory size */
195         unsigned long freehigh;         /* Available high memory size */
196         unsigned int mem_unit;          /* Memory unit size in bytes */
197         char _f[20-2*sizeof(long)-sizeof(int)]; /* Padding: libc5 uses this.. */
198 };
199 extern int sysinfo (struct sysinfo* info);
200
201 enum {
202         KILOBYTE = 1024,
203         MEGABYTE = (KILOBYTE*1024),
204         GIGABYTE = (MEGABYTE*1024)
205 };
206 const char *make_human_readable_str(unsigned long size, unsigned long block_size, unsigned long display_unit);
207
208 int ask_confirmation(void);
209 int klogctl(int type, char * b, int len);
210
211 char *xgetcwd(char *cwd);
212 char *xreadlink(const char *path);
213 char *concat_path_file(const char *path, const char *filename);
214 char *last_char_is(const char *s, int c);
215
216 void *get_header_ar(FILE *in_file);
217 void *get_header_cpio(FILE *src_stream);
218 void *get_header_tar(FILE *tar_stream);
219
220 enum extract_functions_e {
221         extract_verbose_list = 1,
222         extract_list = 2,
223         extract_one_to_buffer = 4,
224         extract_to_stdout = 8,
225         extract_all_to_fs = 16,
226         extract_preserve_date = 32,
227         extract_data_tar_gz = 64,
228         extract_control_tar_gz = 128,
229         extract_unzip_only = 256,
230         extract_unconditional = 512,
231         extract_create_dirs = 1024
232 };
233 char *unarchive(FILE *src_stream, void *(*get_header)(FILE *),
234         const int extract_function, const char *prefix, char **extract_names);
235 char *deb_extract(const char *package_filename, FILE *out_stream, const int extract_function,
236         const char *prefix, const char *filename);
237 char *read_package_field(const char *package_buffer);
238 char *fgets_str(FILE *file, const char *terminating_string);
239
240 extern int unzip(FILE *l_in_file, FILE *l_out_file);
241 extern void gz_close(int gunzip_pid);
242 extern FILE *gz_open(FILE *compressed_file, int *pid);
243
244 extern struct hostent *xgethostbyname(const char *name);
245
246 char *dirname (const char *path);
247 char *strdup_substr (const char *s, int start, int end);
248 int make_directory (char *path, mode_t mode, int flags);
249
250 #define CT_AUTO 0
251 #define CT_UNIX2DOS     1
252 #define CT_DOS2UNIX     2
253 /* extern int convert(char *fn, int ConvType); */
254
255 enum {
256         FILEUTILS_PRESERVE_STATUS = 1,
257         FILEUTILS_PRESERVE_SYMLINKS = 2,
258         FILEUTILS_RECUR = 4,
259         FILEUTILS_FORCE = 8,
260         FILEUTILS_INTERACTIVE = 16
261 };
262
263 extern const char *applet_name;
264 extern const char * const full_version;
265 extern const char * const name_too_long;
266 extern const char * const omitting_directory;
267 extern const char * const not_a_directory;
268 extern const char * const memory_exhausted;
269 extern const char * const invalid_date;
270 extern const char * const invalid_option;
271 extern const char * const io_error;
272 extern const char * const dash_dash_help;
273 extern const char * const write_error;
274 extern const char * const too_few_args;
275 extern const char * const name_longer_than_foo;
276 extern const char * const unknown;
277
278 #endif /* __LIBBB_H__ */