/* * $Id$ */ #if defined(__DJGPP__) || defined(__GNUC__) #include #include #else #include #include #endif #include #include #include "harb.h" int Hp_Parse( FILE*, FILE* ); extern int ParseDirective( char* ); extern int ParseExpression( char*, char* ); extern int RdStr(FILE*,char *,int,int,char*,int*,int*); extern int WrStr(FILE*,char *); #define SKIPTABSPACES(sptr) while ( *sptr == ' ' || *sptr == '\t' ) (sptr)++ extern int lInclude; extern int *aCondCompile, nCondCompile; extern int nline; extern DEFINES *aDefnew ; #define BUFF_SIZE 2048 #define STR_SIZE 2048 #define INITIAL_ACOM_SIZE 200 extern COMMANDS *aCommnew ; extern TRANSLATES *aTranslates ; PATHNAMES *_pIncludePath = NULL; void AddSearchPath( char *, PATHNAMES * * ); /* add pathname to a search list */ int main (int argc,char* argv[]) { FILE *handl_i,*handl_o; char szFileName[ _POSIX_PATH_MAX ]; FILENAME *pFileName =NULL; int iArg = 1; while( iArg < argc ) { if( IS_OPT_SEP(argv[ iArg ][ 0 ])) { switch( argv[ iArg ][ 1 ] ) { case 'd': case 'D': /* defines a Lex #define from the command line */ { unsigned int i = 0; char * szDefText = strdup( argv[ iArg ] + 2 ); while( i < strolen( szDefText ) && szDefText[ i ] != '=' ) i++; if( szDefText[ i ] != '=' ) AddDefine( szDefText, 0 ); else { szDefText[ i ] = 0; AddDefine( szDefText, szDefText + i + 1 ); } free( szDefText ); } break; case 'i': case 'I': AddSearchPath( argv[ iArg ]+2, &_pIncludePath ); break; default: printf( "\nInvalid command line option: %s\n", &argv[ iArg ][ 1 ] ); break; } } else pFileName =SplitFilename( argv[ iArg ] ); iArg++; } if( pFileName ) { if( !pFileName->extension ) pFileName->extension =".prg"; MakeFilename( szFileName, pFileName ); if ((handl_i = fopen(szFileName, "r")) == NULL) { printf("\nCan't open %s\n",szFileName); return 1; } } else { printf("\nFile name absent\n"); return 1; } pFileName->extension =".ppo"; MakeFilename( szFileName, pFileName ); if ((handl_o = fopen(szFileName, "wt" )) == NULL) { printf("\nCan't open %s\n",szFileName); return 1; } aCondCompile = (int*) _xgrab( sizeof(int) * 5 ); aDefnew = ( DEFINES * ) _xgrab( sizeof(DEFINES) * 50 ); aCommnew = ( COMMANDS * ) _xgrab( sizeof(COMMANDS) * INITIAL_ACOM_SIZE ); aTranslates = ( TRANSLATES * ) _xgrab( sizeof(TRANSLATES) * 50 ); Hp_Parse(handl_i,handl_o ); fclose(handl_i); fclose(handl_o); /* for (int i=0;i= 0 ) { if ( !lInclude ) nline++; lens += rdlen; if( sLine[lens-1] == ';' ) { lContinue = 1; lens--; lens--; while ( sLine[lens] == ' ' || sLine[lens] == '\t' ) lens--; if ( sLine[lens+1] == ' ' || sLine[lens+1] == '\t' ) lens++; sLine[++lens] = '\0'; } else { lContinue = 0; lens=0; } if ( *sLine != '\0' && !lContinue ) { ptr = sLine; SKIPTABSPACES( ptr ); if ( *ptr == '#' ) { if ( (rezParse=ParseDirective( ptr+1 )) > 0 ) { if ( !lInclude ) printf ( "\nError number %u in line %u\n", rezParse, nline ); return rezParse; } *sLine = '\0'; } else { if ( nCondCompile==0 || aCondCompile[nCondCompile-1]) { if ( (rezParse = ParseExpression( ptr, sOutLine)) > 0 ) { printf ( "\nError number %u in line %u\n", rezParse, nline ); return rezParse; } } else *sLine = '\0'; } } if(!lInclude) { if( lContinue ) WrStr(handl_o,"\n"); else WrStr(handl_o,sLine); } } return 0; } /* * Split given filename into path, name and extension */ FILENAME *SplitFilename( char *szFilename ) { FILENAME *pName =(FILENAME *)OurMalloc( sizeof(FILENAME) ); int iLen = strlen(szFilename); int iSlashPos, iDotPos; int iPos; pName->path =pName->name =pName->extension =NULL; iSlashPos =iLen-1; iPos =0; while( iSlashPos >= 0 && !IS_PATH_SEP(szFilename[ iSlashPos ]) ) --iSlashPos; if( iSlashPos == 0 ) { /* root path -> \filename */ pName->_buffer[ 0 ] =PATH_DELIMITER[ 0 ]; pName->_buffer[ 1 ] ='\x0'; pName->path =pName->_buffer; iPos =2; /* first free position after the slash */ } else if( iSlashPos > 0 ) { /* path with separator -> path\filename */ memcpy( pName->_buffer, szFilename, iSlashPos ); pName->_buffer[ iSlashPos ] ='\x0'; pName->path =pName->_buffer; iPos =iSlashPos +1; /* first free position after the slash */ } iDotPos =iLen-1; while( iDotPos > iSlashPos && szFilename[ iDotPos ] != '.' ) --iDotPos; if( (iDotPos-iSlashPos) > 1 ) { /* the dot was found * and there is at least one character between a slash and a dot */ if( iDotPos == iLen-1 ) { /* the dot is the last character -use it as extension name */ pName->extension =pName->_buffer+iPos; pName->_buffer[ iPos++ ] ='.'; pName->_buffer[ iPos++ ] ='\x0'; } else { pName->extension =pName->_buffer+iPos; /* copy rest of the string with terminating ZERO character */ memcpy( pName->extension, szFilename+iDotPos+1, iLen-iDotPos ); iPos +=iLen-iDotPos; } } else /* there is no dot in the filename or it is '.filename' */ iDotPos =iLen; pName->name =pName->_buffer+iPos; memcpy( pName->name, szFilename+iSlashPos+1, iDotPos-iSlashPos-1 ); pName->name[ iDotPos-iSlashPos-1 ] ='\x0'; return pName; } /* * This function joins path, name and extension into a string with a filename */ char *MakeFilename( char *szFileName, FILENAME *pFileName ) { if( pFileName->path && pFileName->path[ 0 ] ) { /* we have not empty path specified */ int iLen =strlen(pFileName->path); strcpy( szFileName, pFileName->path ); /* if the path is a root directory then we don't need to add path separator */ if( !(IS_PATH_SEP(pFileName->path[ 0 ]) && pFileName->path[ 0 ] == '\x0') ) { /* add the path separator only in cases: * when a name doesn't start with it * when the path doesn't end with it */ if( !( IS_PATH_SEP(pFileName->name[ 0 ]) || IS_PATH_SEP(pFileName->path[ iLen-1 ]) ) ) { szFileName[ iLen++ ] =PATH_DELIMITER[ 0 ]; szFileName[ iLen ] ='\x0'; } } strcpy( szFileName+iLen, pFileName->name ); } else strcpy( szFileName, pFileName->name ); if( pFileName->extension ) { int iLen =strlen(szFileName); if( !(pFileName->extension[ 0 ] == '.' || pFileName->name[ iLen-1 ] == '.') ) { /* add extension separator only when extansion doesn't contain it */ szFileName[ iLen++ ] ='.'; szFileName[ iLen ] ='\x0'; } strcpy( szFileName+iLen, pFileName->extension ); } return szFileName; } /* * Function that adds specified path to the list of pathnames to search */ void AddSearchPath( char *szPath, PATHNAMES * *pSearchList ) { PATHNAMES *pPath = *pSearchList; if( pPath ) { while( pPath->pNext ) pPath = pPath->pNext; pPath->pNext = ( PATHNAMES * ) OurMalloc( sizeof( PATHNAMES ) ); pPath = pPath->pNext; } else { *pSearchList =pPath =(PATHNAMES *)OurMalloc( sizeof(PATHNAMES) ); } pPath->pNext = NULL; pPath->szPath = szPath; } void * OurMalloc( LONG lSize ) { void * pMem = malloc( lSize ); if( ! pMem ) printf( "\nCan't allocate memory!\n" ); return pMem; } void * _xgrab( ULONG ulSize ) /* allocates fixed memory */ { void * pMem = malloc( ulSize ); if( ! pMem ) { printf( "\n_xgrab error: can't allocate memory!\n" ); exit( 1 ); } return pMem; } void * _xrealloc( void * pMem, ULONG ulSize ) /* reallocates memory */ { void * pResult = realloc( pMem, ulSize ); if( ! pResult ) { printf( "\n_xrealloc error: can't reallocate memory!\n" ); exit( 1 ); } return pResult; } void _xfree( void * pMem ) /* frees fixed memory */ { if( pMem ) free( pMem ); }