/* do not edit automatically generated by mc from libc. */ /* libc.def provides an interface to the C library functions. Copyright (C) 2001-2023 Free Software Foundation, Inc. Contributed by Gaius Mulley . This file is part of GNU Modula-2. GNU Modula-2 is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version. GNU Modula-2 is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. Under Section 7 of GPL version 3, you are granted additional permissions described in the GCC Runtime Library Exception, version 3.1, as published by the Free Software Foundation. You should have received a copy of the GNU General Public License and a copy of the GCC Runtime Library Exception along with this program; see the files COPYING3 and COPYING.RUNTIME respectively. If not, see . */ #if !defined (_libc_H) # define _libc_H #include "config.h" #include "system.h" # ifdef __cplusplus extern "C" { # endif #include # if !defined (PROC_D) # define PROC_D typedef void (*PROC_t) (void); typedef struct { PROC_t proc; } PROC; # endif # include "GSYSTEM.h" # if defined (_libc_C) # define EXTERN # else # define EXTERN extern # endif typedef long int libc_time_t; typedef struct libc_tm_r libc_tm; typedef struct libc_timeb_r libc_timeb; typedef struct libc_exitP_p libc_exitP; typedef libc_tm *libc_ptrToTM; struct libc_tm_r { int tm_sec; int tm_min; int tm_hour; int tm_mday; int tm_mon; int tm_year; int tm_wday; int tm_yday; int tm_isdst; long int tm_gmtoff; void *tm_zone; }; struct libc_timeb_r { libc_time_t time_; short unsigned int millitm; short unsigned int timezone; short unsigned int dstflag; }; typedef int (*libc_exitP_t) (void); typedef libc_exitP_t libc_exitP_C; struct libc_exitP_p { libc_exitP_t proc; }; EXTERN ssize_t libc_write (int d, void * buf, size_t nbytes); EXTERN ssize_t libc_read (int d, void * buf, size_t nbytes); EXTERN int libc_system (void * a); /* abort - generate a fault abort() first closes all open files if possible, then sends an IOT signal to the process. This signal usually results in termination with a core dump, which may be used for debugging. It is possible for abort() to return control if is caught or ignored, in which case the value returned is that of the kill(2V) system call. */ EXTERN void libc_abort (void) __attribute__ ((noreturn)); /* malloc - memory allocator. void *malloc(size_t size); malloc() returns a pointer to a block of at least size bytes, which is appropriately aligned. If size is zero, malloc() returns a non-NULL pointer, but this pointer should not be dereferenced. */ EXTERN void * libc_malloc (size_t size); /* free - memory deallocator. free (void *ptr); free() releases a previously allocated block. Its argument is a pointer to a block previously allocated by malloc, calloc, realloc, malloc, or memalign. */ EXTERN void libc_free (void * ptr); EXTERN void * libc_realloc (void * ptr, size_t size); /* isatty - does this descriptor refer to a terminal. */ EXTERN int libc_isatty (int fd); /* exit - returns control to the invoking process. Result, r, is returned. */ EXTERN void libc_exit (int r) __attribute__ ((noreturn)); /* getenv - returns the C string for the equivalent C environment variable. */ EXTERN void * libc_getenv (void * s); /* putenv - change or add an environment variable. */ EXTERN int libc_putenv (void * s); /* getpid - returns the UNIX process identification number. */ EXTERN int libc_getpid (void); /* dup - duplicates the file descriptor, d. */ EXTERN int libc_dup (int d); /* close - closes the file descriptor, d. */ EXTERN int libc_close (int d); /* open - open the file, filename with flag and mode. */ EXTERN int libc_open (void * filename, int oflag, ...); /* creat - creates a new file */ EXTERN int libc_creat (void * filename, unsigned int mode); /* lseek - calls unix lseek: off_t lseek(int fildes, off_t offset, int whence); */ EXTERN long int libc_lseek (int fd, long int offset, int whence); /* perror - writes errno and string. (ARRAY OF CHAR is translated onto ADDRESS). */ EXTERN void libc_perror (const char *string_, unsigned int _string_high); /* readv - reads an io vector of bytes. */ EXTERN int libc_readv (int fd, void * v, int n); /* writev - writes an io vector of bytes. */ EXTERN int libc_writev (int fd, void * v, int n); /* getcwd - copies the absolute pathname of the current working directory to the array pointed to by buf, which is of length size. If the current absolute path name would require a buffer longer than size elements, NULL is returned, and errno is set to ERANGE; an application should check for this error, and allocate a larger buffer if necessary. */ EXTERN void * libc_getcwd (void * buf, size_t size); /* chown - The owner of the file specified by path or by fd is changed. Only the super-user may change the owner of a file. The owner of a file may change the group of the file to any group of which that owner is a member. The super-user may change the group arbitrarily. If the owner or group is specified as -1, then that ID is not changed. On success, zero is returned. On error, -1 is returned, and errno is set appropriately. */ EXTERN int libc_chown (void * filename, int uid, int gid); /* strlen - returns the length of string, a. */ EXTERN size_t libc_strlen (void * a); /* strcpy - copies string, src, into, dest. It returns dest. */ EXTERN void * libc_strcpy (void * dest, void * src); /* strncpy - copies string, src, into, dest, copying at most, n, bytes. It returns dest. */ EXTERN void * libc_strncpy (void * dest, void * src, unsigned int n); /* unlink - removes file and returns 0 if successful. */ EXTERN int libc_unlink (void * file); /* memcpy - copy memory area SYNOPSIS #include void *memcpy(void *dest, const void *src, size_t n); It returns dest. */ EXTERN void * libc_memcpy (void * dest, void * src, size_t size); /* memset - fill memory with a constant byte SYNOPSIS #include void *memset(void *s, int c, size_t n); It returns s. */ EXTERN void * libc_memset (void * s, int c, size_t size); /* memmove - copy memory areas which may overlap SYNOPSIS #include void *memmove(void *dest, const void *src, size_t n); It returns dest. */ EXTERN void * libc_memmove (void * dest, void * src, size_t size); EXTERN int libc_printf (const char *format_, unsigned int _format_high, ...); EXTERN int libc_snprintf (void * dest, size_t size, const char *format_, unsigned int _format_high, ...); /* setenv - sets environment variable, name, to value. It will overwrite an existing value if, overwrite, is true. It returns 0 on success and -1 for an error. */ EXTERN int libc_setenv (void * name, void * value, int overwrite); /* srand - initialize the random number seed. */ EXTERN void libc_srand (int seed); /* rand - return a random integer. */ EXTERN int libc_rand (void); /* time - returns a pointer to the time_t value. If, a, is not NIL then the libc value is copied into memory at address, a. */ EXTERN libc_time_t libc_time (void * a); /* localtime - returns a pointer to the libc copy of the tm structure. */ EXTERN void * libc_localtime (libc_time_t *t); /* ftime - return date and time. */ EXTERN int libc_ftime (libc_timeb *t); /* shutdown - shutdown a socket, s. if how = 0, then no more reads are allowed. if how = 1, then no more writes are allowed. if how = 2, then mo more reads or writes are allowed. */ EXTERN int libc_shutdown (int s, int how); /* rename - change the name or location of a file */ EXTERN int libc_rename (void * oldpath, void * newpath); /* setjmp - returns 0 if returning directly, and non-zero when returning from longjmp using the saved context. */ EXTERN int libc_setjmp (void * env); /* longjmp - restores the environment saved by the last call of setjmp with the corresponding env argument. After longjmp is completed, program execution continues as if the corresponding call of setjmp had just returned the value val. The value of val must not be zero. */ EXTERN void libc_longjmp (void * env, int val); /* atexit - execute, proc, when the function exit is called. */ EXTERN int libc_atexit (libc_exitP_C proc); /* ttyname - returns a pointer to a string determining the ttyname. */ EXTERN void * libc_ttyname (int filedes); /* sleep - calling thread sleeps for seconds. */ EXTERN unsigned int libc_sleep (unsigned int seconds); /* execv - execute a file. */ EXTERN int libc_execv (void * pathname, void * argv); # ifdef __cplusplus } # endif # undef EXTERN #endif