diff options
Diffstat (limited to 'src/backen.c')
| -rw-r--r-- | src/backen.c | 108 |
1 files changed, 0 insertions, 108 deletions
diff --git a/src/backen.c b/src/backen.c deleted file mode 100644 index b93c721..0000000 --- a/src/backen.c +++ /dev/null | |||
| @@ -1,108 +0,0 @@ | |||
| 1 | #include <string.h> | ||
| 2 | #include "mystdlib.h" | ||
| 3 | |||
| 4 | int mystrcmp( void *a, void *b ) { | ||
| 5 | return strncmp( a, *(char**)b, strlen( a )); | ||
| 6 | } | ||
| 7 | |||
| 8 | int mystrcmp2( void *a, void *b ) { | ||
| 9 | return strcmp( *(char**)a, *(char**)b); | ||
| 10 | } | ||
| 11 | |||
| 12 | int main( int argc, char **argv ) { | ||
| 13 | char path[32]; /* files/file_XXXXX */ | ||
| 14 | int streetnum = 0, geomapnum = 0, geomahnum = 0, d = 0, i, j, k, run = 1; | ||
| 15 | char *geomahs[15000000]; | ||
| 16 | char *streets[400000]; | ||
| 17 | MAP maps[11]; int mapoffs[11]; | ||
| 18 | MAP streetf = map_file( "lists/streetlist", 1); | ||
| 19 | MAP geomahf = map_file( "lists/geohnrlist", 1); | ||
| 20 | unsigned char lookup[1024], **geokord; /* PLZ, Streetname, Hnr */ | ||
| 21 | |||
| 22 | streets[streetnum++] = streetf->addr; | ||
| 23 | for( i=0; i<streetf->size; ++i ) | ||
| 24 | if( streetf->addr[i] == 0 ) streets[streetnum++] = streetf->addr+i+1; | ||
| 25 | |||
| 26 | geomahs[geomahnum++] = geomahf->addr; | ||
| 27 | for( i=0; i<geomahf->size; ++i ) | ||
| 28 | if( geomahf->addr[i] == 0 ) geomahs[geomahnum++] = geomahf->addr+i+1; | ||
| 29 | |||
| 30 | qsort( geomahs, geomahnum, sizeof(char*), mystrcmp2 ); | ||
| 31 | |||
| 32 | i = 0; | ||
| 33 | while( run ) { | ||
| 34 | for(j=0; j<11; ++j) { | ||
| 35 | sprintf( path, "files/file_%05X", i++); | ||
| 36 | maps[j] = map_file( path, 1 ); mapoffs[j] = 0; | ||
| 37 | } | ||
| 38 | |||
| 39 | if( !maps[0] ) goto out; | ||
| 40 | |||
| 41 | for(j=0;j<maps[0]->size;++j) { | ||
| 42 | char ch; | ||
| 43 | |||
| 44 | for( k=0; k<11; ++k) { | ||
| 45 | unsigned char *end; | ||
| 46 | int sid,x ; | ||
| 47 | switch(k) { | ||
| 48 | case 0: | ||
| 49 | printf( "%02X\t", maps[k]->addr[mapoffs[k]++]); | ||
| 50 | break; | ||
| 51 | case 5: | ||
| 52 | sid = strtol( maps[k]->addr+mapoffs[k], &end, 10); | ||
| 53 | if( end > maps[k]->addr+mapoffs[k] ) { | ||
| 54 | // no hnr, end+1 points to "" afterwards | ||
| 55 | if( !*end ) end--; | ||
| 56 | |||
| 57 | printf( "%s\t%s\t", streets[sid], end+1 ); | ||
| 58 | end = lookup + 6 + sprintf( lookup+6, "%s\t%s", streets[sid], end + 1 ); | ||
| 59 | while( isalpha( (int)end[-1] )) *--end = 0; | ||
| 60 | *end++ = '\t'; *end = 0; | ||
| 61 | } else { | ||
| 62 | printf( "\t\t" ); lookup[6] = lookup[7] = '\t'; lookup[8] = 0; | ||
| 63 | } | ||
| 64 | while( maps[k]->addr[mapoffs[k]++]); | ||
| 65 | break; | ||
| 66 | case 10: | ||
| 67 | if( !maps[k]->addr[mapoffs[k]] ) | ||
| 68 | printf( "\t\t" ); | ||
| 69 | else if( !strchr(maps[k]->addr+mapoffs[k], 9)) | ||
| 70 | printf( "%s\t\t", maps[k]->addr+mapoffs[k] ); | ||
| 71 | else | ||
| 72 | printf( "%s\t", maps[k]->addr+mapoffs[k] ); | ||
| 73 | while( maps[k]->addr[mapoffs[k]++]); | ||
| 74 | break; | ||
| 75 | case 7: | ||
| 76 | for( x=0; (x<5) && (maps[k]->addr+mapoffs[k])[x]; ++x ) | ||
| 77 | lookup[x] = (maps[k]->addr+mapoffs[k])[x]; | ||
| 78 | for( ; x<5; ++x ) | ||
| 79 | lookup[x] = '.'; | ||
| 80 | lookup[x] = '\t'; | ||
| 81 | default: | ||
| 82 | while( maps[k]->addr[mapoffs[k]] == '\t' ) mapoffs[k]++; | ||
| 83 | while( (ch = maps[k]->addr[mapoffs[k]++] )) | ||
| 84 | if( ch < 32 ) | ||
| 85 | putchar( 32 ); | ||
| 86 | else | ||
| 87 | putchar( ch ); | ||
| 88 | putchar( '\t' ); | ||
| 89 | break; | ||
| 90 | } | ||
| 91 | } | ||
| 92 | /* postprocessing */ | ||
| 93 | |||
| 94 | if( (geokord = (char**)bsearch( lookup, geomahs, geomahnum, sizeof(char *), mystrcmp ) ) ) { | ||
| 95 | printf( "%s", *geokord+strlen(lookup)+1 ); | ||
| 96 | } else { | ||
| 97 | putchar('\t'); putchar('\t'); | ||
| 98 | } | ||
| 99 | putchar( 10 ); | ||
| 100 | } | ||
| 101 | for(j=0; j<11; ++j) unmap_file( &maps[j] ); | ||
| 102 | } | ||
| 103 | |||
| 104 | out: | ||
| 105 | unmap_file( &streetf ); | ||
| 106 | unmap_file( &geomahf ); | ||
| 107 | return 0; | ||
| 108 | } | ||
