X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/9071a01f94406f881e6bdd9f875eb926333eb81d..4c9396d05ddc6c73873d21f175e6b5bbd6f25993:/emufs_gui/registros.c diff --git a/emufs_gui/registros.c b/emufs_gui/registros.c index 1d244ee..e6f81fc 100644 --- a/emufs_gui/registros.c +++ b/emufs_gui/registros.c @@ -4,7 +4,7 @@ #include "articulos.h" /* Se encarga de reemplazar los \0 un caracter visual, y segurar un \0 al final */ -static char *procesar_registro_articulo(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual); +static char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual); #define ACT 0 #define ANT 1 @@ -28,7 +28,7 @@ void ver_registros(WINDOW *padre, int w, int h) ant_indice = 1; data = (char *)fp->leer_registro_raw(fp, emufs_idx_get_id_at(fp, ant_indice), &size, &pos_actual); - data = procesar_registro_articulo(fp, data, &size, &pos_actual); + data = procesar_registro_articulo_tipo3(fp, data, &size, &pos_actual); ancho_registro = sizeof(t_Articulo)-sizeof(unsigned int)*2+20; @@ -72,7 +72,7 @@ void ver_registros(WINDOW *padre, int w, int h) mvwaddstr(padre, h-5, 35, "Leyenda :"); wattroff(padre, A_BOLD); wattroff(padre, COLOR_PAIR(COLOR_RED)); - mvwaddstr(padre, h-4, 38, "| = Separador de campo"); + mvwaddstr(padre, h-4, 38, "| = Separador de campo . = Libre"); mvwaddstr(padre, h-3, 38, "[XXX] = Campo numerico"); mvwaddstr(padre, h-2, 38, "(XXX) = ID de registro"); @@ -91,20 +91,21 @@ void ver_registros(WINDOW *padre, int w, int h) case 'e': case 'E': fp->borrar_registro(fp, emufs_idx_get_id_at(fp, ant_indice)); - data = (char *)fp->leer_registro_raw(fp, emufs_idx_get_id_at(fp, ant_indice), &size, &pos_actual); - data = procesar_registro_articulo(fp, data, &size, &pos_actual); total_indice = emufs_idx_get_count(fp); if (ant_indice >= total_indice) { ant_indice = total_indice - 1; } + + data = (char *)fp->leer_registro_raw(fp, emufs_idx_get_id_at(fp, ant_indice), &size, &pos_actual); + data = procesar_registro_articulo_tipo3(fp, data, &size, &pos_actual); break; case 'g': case 'G': art_agregar(NULL); free(data); data = (char *)fp->leer_registro_raw(fp, emufs_idx_get_id_at(fp, ant_indice), &size, &pos_actual); - data = procesar_registro_articulo(fp, data, &size, &pos_actual); + data = procesar_registro_articulo_tipo3(fp, data, &size, &pos_actual); total_indice = emufs_idx_get_count(fp); @@ -115,7 +116,7 @@ void ver_registros(WINDOW *padre, int w, int h) mvwaddstr(padre, h-5, 35, "Leyenda :"); wattroff(padre, A_BOLD); wattroff(padre, COLOR_PAIR(COLOR_RED)); - mvwaddstr(padre, h-4, 38, "| = Separador de campo"); + mvwaddstr(padre, h-4, 38, "| = Separador de campo . = Libre"); mvwaddstr(padre, h-4, 8, "Salir = ENTER"); box(actual[0], 0, 0); wrefresh(actual[0]); @@ -128,7 +129,7 @@ void ver_registros(WINDOW *padre, int w, int h) free(data); data = (char *)fp->leer_registro_raw(fp, emufs_idx_get_id_at(fp, ant_indice), &size, &pos_actual); - data = procesar_registro_articulo(fp, data, &size, &pos_actual); + data = procesar_registro_articulo_tipo3(fp, data, &size, &pos_actual); /* Tengo que re-pintar algunas cosas */ wattron(padre, A_BOLD); @@ -137,7 +138,7 @@ void ver_registros(WINDOW *padre, int w, int h) mvwaddstr(padre, h-5, 35, "Leyenda :"); wattroff(padre, A_BOLD); wattroff(padre, COLOR_PAIR(COLOR_RED)); - mvwaddstr(padre, h-4, 38, "| = Separador de campo"); + mvwaddstr(padre, h-4, 38, "| = Separador de campo . = Libre"); mvwaddstr(padre, h-4, 8, "Salir = ENTER"); box(actual[0], 0, 0); wrefresh(actual[0]); @@ -156,7 +157,7 @@ void ver_registros(WINDOW *padre, int w, int h) if (ant_indice >= total_indice) ant_indice = total_indice-1; if (data) free(data); data = (char *)fp->leer_registro_raw(fp, emufs_idx_get_id_at(fp, ant_indice), &size, &pos_actual); - data = procesar_registro_articulo(fp, data, &size, &pos_actual); + data = procesar_registro_articulo_tipo3(fp, data, &size, &pos_actual); } break; case 'k': @@ -165,7 +166,7 @@ void ver_registros(WINDOW *padre, int w, int h) if (ant_indice == EMUFS_NOT_FOUND) ant_indice = 0; if (data) free(data); data = (char *)fp->leer_registro_raw(fp, emufs_idx_get_id_at(fp, ant_indice), &size, &pos_actual); - data = procesar_registro_articulo(fp, data, &size, &pos_actual); + data = procesar_registro_articulo_tipo3(fp, data, &size, &pos_actual); } } @@ -194,9 +195,9 @@ void ver_registros(WINDOW *padre, int w, int h) curs_set(1); } -static char *procesar_registro_articulo(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual) +char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual) { - char *tmp, *salida, *tmp1, pos_actualizada; + char *tmp, *salida, *tmp1, pos_actualizada, ant; int cant_header, i=0, j; if (ptr == NULL) return NULL; @@ -216,6 +217,9 @@ static char *procesar_registro_articulo(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *s tmp1 = salida; pos_actualizada = 0; while (i