summaryrefslogtreecommitdiff
path: root/src/backen.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/backen.c')
-rw-r--r--src/backen.c108
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
4int mystrcmp( void *a, void *b ) {
5 return strncmp( a, *(char**)b, strlen( a ));
6}
7
8int mystrcmp2( void *a, void *b ) {
9 return strcmp( *(char**)a, *(char**)b);
10}
11
12int 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
104out:
105 unmap_file( &streetf );
106 unmap_file( &geomahf );
107 return 0;
108}