windows-nt/Source/XPSP1/NT/sdktools/listmung/listmung.c
2020-09-26 16:20:57 +08:00

338 lines
9.6 KiB
C

/*++
Copyright (c) 1992 Microsoft Corporation
Module Name:
listmung.c
Abstract:
This is the main module for a stubfile generation utility
Author:
Sanford Staab (sanfords) 22-Apr-1992
Revision History:
--*/
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#include <windef.h>
#define STRING_BUFFER_SIZE 120
char StringBuffer[STRING_BUFFER_SIZE];
char ItemBuffer[STRING_BUFFER_SIZE];
char ItemBuffer2[STRING_BUFFER_SIZE];
char *ListName, *TemplateName;
FILE *ListFile, *TemplateFile;
char szBEGINTRANSLATE[] = "BeginTranslate";
char szENDTRANSLATE[] = "EndTranslate";
char szENDTRANSLATEQLPC[] = "EndTranslateQLPC";
BOOL IsTranslateTag(char * pBuffer)
{
return (_strnicmp(pBuffer, szBEGINTRANSLATE, sizeof(szBEGINTRANSLATE)-1) == 0)
|| (_strnicmp(pBuffer, szENDTRANSLATE, sizeof(szENDTRANSLATE)-1) == 0);
}
BOOL IsCommentOrTag(char * pBuffer)
{
return ((*pBuffer == ';') || IsTranslateTag(pBuffer));
}
int
ProcessParameters(
int argc,
char *argv[]
)
{
char c, *p;
while (*++argv != NULL) {
p = *argv;
//
// if we have a delimiter for a parameter, case throught the valid
// parameter. Otherwise, the rest of the parameters are the list of
// input files.
//
if (*p == '/' || *p == '-') {
//
// Switch on all the valid delimiters. If we don't get a valid
// one, return with an error.
//
c = *++p;
switch (toupper( c )) {
default:
return 0;
}
} else {
ListName = *argv++;
TemplateName = *argv++;
return (ListName && TemplateName);
}
}
return 0;
}
BOOL mysubstr(
char *s,
char *find,
char *put)
{
char *p;
if (p = strstr(s, find)) {
strcpy(p, put);
strcpy(p + strlen(put), p + strlen(find)); // find > put!
return(TRUE);
}
return(FALSE);
}
VOID myprint(
char *s,
char *item,
int index)
{
if (strstr(s, "%d") || mysubstr(s, "%%INDEX%%", "%d")) {
printf(s, item, index);
} else {
printf(s, item);
}
}
//+---------------------------------------------------------------------------
//
// Function: myfgets
//
// Synopsis: Calls fgets to read a string from a file.
// It ignores empty lines or lines starting with a blank character
//
// This is needed when the input file was generated by the
// compiler preprocessor. Using the preprocessor allows us
// to use #idfdef, #inlcude, etc in the original list file.
//
// Arguments: [pszBuff] -- Buffer to store the string
// [iBuffSize] -- Buffer size
// [pFile] -- Pointer to the file to read
//
// Return [pszRet] -- Pointer to pszBuff if succesful read. NULL otherwise.
//----------------------------------------------------------------------------
char * myfgets(
char * pszBuff,
int iBuffSize,
FILE * pFile)
{
char *pszRet;
while (pszRet = fgets(pszBuff, iBuffSize, pFile)) {
if ((*pszRet == '\n') || (*pszRet == ' ')) {
continue;
} else {
break;
}
}
return pszRet;
}
//+---------------------------------------------------------------------------
//
// Function: SkipCommentsAndTags
//
// Synopsis: Calls myfgets to read a string from a file.
// It ignores lines starting with ; (ie, comments) and lines
// containing the Begin/EndTranslate tags.
//
// Arguments: [pszBuff] -- Buffer to store the string
// [iBuffSize] -- Buffer size
// [pFile] -- Pointer to the file to read
//
// Return [pszRet] -- Pointer to pszBuff if succesful read. NULL otherwise.
//----------------------------------------------------------------------------
char * SkipCommentsAndTags(
char * pszBuff,
int iBuffSize,
FILE * pFile)
{
char *pszRet;
while (pszRet = myfgets(pszBuff, iBuffSize, pFile)) {
if (IsCommentOrTag(pszRet)) {
continue;
} else {
break;
}
}
return pszRet;
}
void
ProcessTemplate( void )
{
char *s;
char *pchItem;
char *pchLastItem;
int index;
s = fgets(StringBuffer,STRING_BUFFER_SIZE,TemplateFile);
while ( s ) {
if (mysubstr(s, "%%FOR_ALL_UPPER%%", "%-45s")) {
rewind(ListFile);
index = 0;
while (pchItem = myfgets(ItemBuffer, STRING_BUFFER_SIZE, ListFile)) {
if (ItemBuffer[0] != ';') {
pchItem[strlen(pchItem) - 1] = '\0'; // strip off \n
pchItem = _strupr(pchItem);
if (IsTranslateTag(ItemBuffer)) {
myprint(s, pchItem, index);
} else {
myprint(s, pchItem, index++);
}
} else {
printf("// %s", ItemBuffer);
}
}
} else if (mysubstr(s, "%%FOR_ALL%%", "%s")) {
rewind(ListFile);
index = 0;
while (pchItem = myfgets(ItemBuffer, STRING_BUFFER_SIZE, ListFile)) {
if (ItemBuffer[0] != ';') {
pchItem[strlen(pchItem) - 1] = '\0'; // strip off \n
myprint(s, pchItem, index++);
}
}
} else if (mysubstr(s, "%%FOR_ALL_QLPC%%", "%s")) {
rewind(ListFile);
index = 0;
while (pchItem = myfgets(ItemBuffer, STRING_BUFFER_SIZE, ListFile)) {
if (ItemBuffer[0] != ';') {
pchItem[strlen(pchItem) - 1] = '\0'; // strip off \n
if (_strnicmp(ItemBuffer, szENDTRANSLATEQLPC, sizeof(szENDTRANSLATEQLPC)-1) == 0)
break;
myprint(s, pchItem, index++);
}
}
} else if (mysubstr(s, "%%FOR_ALL_LPC%%", "%s")) {
rewind(ListFile);
index = 0;
while (pchItem = myfgets(ItemBuffer, STRING_BUFFER_SIZE, ListFile)) {
if (ItemBuffer[0] != ';') {
pchItem[strlen(pchItem) - 1] = '\0'; // strip off \n
if (_strnicmp(ItemBuffer, szENDTRANSLATEQLPC, sizeof(szENDTRANSLATEQLPC)-1) == 0)
break;
}
}
while (pchItem = myfgets(ItemBuffer, STRING_BUFFER_SIZE, ListFile)) {
if (ItemBuffer[0] != ';') {
pchItem[strlen(pchItem) - 1] = '\0'; // strip off \n
myprint(s, pchItem, index++);
}
}
} else if (mysubstr(s, "%%FOR_ALL_BUT_LAST%%", "%s")) {
rewind(ListFile);
index = 0;
pchLastItem = SkipCommentsAndTags(ItemBuffer, STRING_BUFFER_SIZE, ListFile);
if (pchLastItem != NULL) {
pchLastItem[strlen(pchLastItem) - 1] = '\0'; // strip off \n
while (pchItem = myfgets(ItemBuffer2, STRING_BUFFER_SIZE, ListFile)) {
if (!IsCommentOrTag(pchItem)) {
pchItem[strlen(pchItem) - 1] = '\0'; // strip off \n
myprint(s, pchLastItem, index++); // Write previous line
strcpy(pchLastItem, pchItem); // Save current line
}
}
} else {
fprintf(stderr,"LISTMUNG: FOR_ALL_BUT_LAST: no lines found\n");
}
} else if (mysubstr(s, "%%FOR_LAST%%", "%s")) {
rewind(ListFile);
index = 0;
pchLastItem = SkipCommentsAndTags(ItemBuffer, STRING_BUFFER_SIZE, ListFile);
if (pchLastItem != NULL) {
pchLastItem[strlen(pchLastItem) - 1] = '\0'; // strip off \n
while (pchItem = myfgets(ItemBuffer2, STRING_BUFFER_SIZE, ListFile)) {
if (!IsCommentOrTag(pchItem)) {
pchItem[strlen(pchItem) - 1] = '\0'; // strip off \n
strcpy(pchLastItem, pchItem); // Save current line
index++;
}
}
myprint(s, pchLastItem, index); // Write Last line.
} else {
fprintf(stderr,"LISTMUNG: FOR_LAST: no lines found\n");
}
} else {
printf("%s", s);
}
s = fgets(StringBuffer,STRING_BUFFER_SIZE,TemplateFile);
}
}
int
__cdecl main( argc, argv )
int argc;
char *argv[];
{
if (!ProcessParameters( argc, argv )) {
fprintf( stderr, "Stub File Generation Utility. Version: 1.1\n" );
fprintf( stderr, "usage: listmung <symbol_list_file> <template>\n" );
fprintf( stderr, " Converts the elements in the list file into an output file\n" );
fprintf( stderr, " where the template dictates the format. The following strings\n");
fprintf( stderr, " are substituted apropriately:\n");
fprintf( stderr, " %%FOR_ALL%%\n");
fprintf( stderr, " %%FOR_ALL_UPPER%%\n");
fprintf( stderr, " %%FOR_ALL_BUT_LAST%%\n");
fprintf( stderr, " %%FOR_LAST%%\n");
fprintf( stderr, " %%INDEX%%\n");
fprintf( stderr, " output is to stdout.\n");
return 1;
}
if ( (ListFile = fopen(ListName,"r")) == 0) {
fprintf(stderr,"LISTMUNG: Unable to open list file.\n");
return 1;
}
if ( (TemplateFile = fopen(TemplateName,"r")) == 0) {
fprintf(stderr,"LISTMUNG: Unable to open template file.\n");
return 1;
}
ProcessTemplate();
fclose(ListFile);
fclose(TemplateFile);
return( 0 );
}