From: Ricardo Markiewicz Date: Thu, 15 Apr 2004 18:41:36 +0000 (+0000) Subject: * Al procesar se truncaba el tamaño del bloque para tipo1. Ahora X-Git-Tag: svn_import_r684~474 X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/commitdiff_plain/67aa2f34513b00be510b317accecb4edb9c3dcf6?ds=inline * Al procesar se truncaba el tamaño del bloque para tipo1. Ahora muestra el bloque entero como debe ser. Probe hasta con bloques de 5000 y al parece anda. * Para tipo3 hay algo raro que no anda bien. No puedo poner bloques de mas de 500, y siempre me aparece alguna basura luego de cada registro (tal vez por la alineacion de memoria ?!) --- diff --git a/emufs_gui/registros.c b/emufs_gui/registros.c index bb29f84..911c43d 100644 --- a/emufs_gui/registros.c +++ b/emufs_gui/registros.c @@ -85,8 +85,11 @@ void ver_registros(WINDOW *padre, int w, int h) indices_actual = 0; if (indices) { + fprintf(stderr, "LEO REGISTRO %lu\n", indices[indices_actual]); data = (char *)fp->leer_registro_raw(fp, indices[indices_actual], &size, &pos_actual); + fprintf(stderr, "Data leida %p (%s)\n",data, data); data = procesar(fp, data, &size, &pos_actual, &ancho_registro); + fprintf(stderr, "Tamanio = %lu\n", size); } @@ -251,12 +254,14 @@ char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si */ salida = (char *)malloc((*size)-sizeof(unsigned int)*cant_header*2 + 2*cant_header*10+1); if (salida == NULL) { + fprintf(stderr, "Error de malloc en salida\n"); return NULL; } tmp = ptr; tmp1 = salida; pos_actualizada = 0; while (itam_bloque > emu->tam_reg) { (*size) = (*size)-sizeof(unsigned int)*cant_header*2+2*cant_header*10+1; @@ -301,6 +305,8 @@ char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si (*size) = (*size)-sizeof(EMUFS_REG_ID)-sizeof(unsigned int)+21; (*ancho) = (*size); } + memset(tmp1, '.', (*size)-(tmp1-salida)); + salida[*size] = '\0'; return salida; } @@ -380,9 +386,11 @@ char *procesar_registro_articulo_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si } i++; } - free(ptr); - (*tmp1) = '\0'; + /* Tengo que trabajar sobre lo que me falte (seguro es espacio libre) */ (*size) = (*size)-sizeof(unsigned int)*cant_header*3+3*cant_header*10+1; + memset(tmp1, '.', (*size)-(tmp1-salida)); + free(ptr); + salida[*size] = '\0'; return salida; }