X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/80aa04fe7756cf1670b51e01238b166d95eb43e4..f7ab25b7a02d1930ce9333f5604ecc6c124d122b:/emufs_gui/registros.c diff --git a/emufs_gui/registros.c b/emufs_gui/registros.c index 7c043e7..e08df56 100644 --- a/emufs_gui/registros.c +++ b/emufs_gui/registros.c @@ -46,6 +46,7 @@ void mostrar_info(WINDOW *padre, int h, int offset_alto) mvwaddstr(padre, h-offset_alto+4, 48, "(XXX) = ID de registro"); mvwaddstr(padre, h-offset_alto+5, 48, "{XXX} = Tam. de registro"); mvwaddstr(padre, h-offset_alto+6, 48, " . = Esp. Libre"); + mvwaddstr(padre, h-offset_alto+7, 48, " < > = Separador Bloques"); } void ver_registros(WINDOW *padre, int w, int h) @@ -83,8 +84,10 @@ void ver_registros(WINDOW *padre, int w, int h) indices = emufs_idx_get(fp, &indices_total); indices_actual = 0; - data = (char *)fp->leer_registro_raw(fp, indices[indices_actual], &size, &pos_actual); - data = procesar(fp, data, &size, &pos_actual, &ancho_registro); + if (indices) { + data = (char *)fp->leer_registro_raw(fp, indices[indices_actual], &size, &pos_actual); + data = procesar(fp, data, &size, &pos_actual, &ancho_registro); + } offset_alto = 8; @@ -213,22 +216,29 @@ void ver_registros(WINDOW *padre, int w, int h) wrefresh(actual[1]); wrefresh(padre); } - delwin(actual[1]); + if (indices) free(indices); + if (data) free(data); + delwin(actual[0]); wrefresh(padre); curs_set(1); - free(indices); } char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho) { char *tmp, *salida, *tmp1, pos_actualizada, ant; - int cant_header, i=0, j; + int cant_header, i=0, j, tam_data; if (ptr == NULL) return NULL; /* Calculo cuantos headers de registros va a haber en el archivo */ - cant_header = emu->tam_bloque / (emu->tam_reg+sizeof(EMUFS_REG_ID)); - if (cant_header == 0) cant_header++; /* Si tam_reg > tam_bloque, voy a tener solo 1 header */ + if (emu->tam_bloque > emu->tam_reg) { + cant_header = emu->tam_bloque / (emu->tam_reg+sizeof(EMUFS_REG_ID)); + if (cant_header == 0) cant_header++; /* Si tam_reg > tam_bloque, voy a tener solo 1 header */ + tam_data = sizeof(t_Articulo)-sizeof(unsigned int); + } else { + cant_header = 1; + tam_data = *size - sizeof(EMUFS_REG_ID)-sizeof(unsigned int); + } /* El tamaƱo del nuevo array lo calculo asi : * @@ -240,10 +250,15 @@ char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si * +1 == Por el \0 */ 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; + (*ancho) = sizeof(t_Articulo)-sizeof(unsigned int)*2+20+1; + } else { + (*size) = (*size)-sizeof(EMUFS_REG_ID)-sizeof(unsigned int)+21; + (*ancho) = (*size); + } + memset(tmp1, '.', (*size)-(tmp1-salida)); + salida[*size-1] = '\0'; + return salida; } @@ -293,6 +318,7 @@ char *procesar_registro_articulo_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si /* Cuento la cantidad de registros en este bloque */ cant_header = 0; offset = 0; + fprintf(stderr, "Tam = %lu\n", *size); do { /* Me salto el ID, que no me interesa saber su valor */ offset += sizeof(EMUFS_REG_ID); @@ -358,9 +384,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; }