diff options
| author | Dirk Engling <erdgeist@erdgeist.org> | 2014-02-20 22:42:56 +0100 |
|---|---|---|
| committer | Dirk Engling <erdgeist@erdgeist.org> | 2014-02-20 22:42:56 +0100 |
| commit | 046857dfb88f05e6b310fe9ef07b9f2d3ac5922d (patch) | |
| tree | 9ce854f9572168c3ec1fe6751276430fa4a79cd9 /src/export | |
| parent | 64c85dfc1d3b546dd4b5f84168e9256817f3a741 (diff) | |
Restructure project, make names more clear
Diffstat (limited to 'src/export')
| -rw-r--r-- | src/export/convert_coords.c | 40 | ||||
| -rw-r--r-- | src/export/extract_version_2.c | 131 | ||||
| -rw-r--r-- | src/export/extract_version_3.c | 61 | ||||
| -rw-r--r-- | src/export/map_coords.c | 62 | ||||
| -rw-r--r-- | src/export/mystdlib.c | 56 | ||||
| -rw-r--r-- | src/export/mystdlib.h | 32 | ||||
| -rw-r--r-- | src/export/split_version_2.c | 42 |
7 files changed, 424 insertions, 0 deletions
diff --git a/src/export/convert_coords.c b/src/export/convert_coords.c new file mode 100644 index 0000000..37d780a --- /dev/null +++ b/src/export/convert_coords.c | |||
| @@ -0,0 +1,40 @@ | |||
| 1 | #include <stdio.h> | ||
| 2 | #include <stdlib.h> | ||
| 3 | #include <math.h> | ||
| 4 | int main(int argc, char *argv[]) | ||
| 5 | { | ||
| 6 | double x, y; | ||
| 7 | char buf[64]; | ||
| 8 | int in; | ||
| 9 | while( fgets( buf, sizeof(buf), stdin ) ) | ||
| 10 | { | ||
| 11 | if( sscanf( buf, "%lf %lf", &x, &y ) == 2 ) { | ||
| 12 | double R = 6365000; | ||
| 13 | double fe = 5200000; | ||
| 14 | double fn = 1200000; | ||
| 15 | double ph0 = 0.5235977; // 30deg | ||
| 16 | double ph1 = 0.7853980; // 45deg | ||
| 17 | double ph2 = 0.9599309; // 55deg | ||
| 18 | double l0 = 0.1745329; // 10deg | ||
| 19 | |||
| 20 | double xs = (x-fe)/R; | ||
| 21 | double ys = (y-fn)/R; | ||
| 22 | double ph0_s = 0.25*M_PI+0.5*ph0; | ||
| 23 | double ph1_s = 0.25*M_PI+0.5*ph1; | ||
| 24 | double ph2_s = 0.25*M_PI+0.5*ph2; | ||
| 25 | |||
| 26 | double n = log(cos(ph1)/cos(ph2))/log(tan(ph2_s)/tan(ph1_s)); | ||
| 27 | double F = cos(ph1)*pow(tan(ph1_s),n)/n; | ||
| 28 | double r0 = F / pow(tan(ph0_s),n); | ||
| 29 | double r = sqrt(pow(xs,2)+pow(r0-ys,2)); | ||
| 30 | double th = atan(xs/(r0-ys)); | ||
| 31 | |||
| 32 | double lon = l0+th/n; | ||
| 33 | double lat = 2.0*atan(pow(F/r,1.0/n))-0.5*M_PI; | ||
| 34 | |||
| 35 | printf("%lf\t%lf\n", lat*180.0/M_PI, lon*180.0/M_PI); | ||
| 36 | } else | ||
| 37 | printf("\t\n"); | ||
| 38 | } | ||
| 39 | return 0; | ||
| 40 | } | ||
diff --git a/src/export/extract_version_2.c b/src/export/extract_version_2.c new file mode 100644 index 0000000..fe85252 --- /dev/null +++ b/src/export/extract_version_2.c | |||
| @@ -0,0 +1,131 @@ | |||
| 1 | #include <fcntl.h> | ||
| 2 | #include "mystdlib.h" | ||
| 3 | #include <stdlib.h> | ||
| 4 | #include <string.h> | ||
| 5 | #include <stdint.h> | ||
| 6 | #include <unistd.h> | ||
| 7 | |||
| 8 | /* lha header: | ||
| 9 | |||
| 10 | 00 Header length | ||
| 11 | 01 Header checksum [02-length] | ||
| 12 | 02 0x2d ('-') | ||
| 13 | 03 0x6c ('l') | ||
| 14 | 04 0x68 ('h') | ||
| 15 | 05 0x?? ('0' or '5') unsure | ||
| 16 | 06 0x2d ('-') | ||
| 17 | 07 0x?? LSB of compressed size | ||
| 18 | 08 0x?? .. | ||
| 19 | 09 0x00 .. | ||
| 20 | 10 0x00 MSB of compressed size, i.e. 0 | ||
| 21 | .. | ||
| 22 | 21 Length of path name | ||
| 23 | |||
| 24 | |||
| 25 | */ | ||
| 26 | |||
| 27 | static uint8_t mantra_in[] = { 0x68, 0x35, 0x2d, 0x6c }; | ||
| 28 | |||
| 29 | int main( int args, char **argv ) | ||
| 30 | { | ||
| 31 | int filenum = 0, run = 1; | ||
| 32 | size_t offset = 0, oldoffset = -1, reported = 0, enc_len = 32; | ||
| 33 | uint8_t mantra[4], id0, id5, *mappedfile; | ||
| 34 | MAP map; | ||
| 35 | |||
| 36 | /* For streets we do have a enc_len of 34 */ | ||
| 37 | while( run ) { | ||
| 38 | switch( getopt( args, argv, ":e:" ) ) { | ||
| 39 | case -1 : run = 0; break; | ||
| 40 | case 'e': | ||
| 41 | enc_len = atol( optarg ); | ||
| 42 | break; | ||
| 43 | default: | ||
| 44 | fputs( "Syntax: %s [-e encrypted_length (default: 32, for streets 34 or 0)] path-to-teiln.dat", stderr ); exit( 1 ); | ||
| 45 | break; | ||
| 46 | } | ||
| 47 | } | ||
| 48 | run = 1; | ||
| 49 | |||
| 50 | if( optind == args ) | ||
| 51 | { fputs( "Missing filename.", stderr ); exit( 1 ); } | ||
| 52 | |||
| 53 | map = map_file( argv[optind], 1 ); | ||
| 54 | mappedfile = map->addr; | ||
| 55 | |||
| 56 | mantra[0] = mantra_in[0] ^ mappedfile[4]; | ||
| 57 | mantra[1] = mantra_in[1] ^ mappedfile[5]; | ||
| 58 | mantra[2] = mantra_in[2] ^ mappedfile[2]; | ||
| 59 | mantra[3] = mantra_in[3] ^ mappedfile[3]; | ||
| 60 | |||
| 61 | id0 = mappedfile[0]; | ||
| 62 | id5 = mappedfile[5]; | ||
| 63 | |||
| 64 | while( run ) | ||
| 65 | { | ||
| 66 | while( ( offset < map->size ) && ( | ||
| 67 | ( mappedfile[ offset + 0 ] != id0 ) || | ||
| 68 | ( mappedfile[ offset + 2 ] != ( '-' ^ mantra[2] )) || | ||
| 69 | ( mappedfile[ offset + 3 ] != ( 'l' ^ mantra[3] )) || | ||
| 70 | ( mappedfile[ offset + 4 ] != ( 'h' ^ mantra[0] )) || | ||
| 71 | ( mappedfile[ offset + 5 ] != id5 ) || | ||
| 72 | ( mappedfile[ offset + 6 ] != ( '-' ^ mantra[2] )) | ||
| 73 | ) ) offset++; | ||
| 74 | |||
| 75 | // printf( "Found an appropriate offset at: %zd\n", offset ); | ||
| 76 | |||
| 77 | if( reported < ( offset * 10 ) / map->size ) | ||
| 78 | { | ||
| 79 | reported++; | ||
| 80 | printf( "%zd%% ", 10 * reported ); | ||
| 81 | fflush( stdout ); | ||
| 82 | } | ||
| 83 | |||
| 84 | if( offset == map->size ) | ||
| 85 | run = 0; | ||
| 86 | |||
| 87 | if( oldoffset != -1 ) | ||
| 88 | { | ||
| 89 | uint8_t *mf = mappedfile + oldoffset, df[128]; | ||
| 90 | size_t filename_len, header_len; | ||
| 91 | char filename_template[32], filename[32]; | ||
| 92 | int i; | ||
| 93 | |||
| 94 | /* De-"crypt" obfuscation to our header copy */ | ||
| 95 | for( i=0; i<enc_len; ++i) | ||
| 96 | df[i] = mf[i] ^ mantra[i%4]; | ||
| 97 | |||
| 98 | /* Get values from LHA header */ | ||
| 99 | header_len = df[0] + 2; | ||
| 100 | filename_len = df[21]; | ||
| 101 | |||
| 102 | /* Copy rest of header, so we can checksum */ | ||
| 103 | for( i=enc_len; i<header_len; ++i) | ||
| 104 | df[i] = mf[i]; | ||
| 105 | |||
| 106 | /* Make up new sequental file name */ | ||
| 107 | snprintf( filename_template, sizeof(filename_template), "%%0%dd.lha", (int)filename_len ); | ||
| 108 | snprintf( filename, sizeof( filename ), filename_template, filenum++ ); | ||
| 109 | memcpy( ((uint8_t*)df) + 22, filename, filename_len); | ||
| 110 | |||
| 111 | /* Recalculate checksum with new file name */ | ||
| 112 | df[1] = 0; for( i=2; i<header_len; ++i) df[1] += df[i]; | ||
| 113 | |||
| 114 | /* Open file and dump our de-"crypted" header and then rest of file */ | ||
| 115 | i = open( filename, O_CREAT | O_TRUNC | O_WRONLY, 0644 ); | ||
| 116 | if( enc_len > header_len ) { | ||
| 117 | write( i, df, enc_len ); | ||
| 118 | write( i, mf + enc_len, offset - oldoffset - enc_len ); | ||
| 119 | } else { | ||
| 120 | write( i, df, header_len ); | ||
| 121 | write( i, mf + header_len, offset - oldoffset - header_len ); | ||
| 122 | } | ||
| 123 | close( i ); | ||
| 124 | } | ||
| 125 | oldoffset = offset; | ||
| 126 | offset++; | ||
| 127 | } | ||
| 128 | |||
| 129 | unmap_file( &map ); | ||
| 130 | return 0; | ||
| 131 | } | ||
diff --git a/src/export/extract_version_3.c b/src/export/extract_version_3.c new file mode 100644 index 0000000..fef4241 --- /dev/null +++ b/src/export/extract_version_3.c | |||
| @@ -0,0 +1,61 @@ | |||
| 1 | #include <stdlib.h> | ||
| 2 | #include <stdio.h> | ||
| 3 | #include <unistd.h> | ||
| 4 | #include <fcntl.h> | ||
| 5 | #include <string.h> | ||
| 6 | #include <zlib.h> | ||
| 7 | #include "mystdlib.h" | ||
| 8 | |||
| 9 | #define XORLEN (29) | ||
| 10 | #define HUGEBLOCK (1024*1024) | ||
| 11 | |||
| 12 | int main(int argc, char **argv) { | ||
| 13 | MAP in = map_file( argv[1], 1 ); | ||
| 14 | |||
| 15 | unsigned const char xorkey [XORLEN] = "Just for Fun. Linus Torvalds."; | ||
| 16 | unsigned char input [XORLEN]; | ||
| 17 | unsigned char output [HUGEBLOCK]; | ||
| 18 | char respath[32]; /* file_XXXXX\0 */ | ||
| 19 | int i, zres = 0, filenum = 0, resfile; | ||
| 20 | size_t offs = 0, reported = 0; | ||
| 21 | |||
| 22 | z_stream z; memset( &z, 0, sizeof(z)); | ||
| 23 | |||
| 24 | while( offs < in->size - XORLEN ) { | ||
| 25 | for( i=0; i<XORLEN; ++i ) input[i] = in->addr[offs+i] ^ xorkey[i]; | ||
| 26 | z.next_in = input; z.avail_in = XORLEN; | ||
| 27 | z.next_out = output; z.avail_out = HUGEBLOCK; | ||
| 28 | inflateInit( &z ); zres = inflate( &z, Z_NO_FLUSH ); | ||
| 29 | if( (zres != Z_OK) && (zres != Z_STREAM_END) ) | ||
| 30 | goto error_continue; | ||
| 31 | |||
| 32 | z.next_in = in->addr + offs + XORLEN; z.avail_in = in->size - offs - XORLEN; | ||
| 33 | while( zres == Z_OK ) zres = inflate( &z, Z_NO_FLUSH ); | ||
| 34 | |||
| 35 | if( zres != Z_STREAM_END ) { | ||
| 36 | error_continue: | ||
| 37 | inflateEnd(&z); memset( &z, 0, sizeof(z)); | ||
| 38 | offs++; | ||
| 39 | continue; | ||
| 40 | } | ||
| 41 | |||
| 42 | sprintf( respath, "file_%05X", filenum++ ); | ||
| 43 | resfile = open( respath, O_RDWR | O_CREAT, 0644 ); | ||
| 44 | if( resfile < 0 ) { | ||
| 45 | fprintf( stderr, "Could not open output file %s\n", respath ); | ||
| 46 | exit(1); | ||
| 47 | } | ||
| 48 | write( resfile, output, z.total_out ); | ||
| 49 | close( resfile ); | ||
| 50 | offs += z.total_in; | ||
| 51 | |||
| 52 | if( reported < ( offs * 10 ) / in->size ) { | ||
| 53 | reported++; | ||
| 54 | printf( "%zd%% ", 10 * reported ); | ||
| 55 | fflush( stdout ); | ||
| 56 | } | ||
| 57 | |||
| 58 | inflateEnd(&z); memset( &z, 0, sizeof(z)); | ||
| 59 | } | ||
| 60 | unmap_file(&in); | ||
| 61 | } | ||
diff --git a/src/export/map_coords.c b/src/export/map_coords.c new file mode 100644 index 0000000..b46f1cf --- /dev/null +++ b/src/export/map_coords.c | |||
| @@ -0,0 +1,62 @@ | |||
| 1 | #define _WITH_GETLINE | ||
| 2 | #include "mystdlib.h" | ||
| 3 | #include <stdlib.h> | ||
| 4 | #include <stdio.h> | ||
| 5 | #include <string.h> | ||
| 6 | #include <ctype.h> | ||
| 7 | |||
| 8 | int find_offset( const void *key, const void *line ) | ||
| 9 | { | ||
| 10 | size_t l = strlen( (char*)key ); | ||
| 11 | return strncmp( (char*)key, *(char**)line, l ); | ||
| 12 | } | ||
| 13 | |||
| 14 | int qsort_cmp( const void *a, const void *b ) | ||
| 15 | { | ||
| 16 | return strcmp( *(char**)a, *(char**)b ); | ||
| 17 | } | ||
| 18 | |||
| 19 | int main( int argc, char ** args ) | ||
| 20 | { | ||
| 21 | MAP coords = map_file( args[1], 1 ); | ||
| 22 | int i, l, lines; | ||
| 23 | char *p, **offsets, *input = malloc(1024); | ||
| 24 | ssize_t ll; | ||
| 25 | size_t input_length = 1024; | ||
| 26 | |||
| 27 | if( !coords ) exit( 111 ); | ||
| 28 | p = (char *)coords->addr; | ||
| 29 | for ( i=0, lines=0; i<coords->size; ++i ) | ||
| 30 | if( p[i] == 0x00 ) | ||
| 31 | ++lines; | ||
| 32 | |||
| 33 | offsets = malloc( lines * sizeof(char*)); | ||
| 34 | if( !offsets ) exit( 111 ); | ||
| 35 | |||
| 36 | offsets[0] = p; l = 1; | ||
| 37 | for ( i=0; i<coords->size; ++i ) | ||
| 38 | if( p[i] == 0x00 ) | ||
| 39 | offsets[l++] = p+i+1; | ||
| 40 | |||
| 41 | l--; qsort(offsets, l, sizeof(char*), qsort_cmp ); | ||
| 42 | |||
| 43 | while( ( ll = getline( &input, &input_length, stdin ) ) >= 0 ) | ||
| 44 | { | ||
| 45 | char **coord_line; | ||
| 46 | input[ll-1]='\t'; | ||
| 47 | coord_line = bsearch( input, offsets, l, sizeof(char*), find_offset ); | ||
| 48 | if( !coord_line && ll > 2 && isalpha( input[ll-2] ) ) | ||
| 49 | { | ||
| 50 | input[ll-2] = '\t'; input[ll-1]=0; | ||
| 51 | ll--; | ||
| 52 | coord_line = bsearch( input, offsets, l, sizeof(char*), find_offset ); | ||
| 53 | } | ||
| 54 | |||
| 55 | if( coord_line ) | ||
| 56 | printf( "%s\n", *coord_line + ll ); | ||
| 57 | else | ||
| 58 | puts( "\t" ); | ||
| 59 | } | ||
| 60 | |||
| 61 | return 0; | ||
| 62 | } | ||
diff --git a/src/export/mystdlib.c b/src/export/mystdlib.c new file mode 100644 index 0000000..17f123b --- /dev/null +++ b/src/export/mystdlib.c | |||
| @@ -0,0 +1,56 @@ | |||
| 1 | #include <sys/types.h> | ||
| 2 | #include <sys/stat.h> | ||
| 3 | #include <sys/mman.h> | ||
| 4 | #include <unistd.h> | ||
| 5 | #include <fcntl.h> | ||
| 6 | #include <stdio.h> | ||
| 7 | #include <string.h> | ||
| 8 | #include <stdlib.h> | ||
| 9 | |||
| 10 | #include "mystdlib.h" | ||
| 11 | |||
| 12 | MAP map_file( char *filename, int readonly ) | ||
| 13 | { | ||
| 14 | struct stat fstatus; | ||
| 15 | MAP map = (MAP)malloc( sizeof( *map )); | ||
| 16 | |||
| 17 | if( map ) | ||
| 18 | { | ||
| 19 | memset( map, 0, sizeof( *map )); | ||
| 20 | |||
| 21 | if( ( map->fh = open( filename, readonly ? O_RDONLY : O_RDWR ) ) >= 0 ) | ||
| 22 | { | ||
| 23 | fstat( map->fh, &fstatus ); | ||
| 24 | if( ( map->addr = mmap( NULL, map->size = (size_t)fstatus.st_size, | ||
| 25 | PROT_READ | ( readonly ? 0 : PROT_WRITE), (readonly ? MAP_PRIVATE : MAP_SHARED), map->fh, 0) ) == MAP_FAILED ) | ||
| 26 | { | ||
| 27 | fprintf( stderr, "Mapping file '%s' failed\n", filename ); | ||
| 28 | close( map->fh ); free( map ); map = NULL; | ||
| 29 | } | ||
| 30 | } else { | ||
| 31 | fprintf( stderr, "Couldn't open file: '%s'\n", filename ); | ||
| 32 | free( map ); map = NULL; | ||
| 33 | } | ||
| 34 | } else { | ||
| 35 | fputs( "Couldn't allocate memory", stderr ); | ||
| 36 | } | ||
| 37 | |||
| 38 | return map; | ||
| 39 | } | ||
| 40 | |||
| 41 | void unmap_file ( MAP *pMap ) | ||
| 42 | { | ||
| 43 | if( !pMap || !*pMap ) return; | ||
| 44 | munmap( (*pMap)->addr, (*pMap)->size); | ||
| 45 | close( (*pMap)->fh); | ||
| 46 | free( *pMap ); *pMap = NULL; | ||
| 47 | } | ||
| 48 | |||
| 49 | int getfilesize( int fd, unsigned long *size) | ||
| 50 | { | ||
| 51 | struct stat sb; | ||
| 52 | int ret; | ||
| 53 | if( fstat( fd, &sb )) return -1; | ||
| 54 | *size = sb.st_size; | ||
| 55 | return 0; | ||
| 56 | } | ||
diff --git a/src/export/mystdlib.h b/src/export/mystdlib.h new file mode 100644 index 0000000..2e9499f --- /dev/null +++ b/src/export/mystdlib.h | |||
| @@ -0,0 +1,32 @@ | |||
| 1 | #include <sys/types.h> | ||
| 2 | #include <stdio.h> | ||
| 3 | |||
| 4 | typedef struct { int fh; unsigned char *addr; size_t size; } *MAP; | ||
| 5 | |||
| 6 | /* Mapps a file into memory | ||
| 7 | returns pointer to the mapping struct, | ||
| 8 | containing the file's size, the mapped | ||
| 9 | address and its file handle. | ||
| 10 | |||
| 11 | If readonly is true, the file will be | ||
| 12 | opened and mapped read only. File is | ||
| 13 | opened and mapped writable, if false. | ||
| 14 | |||
| 15 | Returns NULL if memory could not be | ||
| 16 | allocated, file could not be opened or | ||
| 17 | mapped. Gives out an diagnostic message | ||
| 18 | on stderr | ||
| 19 | */ | ||
| 20 | MAP map_file( char *filename, int readonly ); | ||
| 21 | |||
| 22 | /* Unmapps a file from memory. NULL pointer | ||
| 23 | checks are being done, so this is safe | ||
| 24 | to be called from cleanup without knowing | ||
| 25 | whether there actually is a map. | ||
| 26 | */ | ||
| 27 | void unmap_file ( MAP *pMap ); | ||
| 28 | |||
| 29 | /* Gets file size of open file | ||
| 30 | returns != 0 in case of error */ | ||
| 31 | inline int getfilesize( int fd, unsigned long *size ); | ||
| 32 | |||
diff --git a/src/export/split_version_2.c b/src/export/split_version_2.c new file mode 100644 index 0000000..bd85775 --- /dev/null +++ b/src/export/split_version_2.c | |||
| @@ -0,0 +1,42 @@ | |||
| 1 | #include <stdint.h> | ||
| 2 | #include <stdio.h> | ||
| 3 | #include <unistd.h> | ||
| 4 | #include <fcntl.h> | ||
| 5 | #include <stdlib.h> | ||
| 6 | #include <string.h> | ||
| 7 | |||
| 8 | int main( int argc, char **args ) { | ||
| 9 | char table[64], f[1024*1024*16]; | ||
| 10 | int outfiles[64], i, off, base = 0; | ||
| 11 | uint32_t fixed_columns = 0; | ||
| 12 | |||
| 13 | if( argc > 1 ) base = atol( args[1] ); | ||
| 14 | if( argc > 2 ) fixed_columns = atol( args[2] ); | ||
| 15 | |||
| 16 | for( i=0; i<64; ++i ) outfiles[i] = -1; | ||
| 17 | while( fgets( table, sizeof(table), stdin ) ) { | ||
| 18 | int off = ( table[strlen(table)-1] = 0 ); /* fgets sucks */ | ||
| 19 | int f_in = open( table, O_RDONLY ); | ||
| 20 | size_t s_in = read( f_in, f, sizeof(f)); | ||
| 21 | uint32_t *p = (uint32_t*)f; | ||
| 22 | uint32_t count = p[0], columns = fixed_columns ? fixed_columns : p[1] / 4 - 1; | ||
| 23 | unsigned int file, strnr; | ||
| 24 | |||
| 25 | close(f_in); | ||
| 26 | |||
| 27 | for( file=0; file<columns; ++file ) { | ||
| 28 | /* Create outfile, if it is not yet there */ | ||
| 29 | if( outfiles[file] == -1 ) { | ||
| 30 | sprintf( table, "%02d_unknown", file+base ); | ||
| 31 | outfiles[file] = open( table, O_WRONLY | O_APPEND | O_CREAT, 0644 ); | ||
| 32 | if ( outfiles[file] == -1 ) exit(1); | ||
| 33 | } | ||
| 34 | off = p[file+1]; | ||
| 35 | /* Look for end of this chunk, which is <count> strings long */ | ||
| 36 | for( strnr=0; strnr < count; ++strnr ) { while( f[off++] ) {}; f[off-1] = '\n'; } | ||
| 37 | write( outfiles[file], f + p[file+1], off - p[file+1] ); | ||
| 38 | } | ||
| 39 | } | ||
| 40 | for( i=0; i<64; ++i ) close( outfiles[i] ); | ||
| 41 | return 0; | ||
| 42 | } | ||
