From 67aa2f34513b00be510b317accecb4edb9c3dcf6 Mon Sep 17 00:00:00 2001 From: Ricardo Markiewicz Date: Thu, 15 Apr 2004 18:41:36 +0000 Subject: [PATCH] =?utf8?q?=20*=20Al=20procesar=20se=20truncaba=20el=20tama?= =?utf8?q?=C3=B1o=20del=20bloque=20para=20tipo1.=20Ahora=20=20muestra=20el?= =?utf8?q?=20bloque=20entero=20como=20debe=20ser.=20Probe=20hasta=20con=20?= =?utf8?q?bloques=20de=20=205000=20y=20al=20parece=20anda.?= MIME-Version: 1.0 Content-Type: text/plain; charset=utf8 Content-Transfer-Encoding: 8bit * 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 ?!) --- emufs_gui/registros.c | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) 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; } -- 2.43.0