#include "mystdlib.h" #include #include #include int find_offset( const void *key, const void *line ) { size_t l = strlen( *(char**)key ); return strncmp( *(char**)key, *(char**)line, l ); } int qsort_cmp( const void *a, const void *b ) { return strcmp( *(char**)a, *(char**)b ); } int main( int argc, char ** args ) { MAP coords = map_file( args[1], 1 ); int i, l, lines; char *p, **offsets, *input = malloc(1024); size_t input_length = 1024; if( !coords ) exit( 111 ); p = (char *)coords->addr; for ( i=0, lines=0; isize; ++i ) if( p[i] == 0x0a ) { ++lines; p[i] = 0; } offsets = malloc( lines * sizeof(char*)); if( !offsets ) exit( 111 ); offsets[0] = p; l = 1; for ( i=0, lines=0; isize; ++i ) if( !p[i] ) offsets[l++] = p+i+1; l--; qsort(offsets, l, sizeof(char*), qsort_cmp ); while( getline( &input, &input_length, stdin ) >= 0 ) { char **coord_line = bsearch( input, offsets, l, sizeof(char*), find_offset ); printf( "%s\n", *coord_line + strlen( input ) ); } return 0; }