blderr.c
来自「开放源码的编译器open watcom 1.6.0版的源代码」· C语言 代码 · 共 176 行
C
176 行
/****************************************************************************
*
* Open Watcom Project
*
* Portions Copyright (c) 1983-2002 Sybase, Inc. All Rights Reserved.
*
* ========================================================================
*
* This file contains Original Code and/or Modifications of Original
* Code as defined in and that are subject to the Sybase Open Watcom
* Public License version 1.0 (the 'License'). You may not use this file
* except in compliance with the License. BY USING THIS FILE YOU AGREE TO
* ALL TERMS AND CONDITIONS OF THE LICENSE. A copy of the License is
* provided with the Original Code and Modifications, and is also
* available at www.sybase.com/developer/opensource.
*
* The Original Code and all software distributed under the License are
* distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
* EXPRESS OR IMPLIED, AND SYBASE AND ALL CONTRIBUTORS HEREBY DISCLAIM
* ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR
* NON-INFRINGEMENT. Please see the License for the specific language
* governing rights and limitations under the License.
*
* ========================================================================
*
* Description: WHEN YOU FIGURE OUT WHAT THIS FILE DOES, PLEASE
* DESCRIBE IT HERE!
*
****************************************************************************/
//
// BLDERR : Build an error message.
//
#include "ftnstd.h"
#include <stdarg.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define MAX_SUBSTITUTABLE_ARGS 8
typedef union msg_arg {
char *s;
int d;
unsigned int u;
long int i;
} msg_arg;
static void OrderArgs( char *msg, msg_arg *ordered_args, va_list args ) {
//===========================================================================
char chr;
uint idx;
uint arg_count;
arg_count = 0;
for(;;) {
for(;;) {
chr = *msg;
if( chr == '%' ) break;
if( chr == NULLCHAR ) return;
++msg;
}
++arg_count;
++msg; // skip over '%'
chr = *msg;
if( isdigit( chr ) ) { // only support a 1 digit field width
++msg; // skip over width specifier
chr = *msg;
}
++msg; // skip over format specifier
idx = *msg - '0' - 1; // get positional information
++msg;
if( arg_count > MAX_SUBSTITUTABLE_ARGS ) continue;
if( chr == 's' ) {
ordered_args[idx].s = va_arg( args, char * );
} else if( chr == 'd' ) {
ordered_args[idx].d = va_arg( args, int );
} else if( chr == 'u' ) {
ordered_args[idx].u = va_arg( args, unsigned int );
} else { // assume --> fflag == 'i'
ordered_args[idx].i = va_arg( args, long int );
}
}
}
void Substitute( char *msg, char *buffer, va_list args ) {
//===========================================================
// Do the necessary "%" substitutions.
char *subs_ptr;
int subs_len;
char chr;
char temp_buff[MAX_INT_SIZE];
int width;
int arg_count;
int idx;
msg_arg ordered_args[MAX_SUBSTITUTABLE_ARGS];
bool same_buff;
same_buff = ( msg == buffer ) ? TRUE : FALSE;
OrderArgs( msg, ordered_args, args );
arg_count = 0;
for(;;) {
for(;;) {
chr = *msg;
if( chr == '%' ) break;
if( chr == NULLCHAR ) break;
*buffer = chr;
++buffer;
++msg;
}
if( chr == NULLCHAR ) break;
++arg_count;
++msg; // skip over '%'
chr = *msg;
width = 0;
if( isdigit( chr ) ) { // only support a 1 digit field width
width = chr - '0';
++msg; // skip over width specifier
chr = *msg;
}
++msg; // skip over format specifier
idx = *msg - '0' - 1; // get positional information
++msg;
subs_ptr = temp_buff;
if( arg_count > MAX_SUBSTITUTABLE_ARGS ) {
temp_buff[0] = '?';
temp_buff[1] = NULLCHAR;
} else if( chr == 's' ) {
subs_ptr = ordered_args[idx].s;
} else if( chr == 'd' ) {
itoa( ordered_args[idx].d, temp_buff, 10 );
} else if( chr == 'u' ) {
utoa( ordered_args[idx].u, temp_buff, 10 );
} else { // assume --> fflag == 'i'
ultoa( ordered_args[idx].i, temp_buff, 10 );
}
subs_len = strlen( subs_ptr );
if( width < subs_len ) {
width = subs_len;
}
if( same_buff ) {
memmove( buffer + width, msg, strlen( msg ) + sizeof( char ) );
msg = buffer + width;
}
if( subs_len < width ) {
if( chr == 's' ) {
memset( buffer, ' ', width - subs_len );
} else {
memset( buffer, '0', width - subs_len );
}
buffer += width - subs_len;
}
memcpy( buffer, subs_ptr, subs_len );
buffer += subs_len;
}
*buffer = NULLCHAR;
}
int ErrCodOrg( uint error ) {
//===============================
// Take the specified error code and return its group offset.
return( ( error % 256 ) + 1 );
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?