1 /* -*-comment-start: "//";comment-end:""-*-
2 * Mes --- Maxwell Equations of Software
3 * Copyright © 2017 Jan (janneke) Nieuwenhuizen <janneke@gnu.org>
5 * This file is part of Mes.
7 * Mes is free software; you can redistribute it and/or modify it
8 * under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 3 of the License, or (at
10 * your option) any later version.
12 * Mes is distributed in the hope that it will be useful, but
13 * WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with Mes. If not, see <http://www.gnu.org/licenses/>.
33 dlclose (void *handle)
39 dlopen (char const *filename, int flags)
45 execvp (char const *file, char *const argv[])
47 eputs ("execvp stub\n");
59 fdopen (int fd, char const *mode)
68 if (fd == -1) return -1;
75 eputs ("fflush stub\n");
80 fopen (char const *pathname, char const *mode)
82 eputs ("fopen stub\n");
87 fprintf (FILE *stream, char const *format, ...)
90 va_start (ap, format);
91 int r = vfprintf (stream, format, ap);
97 fread (void *ptr, size_t size, size_t nmemb, FILE *stream)
99 eputs ("fread stub\n");
104 fseek (FILE *stream, long offset, int whence)
106 eputs ("fseek stub\n");
113 eputs ("ftell stub\n");
118 fwrite (void const *ptr, size_t size, size_t nmemb, FILE *stream)
120 int fd = (int)stream;
121 return write (fd, ptr, size * nmemb);
125 gettimeofday (struct timeval *tv, struct timezone *tz)
131 ldexp (double x, int exp)
133 eputs ("ldexp stub\n");
138 localtime (time_t const *timep)
140 eputs ("localtime stub\n");
145 memmove (void *dest, void const *src, size_t n)
148 return memcpy (dest, src, n);
150 char const *q = src +n;
157 memset (void *s, int c, size_t n)
160 while (n--) *p++ = c;
165 memcmp (void const *s1, void const *s2, size_t n)
169 while (*a == *b && --n) {a++;b++;}
174 mprotect (void *addr, size_t len, int prot)
180 qswap (void *a, void *b, size_t size)
183 memcpy (buf, a, size);
185 memcpy (b, buf, size);
189 qpart (void *base, size_t count, size_t size, int (*compare)(void const *, void const *))
191 void* p = base + count*size;
193 for (size_t j = 0; j < count; j++)
195 if (compare (base+j*size, p) < 0)
197 qswap (base+i*size, base+j*size, size);
201 if (compare (base+count*size, base+i*size) < 0)
202 qswap (base+i*size, base+count*size, size);
207 qsort (void *base, size_t count, size_t size, int (*compare)(void const *, void const *))
211 int p = qpart (base, count-1, size, compare);
212 qsort (base, p, size, compare);
213 qsort (base+p*size, count-p, size, compare);
218 remove (char const *file_name)
220 eputs ("remove stub\n");
225 sigaction (int signum, struct sigaction const *act, struct sigaction *oldact)
231 sigemptyset (sigset_t *set)
237 snprintf(char *str, size_t size, char const *format, ...)
240 va_start (ap, format);
241 int r = vsprintf (str, format, ap);
247 sscanf (char const *str, const char *format, ...)
249 eputs ("sscanf stub\n");
254 strcat (char *dest, char const *src)
256 char *p = strchr (dest, '\0');
257 while (*src++) *p++ = *src++;
263 strchr (char const *s, int c)
268 if (c == *p) return p;
275 strrchr (char const *s, int c)
279 char const *p = s + n - 1;
282 if (c == *p) return p;
289 strstr (char const *haystack, char const *needle)
291 eputs ("strstr stub\n");
296 strtod (char const *nptr, char **endptr)
298 eputs ("strtoul stub\n");
302 strtof (char const *nptr, char **endptr)
304 return strtod (nptr, endptr);
308 strtold (char const *nptr, char **endptr)
310 return strtod (nptr, endptr);
314 strtol (char const *nptr, char **endptr, int base)
316 if (!strncmp (nptr, "0x", 2))
318 char const *p = nptr + 2;
319 return abtoi (&p, 16);
321 return abtoi (&nptr, base);
325 strtoll (char const *nptr, char **endptr, int base)
327 eputs ("strtoll stub\n");
332 strtoul (char const *nptr, char **endptr, int base)
334 eputs ("strtoul stub\n");
339 strtoull (char const *p, char **endptr, int base)
342 return abtoi (endptr, base);
345 time_t time (time_t *tloc)
351 vsnprintf (char *str, size_t size, char const *format, va_list ap)
353 return vsprintf (str, format, ap);
357 calloc (size_t nmemb, size_t size)
359 size_t count = nmemb * size;
360 void *p = malloc (count);
361 memset (p, 0, count);
366 vfprintf (FILE* f, char const* format, va_list ap)
369 char const *p = format;
379 case '%': {fputc (*p, fd); break;}
380 case 'c': {char c; c = va_arg (ap, char); fputc (c, fd); break;}
381 case 'd': {int d; d = va_arg (ap, int); fputs (itoa (d), fd); break;}
382 case 's': {char *s; s = va_arg (ap, char *); fputs (s, fd); break;}
383 default: {fputc (*p, fd); break;}