objxref.c
来自「开放源码的编译器open watcom 1.6.0版的源代码」· C语言 代码 · 共 367 行
C
367 行
/****************************************************************************
*
* 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: Tool, search all referenced external symbols
*
****************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include "pcobj.h"
#include "hashtab.h"
#include "misc.h"
#define MAX_LINE_LEN 512
typedef unsigned char byte;
typedef byte *data_ptr;
static symbol **pubdef_tab;
static symbol **extdef_tab;
static data_ptr NamePtr;
static byte NameLen;
static unsigned_16 RecLen;
static data_ptr RecBuff;
static data_ptr RecPtr;
static unsigned_16 RecMaxLen;
static int isMS386;
static void usage( void )
/***********************/
{
SymbolFini( pubdef_tab );
printf( "Usage: objxref <options> <list of object or library files>\n" );
printf( " <options> -e=<file> file with excluded symbols\n" );
exit( -1 );
}
static int EndRec( void )
/***********************/
{
return( RecPtr >= (RecBuff + RecLen) );
}
static byte GetByte( void )
/*************************/
{
byte ret;
ret = *RecPtr;
RecPtr++;
return( ret );
}
static unsigned_16 GetUInt( void )
/********************************/
{
unsigned_16 word;
word = *(unsigned_16 *)RecPtr;
CONV_LE_16( word );
RecPtr += 2;
return( word );
}
static unsigned_32 GetOffset( void )
/**********************************/
{
if( isMS386 ) {
unsigned_32 dword;
dword = *(unsigned_32 *)RecPtr;
CONV_LE_32( dword );
RecPtr += 4;
return( dword );
} else {
unsigned_16 word;
word = *(unsigned_16 *)RecPtr;
CONV_LE_16( word );
RecPtr += 2;
return( word );
}
}
static unsigned_16 GetIndex( void )
/*********************************/
{
unsigned_16 index;
index = GetByte();
if( index & 0x80 ) {
index = ( (index & 0x7f) << 8 ) + GetByte();
}
return( index );
}
static char *GetName( void )
/**************************/
{
NameLen = GetByte();
NamePtr = RecPtr;
RecPtr += NameLen;
return( NamePtr );
}
static void ResizeBuff( unsigned_16 reqd_len )
/********************************************/
{
if( reqd_len > RecMaxLen ) {
RecMaxLen = reqd_len;
if( RecBuff != NULL ) {
free( RecBuff );
}
RecBuff = malloc( RecMaxLen );
if( RecBuff == NULL ) {
printf( "**FATAL** Out of memory!\n" );
exit( -1 );
}
}
}
static void ProcFilePubDef( FILE *fp )
/************************************/
{
byte hdr[ 3 ];
unsigned_16 page_len;
unsigned_32 offset;
page_len = 0;
RecBuff = NULL;
RecMaxLen = 0;
for(;;) {
offset = ftell( fp );
if( fread( hdr, 1, 3, fp ) != 3 )
break;
RecLen = hdr[ 1 ] | ( hdr[ 2 ] << 8 );
ResizeBuff( RecLen );
RecPtr = RecBuff;
if( fread( RecBuff, RecLen, 1, fp ) == 0 )
break;
RecLen--;
isMS386 = hdr[ 0 ] & 1;
switch( hdr[ 0 ] & ~1 ) {
case CMD_MODEND:
if( page_len != 0 ) {
offset = ftell( fp );
offset = page_len - offset % page_len;
if( offset != page_len ) {
fseek( fp, offset, SEEK_CUR );
}
}
break;
case CMD_PUBDEF:
if( ( GetIndex() | GetIndex() ) == 0 )
GetUInt();
while( ! EndRec() ) {
GetName();
*RecPtr = 0;
AddSymbol( pubdef_tab, NamePtr, NULL );
GetOffset();
GetIndex();
}
break;
case LIB_HEADER_REC:
if( isMS386 ) {
fseek( fp, 0L, SEEK_END );
page_len = 0;
} else {
page_len = RecLen + 4;
}
break;
default:
break;
}
}
free( RecBuff );
}
static void ProcFileExtDef( FILE *fp )
/************************************/
{
byte hdr[ 3 ];
unsigned_16 page_len;
unsigned_32 offset;
page_len = 0;
RecBuff = NULL;
RecMaxLen = 0;
for(;;) {
offset = ftell( fp );
if( fread( hdr, 1, 3, fp ) != 3 )
break;
RecLen = hdr[ 1 ] | ( hdr[ 2 ] << 8 );
ResizeBuff( RecLen );
RecPtr = RecBuff;
if( fread( RecBuff, RecLen, 1, fp ) == 0 )
break;
RecLen--;
isMS386 = hdr[ 0 ] & 1;
switch( hdr[ 0 ] & ~1 ) {
case CMD_MODEND:
if( page_len != 0 ) {
offset = ftell( fp );
offset = page_len - offset % page_len;
if( offset != page_len ) {
fseek( fp, offset, SEEK_CUR );
}
}
break;
case CMD_EXTDEF:
while( ! EndRec() ) {
GetName();
*RecPtr = 0;
GetIndex();
if( SymbolExists( pubdef_tab, NamePtr ) == 0 ) {
if( SymbolExists( extdef_tab, NamePtr ) == 0 ) {
AddSymbol( extdef_tab, NamePtr, NULL );
printf( "%s\n", NamePtr );
}
}
}
break;
case LIB_HEADER_REC:
if( isMS386 ) {
fseek( fp, 0L, SEEK_END );
page_len = 0;
} else {
page_len = RecLen + 4;
}
break;
default:
break;
}
}
free( RecBuff );
}
static void process_except_file( char *filename )
/***********************************************/
{
FILE *fp;
char line[ MAX_LINE_LEN ];
char *p;
if( filename != NULL ) {
fp = fopen( filename, "rt" );
while( fgets( line, MAX_LINE_LEN , fp ) != NULL ) {
p = line + strlen( line );
while( p >= line ) {
if( ( *p == '\0' )
|| ( *p == ' ' )
|| ( *p == '\n' ) ) {
*p = '\0';
p--;
} else {
break;
}
}
AddSymbol( pubdef_tab, line, NULL );
}
fclose( fp );
}
}
static int process_file_pubdef( char *filename )
/**********************************************/
{
FILE *fp;
fp = fopen( filename, "rb" );
if( fp == NULL ) {
printf( "Cannot open input file: %s.\n", filename );
return( 0 );
}
ProcFilePubDef( fp );
fclose( fp );
return( 1 );
}
static int process_file_extdef( char *filename )
/**********************************************/
{
FILE *fp;
fp = fopen( filename, "rb" );
if( fp == NULL ) {
printf( "Cannot open input file: %s.\n", filename );
return( 0 );
}
ProcFileExtDef( fp );
fclose( fp );
return( 1 );
}
int main( int argc, char *argv[] )
/********************************/
{
char *fn;
int i;
int x;
pubdef_tab = SymbolInit();
for( i = 1; i < argc; ++i ) {
if( argv[i][0] == '-' ) {
switch( tolower( argv[i][1] ) ) {
case 'e':
if( argv[i][2] == '=' ) {
process_except_file( argv[i] + 3 );
break;
}
default:
usage();
}
} else {
break;
}
}
if( i == argc )
usage();
x = i;
for( i = x; i < argc; ++i ) {
fn = DoWildCard( argv[i] );
while( fn != NULL ) {
process_file_pubdef( fn );
fn = DoWildCard( NULL );
}
DoWildCardClose();
}
extdef_tab = SymbolInit();
for( i = x; i < argc; ++i ) {
fn = DoWildCard( argv[i] );
while( fn != NULL ) {
process_file_extdef( fn );
fn = DoWildCard( NULL );
}
DoWildCardClose();
}
SymbolFini( pubdef_tab );
SymbolFini( extdef_tab );
return( 0 );
}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?