/* FUNCTION <>---print an error message on standard error INDEX perror INDEX _perror_r ANSI_SYNOPSIS #include void perror(char *<[prefix]>); void _perror_r(void *<[reent]>, char *<[prefix]>); TRAD_SYNOPSIS #include void perror(<[prefix]>) char *<[prefix]>; void _perror_r(<[reent]>, <[prefix]>) char *<[reent]>; char *<[prefix]>; DESCRIPTION Use <> to print (on standard error) an error message corresponding to the current value of the global variable <>. Unless you use <> as the value of the argument <[prefix]>, the error message will begin with the string at <[prefix]>, followed by a colon and a space (<<: >>). The remainder of the error message is one of the strings described for <>. The alternate function <<_perror_r>> is a reentrant version. The extra argument <[reent]> is a pointer to a reentrancy structure. RETURNS <> returns no result. PORTABILITY ANSI C requires <>, but the strings issued vary from one implementation to another. Supporting OS subroutines required: <>, <>, <>, <>, <>, <>, <>. */ #include #include #include #include "local.h" void _DEFUN (_perror_r, (ptr, s), struct _reent *ptr _AND _CONST char *s) { char *error; _REENT_SMALL_CHECK_INIT(_stderr_r (ptr)); if (s != NULL && *s != '\0') { fputs (s, _stderr_r (ptr)); fputs (": ", _stderr_r (ptr)); } if ((error = strerror (ptr->_errno)) != NULL) fputs (error, _stderr_r (ptr)); fputc ('\n', _stderr_r (ptr)); } #ifndef _REENT_ONLY void _DEFUN (perror, (s), _CONST char *s) { _perror_r (_REENT, s); } #endif