diff options
author | Alan Mishchenko <alanmi@berkeley.edu> | 2011-12-17 13:57:56 -0800 |
---|---|---|
committer | Alan Mishchenko <alanmi@berkeley.edu> | 2011-12-17 13:57:56 -0800 |
commit | cd4752b565b8ced81d1216ada390fcd024d8e143 (patch) | |
tree | 38361b5bd6851e7209cc787b7b6c561d766ca144 /src | |
parent | 024f9a2b13b69a8205626e9281d7b4a07d973022 (diff) | |
download | abc-cd4752b565b8ced81d1216ada390fcd024d8e143.tar.gz abc-cd4752b565b8ced81d1216ada390fcd024d8e143.tar.bz2 abc-cd4752b565b8ced81d1216ada390fcd024d8e143.zip |
Added utility to sort lines in a file alphabetically.
Diffstat (limited to 'src')
-rw-r--r-- | src/misc/extra/extraUtilFile.c | 97 |
1 files changed, 97 insertions, 0 deletions
diff --git a/src/misc/extra/extraUtilFile.c b/src/misc/extra/extraUtilFile.c index 2ddec21e..a8542da4 100644 --- a/src/misc/extra/extraUtilFile.c +++ b/src/misc/extra/extraUtilFile.c @@ -520,6 +520,103 @@ char * Extra_StringAppend( char * pStrGiven, char * pStrAdd ) return pTemp; } +/**Function************************************************************* + + Synopsis [String comparison procedure.] + + Description [] + + SideEffects [] + + SeeAlso [] + +***********************************************************************/ +int Extra_StringCompare( const char * pp1, const char * pp2 ) +{ + return strcmp(*(char **)pp1, *(char **)pp2); +} + +/**Function************************************************************* + + Synopsis [Sorts lines in the file alphabetically.] + + Description [] + + SideEffects [] + + SeeAlso [] + +***********************************************************************/ +void Extra_FileSort( char * pFileName, char * pFileNameOut ) +{ + FILE * pFile; + char * pContents; + char ** pLines; + int i, nLines, Begin; + pFile = fopen( pFileName, "rb" ); + if ( pFile == NULL ) + { + printf( "Extra_FileSort(): Cannot open file \"%s\".\n", pFileName ); + return; + } + pContents = Extra_FileRead( pFile ); + fclose( pFile ); + if ( pContents == NULL ) + { + printf( "Extra_FileSort(): Cannot read contents of file \"%s\".\n", pFileName ); + return; + } + // count end of lines + for ( nLines = 0, i = 0; pContents[i]; i++ ) + nLines += (pContents[i] == '\n'); + // break the file into lines + pLines = (char **)malloc( sizeof(char *) * nLines ); + Begin = 0; + for ( nLines = 0, i = 0; pContents[i]; i++ ) + if ( pContents[i] == '\n' ) + { + pContents[i] = 0; + pLines[nLines++] = pContents + Begin; + Begin = i + 1; + } + // sort the lines + qsort( pLines, nLines, sizeof(char *), Extra_StringCompare ); + // write a new file + pFile = fopen( pFileNameOut, "wb" ); + for ( i = 0; i < nLines; i++ ) + if ( pLines[i][0] ) + fprintf( pFile, "%s\n", pLines[i] ); + fclose( pFile ); + // cleanup + free( pLines ); + free( pContents ); + // report the result + printf( "The file after sorting is \"%s\".\n", pFileNameOut ); +} + + +/**Function************************************************************* + + Synopsis [] + + Description [] + + SideEffects [] + + SeeAlso [] + +***********************************************************************/ +/* +int main( int argc, char ** argv ) +{ + if ( argc == 2 ) + Extra_FileSort( argv[1], Extra_FileNameAppend(argv[1], "_sorted") ); + else + printf( "%s: Wrong number of command line arguments.\n", argv[0] ); + return 1; +} +*/ + /*---------------------------------------------------------------------------*/ /* Definition of internal functions */ /*---------------------------------------------------------------------------*/ |