blob: 8863e64c5fa9c62e24af13304c399c0b1241258f (
plain) (
tree)
|
|
/***
*_strerr.c - routine for indexing into system error list
*
* Copyright (c) 1985-1993, Microsoft Corporation. All rights reserved.
*
*Purpose:
* Returns system error message index by errno; conforms to the
* XENIX standard, much compatibility with 1983 uniforum draft standard.
*
*Revision History:
* 02-24-87 JCR Renamed this routine from "strerror" to "_strerror"
* for MS. The new "strerror" routine conforms to the
* ANSI interface.
* 11-10-87 SKS Remove IBMC20 switch
* 12-11-87 JCR Added "_LOAD_DS" to declaration
* 01-05-87 JCR Mthread support
* 05-31-88 PHG Merged DLL and normal versions
* 06-06-89 JCR 386 mthread support
* 11-20-89 GJF Fixed copyright, indents. Removed unreferenced local.
* Added const attribute to type of message
* 03-13-90 GJF Replaced _LOAD_DS with _CALLTYPE1, added #include
* <cruntime.h> and removed #include <register.h>
* 07-25-90 SBM Removed redundant include (stdio.h)
* 10-04-90 GJF New-style function declarator.
* 07-18-91 GJF Multi-thread support for Win32 [_WIN32_].
* 02-17-93 GJF Changed for new _getptd().
*
*******************************************************************************/
#include <cruntime.h>
#include <stdlib.h>
#include <errmsg.h>
#include <syserr.h>
#include <string.h>
#include <malloc.h>
#include <os2dll.h>
/* Max length of message = user_string(94)+system_string+2 */
/* [NOTE: The mthread error message buffer is shared by both strerror
and _strerror so must be the max length of both. */
#define _ERRMSGLEN_ 94+_SYS_MSGMAX+2
/***
*char *_strerror(message) - get system error message
*
*Purpose:
* builds an error message consisting of the users error message
* (the message parameter), followed by ": ", followed by the system
* error message (index through errno), followed by a newline. If
* message is NULL or a null string, returns a pointer to just
* the system error message.
*
*Entry:
* char *message - user's message to prefix system error message
*
*Exit:
* returns pointer to static memory containing error message.
* returns NULL if malloc() fails in multi-thread versions.
*
*Exceptions:
*
*******************************************************************************/
char * _CRTAPI1 _strerror (
REG1 const char *message
)
{
#ifdef MTHREAD
#ifdef _CRUISER_
struct _tiddata * tdata;
#else /* ndef _CRUISER_ */
#ifdef _WIN32_
_ptiddata ptd = _getptd();
#else /* ndef _WIN32_ */
#error ERROR - ONLY CRUISER OR WIN32 TARGET SUPPORTED!
#endif /* _WIN32_ */
#endif /* _CRUISER_ */
char *bldmsg;
#else
static char bldmsg[_ERRMSGLEN_];
#endif
#ifdef MTHREAD
#ifdef _CRUISER_
/* Use per thread buffer area (malloc space, if necessary) */
/* [NOTE: This buffer is shared between _strerror and streror.] */
tdata = _gettidtab(); /* get tid's data address */
if (tdata->_errmsg == NULL)
if ( (tdata->_errmsg = malloc(_ERRMSGLEN_)) == NULL)
return(NULL);
bldmsg = tdata->_errmsg;
#else /* ndef _CRUISER_ */
#ifdef _WIN32_
/* Use per thread buffer area (malloc space, if necessary) */
/* [NOTE: This buffer is shared between _strerror and streror.] */
if ( (ptd->_errmsg == NULL) && ((ptd->_errmsg = malloc(_ERRMSGLEN_))
== NULL) )
return(NULL);
bldmsg = ptd->_errmsg;
#else /* ndef _WIN32_ */
#error ERROR - ONLY CRUISER OR WIN32 TARGET SUPPORTED!
#endif /* _WIN32_ */
#endif /* _CRUISER_ */
#endif
/* Build the error message */
bldmsg[0] = '\0';
if (message && *message) {
strcat( bldmsg, message );
strcat( bldmsg, ": " );
}
strcat( bldmsg, _sys_err_msg( errno ) );
return( strcat( bldmsg, "\n" ) );
}
|