xref: /plan9/sys/src/9/port/lib.h (revision e94a8e9b44de11e62dfd4566245554f8bf8e0295)
1 /*
2  * functions (possibly) linked in, complete, from libc.
3  */
4 #define nelem(x)	(sizeof(x)/sizeof((x)[0]))
5 #define offsetof(s, m)	(ulong)(&(((s*)0)->m))
6 #define assert(x)	if(x){}else _assert("x")
7 
8 /*
9  * mem routines
10  */
11 extern	void*	memccpy(void*, void*, int, ulong);
12 extern	void*	memset(void*, int, ulong);
13 extern	int	memcmp(void*, void*, ulong);
14 extern	void*	memmove(void*, void*, ulong);
15 extern	void*	memchr(void*, int, ulong);
16 
17 /*
18  * string routines
19  */
20 extern	char*	strcat(char*, char*);
21 extern	char*	strchr(char*, int);
22 extern	char*	strrchr(char*, int);
23 extern	int	strcmp(char*, char*);
24 extern	char*	strcpy(char*, char*);
25 extern	char*	strecpy(char*, char*, char*);
26 extern	char*	strncat(char*, char*, long);
27 extern	char*	strncpy(char*, char*, long);
28 extern	int	strncmp(char*, char*, long);
29 extern	long	strlen(char*);
30 extern	char*	strstr(char*, char*);
31 extern	int	atoi(char*);
32 extern	int	fullrune(char*, int);
33 extern	int	cistrcmp(char*, char*);
34 extern	int	cistrncmp(char*, char*, int);
35 
36 enum
37 {
38 	UTFmax		= 4,		/* maximum bytes per rune */
39 	Runesync	= 0x80,		/* cannot represent part of a UTF sequence (<) */
40 	Runeself	= 0x80,		/* rune and UTF sequences are the same (<) */
41 	Runeerror	= 0xFFFD,	/* decoding error in UTF */
42 	Runemax		= 0x10FFFF,	/* 24 bit rune */
43 	Runemask	= 0x1FFFFF,	/* bits used by runes (see grep) */
44 };
45 
46 /*
47  * rune routines
48  */
49 extern	int	runetochar(char*, Rune*);
50 extern	int	chartorune(Rune*, char*);
51 extern	char*	utfrune(char*, long);
52 extern	int	utflen(char*);
53 extern	int	utfnlen(char*, long);
54 extern	int	runelen(long);
55 
56 extern	int	abs(int);
57 
58 /*
59  * print routines
60  */
61 typedef struct Fmt	Fmt;
62 typedef int (*Fmts)(Fmt*);
63 struct Fmt{
64 	uchar	runes;			/* output buffer is runes or chars? */
65 	void	*start;			/* of buffer */
66 	void	*to;			/* current place in the buffer */
67 	void	*stop;			/* end of the buffer; overwritten if flush fails */
68 	int	(*flush)(Fmt *);	/* called when to == stop */
69 	void	*farg;			/* to make flush a closure */
70 	int	nfmt;			/* num chars formatted so far */
71 	va_list	args;			/* args passed to dofmt */
72 	int	r;			/* % format Rune */
73 	int	width;
74 	int	prec;
75 	ulong	flags;
76 };
77 extern	int	print(char*, ...);
78 extern	char*	seprint(char*, char*, char*, ...);
79 extern	char*	vseprint(char*, char*, char*, va_list);
80 extern	int	snprint(char*, int, char*, ...);
81 extern	int	vsnprint(char*, int, char*, va_list);
82 extern	int	sprint(char*, char*, ...);
83 
84 #pragma	varargck	argpos	fmtprint	2
85 #pragma	varargck	argpos	print		1
86 #pragma	varargck	argpos	seprint		3
87 #pragma	varargck	argpos	snprint		3
88 #pragma	varargck	argpos	sprint		2
89 
90 #pragma	varargck	type	"lld"	vlong
91 #pragma	varargck	type	"llx"	vlong
92 #pragma	varargck	type	"lld"	uvlong
93 #pragma	varargck	type	"llx"	uvlong
94 #pragma	varargck	type	"ld"	long
95 #pragma	varargck	type	"lx"	long
96 #pragma	varargck	type	"ld"	ulong
97 #pragma	varargck	type	"lx"	ulong
98 #pragma	varargck	type	"d"	int
99 #pragma	varargck	type	"x"	int
100 #pragma	varargck	type	"c"	int
101 #pragma	varargck	type	"C"	int
102 #pragma	varargck	type	"d"	uint
103 #pragma	varargck	type	"x"	uint
104 #pragma	varargck	type	"c"	uint
105 #pragma	varargck	type	"C"	uint
106 #pragma	varargck	type	"s"	char*
107 #pragma	varargck	type	"q"	char*
108 #pragma	varargck	type	"S"	Rune*
109 #pragma	varargck	type	"%"	void
110 #pragma	varargck	type	"p"	uintptr
111 #pragma	varargck	type	"p"	void*
112 #pragma	varargck	flag	','
113 
114 extern	int	fmtstrinit(Fmt*);
115 extern	int	fmtinstall(int, int (*)(Fmt*));
116 extern	void	quotefmtinstall(void);
117 extern	int	fmtprint(Fmt*, char*, ...);
118 extern	int	fmtstrcpy(Fmt*, char*);
119 extern	char*	fmtstrflush(Fmt*);
120 
121 /*
122  * one-of-a-kind
123  */
124 extern	char*	cleanname(char*);
125 extern	ulong	getcallerpc(void*);
126 
127 extern	long	strtol(char*, char**, int);
128 extern	ulong	strtoul(char*, char**, int);
129 extern	vlong	strtoll(char*, char**, int);
130 extern	uvlong	strtoull(char*, char**, int);
131 extern	char	etext[];
132 extern	char	edata[];
133 extern	char	end[];
134 extern	int	getfields(char*, char**, int, int, char*);
135 extern	int	tokenize(char*, char**, int);
136 extern	int	dec64(uchar*, int, char*, int);
137 extern	int	encodefmt(Fmt*);
138 extern	void	qsort(void*, long, long, int (*)(void*, void*));
139 
140 /*
141  * Syscall data structures
142  */
143 #define	MORDER	0x0003	/* mask for bits defining order of mounting */
144 #define	MREPL	0x0000	/* mount replaces object */
145 #define	MBEFORE	0x0001	/* mount goes before others in union directory */
146 #define	MAFTER	0x0002	/* mount goes after others in union directory */
147 #define	MCREATE	0x0004	/* permit creation in mounted directory */
148 #define	MCACHE	0x0010	/* cache some data */
149 #define	MMASK	0x0017	/* all bits on */
150 
151 #define	OREAD	0	/* open for read */
152 #define	OWRITE	1	/* write */
153 #define	ORDWR	2	/* read and write */
154 #define	OEXEC	3	/* execute, == read but check execute permission */
155 #define	OTRUNC	16	/* or'ed in (except for exec), truncate file first */
156 #define	OCEXEC	32	/* or'ed in, close on exec */
157 #define	ORCLOSE	64	/* or'ed in, remove on close */
158 #define OEXCL   0x1000	/* or'ed in, exclusive create */
159 
160 #define	NCONT	0	/* continue after note */
161 #define	NDFLT	1	/* terminate after note */
162 #define	NSAVE	2	/* clear note but hold state */
163 #define	NRSTR	3	/* restore saved state */
164 
165 typedef struct Qid	Qid;
166 typedef struct Dir	Dir;
167 typedef struct OWaitmsg	OWaitmsg;
168 typedef struct Waitmsg	Waitmsg;
169 
170 #define	ERRMAX			128	/* max length of error string */
171 #define	KNAMELEN		28	/* max length of name held in kernel */
172 
173 /* bits in Qid.type */
174 #define QTDIR		0x80		/* type bit for directories */
175 #define QTAPPEND	0x40		/* type bit for append only files */
176 #define QTEXCL		0x20		/* type bit for exclusive use files */
177 #define QTMOUNT		0x10		/* type bit for mounted channel */
178 #define QTAUTH		0x08		/* type bit for authentication file */
179 #define QTFILE		0x00		/* plain file */
180 
181 /* bits in Dir.mode */
182 #define DMDIR		0x80000000	/* mode bit for directories */
183 #define DMAPPEND	0x40000000	/* mode bit for append only files */
184 #define DMEXCL		0x20000000	/* mode bit for exclusive use files */
185 #define DMMOUNT		0x10000000	/* mode bit for mounted channel */
186 #define DMREAD		0x4		/* mode bit for read permission */
187 #define DMWRITE		0x2		/* mode bit for write permission */
188 #define DMEXEC		0x1		/* mode bit for execute permission */
189 
190 struct Qid
191 {
192 	uvlong	path;
193 	ulong	vers;
194 	uchar	type;
195 };
196 
197 struct Dir {
198 	/* system-modified data */
199 	ushort	type;	/* server type */
200 	uint	dev;	/* server subtype */
201 	/* file data */
202 	Qid	qid;	/* unique id from server */
203 	ulong	mode;	/* permissions */
204 	ulong	atime;	/* last read time */
205 	ulong	mtime;	/* last write time */
206 	vlong	length;	/* file length: see <u.h> */
207 	char	*name;	/* last element of path */
208 	char	*uid;	/* owner name */
209 	char	*gid;	/* group name */
210 	char	*muid;	/* last modifier name */
211 };
212 
213 struct OWaitmsg
214 {
215 	char	pid[12];	/* of loved one */
216 	char	time[3*12];	/* of loved one and descendants */
217 	char	msg[64];	/* compatibility BUG */
218 };
219 
220 struct Waitmsg
221 {
222 	int	pid;		/* of loved one */
223 	ulong	time[3];	/* of loved one and descendants */
224 	char	msg[ERRMAX];	/* actually variable-size in user mode */
225 };
226