lib.h 5.6 KB

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