X-Git-Url: https://git.llucax.com/z.facultad/75.06/jacu.git/blobdiff_plain/87673889dd7bc0a18e9cefd5cae898ef0e864ba8..ccf1b7bc66344171e458324c6b702caa18c934ca:/src/jacu.c diff --git a/src/jacu.c b/src/jacu.c index fc4188f..e1d6eea 100644 --- a/src/jacu.c +++ b/src/jacu.c @@ -8,6 +8,8 @@ #include #include +long get_file_size(const char* filename); + int main(int argc, char* argv[]) { int cflag = 0; @@ -62,12 +64,15 @@ int main(int argc, char* argv[]) /* Comprimo */ /* No me gusta el tmpfile ... es para probar como anda todo junto */ FILE *fp, *fp_out; - unsigned long int i, j, total, k; + Uint32 i, j, total, k; char *mtf; char *salida, *data, c; + char *z; + int z_len; + data = malloc(sizeof(char)*pagesize); /* Reservo lugar tambien para guardar el k y el tamaño */ - salida = malloc(sizeof(char)*(pagesize)+sizeof(unsigned long int)*2); + salida = malloc(sizeof(char)*(pagesize)+sizeof(Uint32)*2); bs = bs_create(pagesize); fp = fopen(argv[optind], "rb"); @@ -87,21 +92,28 @@ int main(int argc, char* argv[]) bs_solve(data, salida, bs, &k, i); /* Le aplico el MTF, salteo el tamaño del bloque para que no se pierda. */ - mtf = jacu_mtf(salida+sizeof(unsigned long int), i+sizeof(unsigned long int)); + mtf = jacu_mtf(salida+sizeof(Uint32), i+sizeof(Uint32), &z, &z_len); /* Si me lo piden, aplico ZG. */ - if (zflag) - { + if (zflag) { size_t len; char buff[2]; ZG zg; zg_init(&zg); + /* TODO HACER LO MISMO QUE EN EL ELSE XXX */ for (j = 0; j < i; ++j) if ((len = zg_group(&zg, buff, mtf[j]))) fwrite(buff, 1, len, fp_out); - } - else - { - for(j=0; j 0) { - block = malloc((block_size+sizeof(unsigned long int))*sizeof(char)); + block = malloc((block_size+sizeof(Uint32))*sizeof(char)); orig = malloc(block_size*sizeof(char)); vfread(block, block_size, sizeof(char), fp_in); - mtf = jacu_mtf_inv(block, /*XXX NO LO TENGO XXX */pos, block_size); + mtf = jacu_mtf_inv(z, block, block_size); - memcpy(&k, block, sizeof(unsigned long int)); + memcpy(&k, block, sizeof(Uint32)); - bs_restore(orig, block+sizeof(unsigned long int), k, block_size); + bs_restore(orig, block+sizeof(Uint32), k, block_size); fwrite(orig, block_size, sizeof(char), fp_out); free(block); @@ -158,3 +173,15 @@ int main(int argc, char* argv[]) return 0; } + +long get_file_size(const char* filename) +{ + FILE* file; + long file_size; + + if (!(file = fopen(filename, "ab"))) return -1; + file_size = ftell(file); + fclose(file); + return file_size; +} +