X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/27dcebf2414a7fe37fa130561d14d8bf29e9b12d..4c9396d05ddc6c73873d21f175e6b5bbd6f25993:/emufs_gui/registros.c diff --git a/emufs_gui/registros.c b/emufs_gui/registros.c index 4877b88..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; @@ -51,7 +51,20 @@ void ver_registros(WINDOW *padre, int w, int h) mvwaddstr(padre, h-4, 8, "Salir = ENTER"); mvwaddstr(padre, h-3, 8, "Scroll = A/Z"); mvwaddstr(padre, h-2, 8, "Seleccionar registros = K/L"); - mvwaddstr(padre, h-1, 8, "Editar Actual = e"); + mvwaddstr(padre, h-1, 8, "Acciones: "); + waddstr(padre, "A"); + wattron(padre, A_BOLD); + waddch(padre, 'g'); + wattroff(padre, A_BOLD); + waddstr(padre, "regar "); + wattron(padre, A_BOLD); + waddstr(padre, "M"); + wattroff(padre, A_BOLD); + waddstr(padre, "ofidicar "); + wattron(padre, A_BOLD); + waddstr(padre, "E"); + wattroff(padre, A_BOLD); + waddstr(padre, "liminar "); /* Info de leyenda */ wattron(padre, A_BOLD); @@ -59,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"); @@ -75,14 +88,48 @@ void ver_registros(WINDOW *padre, int w, int h) scroll = 0; while ((c=getch()) != 13) { switch (c) { - case 'e': /* Quiero editar !!! */ + case 'e': + case 'E': + fp->borrar_registro(fp, emufs_idx_get_id_at(fp, ant_indice)); + + 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_tipo3(fp, data, &size, &pos_actual); + + total_indice = emufs_idx_get_count(fp); + + /* Tengo que re-pintar algunas cosas */ + wattron(padre, A_BOLD); + wattron(padre, COLOR_PAIR(COLOR_RED)); + mvwaddstr(padre, h-5, 5, "Teclas :"); + mvwaddstr(padre, h-5, 35, "Leyenda :"); + wattroff(padre, A_BOLD); + wattroff(padre, COLOR_PAIR(COLOR_RED)); + mvwaddstr(padre, h-4, 38, "| = Separador de campo . = Libre"); + mvwaddstr(padre, h-4, 8, "Salir = ENTER"); + box(actual[0], 0, 0); + wrefresh(actual[0]); + break; + case 'M': + case 'm': /* Quiero editar !!! */ sprintf(codigo, "%lu", emufs_idx_get_id_at(fp, ant_indice)); art_modificar(codigo); /* Vuelvo a cargar el articulo actual */ 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); @@ -91,6 +138,8 @@ 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 . = Libre"); + mvwaddstr(padre, h-4, 8, "Salir = ENTER"); box(actual[0], 0, 0); wrefresh(actual[0]); break; @@ -108,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': @@ -117,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); } } @@ -146,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; @@ -168,6 +217,9 @@ static char *procesar_registro_articulo(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *s tmp1 = salida; pos_actualizada = 0; while (i