X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/087bc4de9c787d31ba4711af77af8620c4eae004..2f11b196bec87977b7af6087fab42e986d24b743:/emufs_gui/registros.c?ds=sidebyside diff --git a/emufs_gui/registros.c b/emufs_gui/registros.c index 0a9324f..ab6b5bc 100644 --- a/emufs_gui/registros.c +++ b/emufs_gui/registros.c @@ -1,86 +1,196 @@ #include "registros.h" +#include "idx.h" +#include "articulos.h" /* Se encarga de reemplazar los \0 un caracter visual, y segurar un \0 al final */ -static char *procesar_registro(char *ptr, size_t size); +static char *procesar_registro_articulo(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual); + +#define ACT 0 +#define ANT 1 +#define SIG 2 void ver_registros(WINDOW *padre, int w, int h) { /* Ventanas donde mostrar las cosas */ - WINDOW *actual[2], *ant[2], *sig[2]; - int c, scroll, actual_ancho; - char *data; + WINDOW *actual[2]; + EMUFS_REG_SIZE size; + int scroll, actual_ancho; + int max_scroll, c; + EMUFS_REG_ID ant_indice, total_indice; /* Indice de registro que tengo en ANT */ + char *data; /* Registros a mostrar en pantalla */ + char codigo[50]; /* Variable para guardar el codigo actual para mandar a modificar */ EMUFS *fp; + int pos_actual, ancho_registro; fp = emufs_abrir("articulos"); - data = (char *)fp->leer_registro(fp, 0, &c, &scroll); + total_indice = emufs_idx_get_count(fp); + + 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); + + ancho_registro = sizeof(t_Articulo)-sizeof(unsigned int)*2+20; - data = procesar_registro(data, c); + max_scroll = size / (w/3-2) - (h-8); + if (max_scroll < 0) max_scroll = 0; - actual[0] = derwin(padre, h-2, w/3, 1, w/3); - actual_ancho = w/3-2; - actual[1] = derwin(actual[0], h-4, w/3-2, 1, 1); + actual[0] = derwin(padre, h-6, w-2, 1, 1); + actual_ancho = w-4; + actual[1] = derwin(actual[0], h-8, w-4, 1, 1); box(actual[0], 0, 0); - ant[0] = derwin(padre, h-2, w/3, 1, 0); - box(ant[0], 0, 0); - sig[0] = derwin(padre, h-2, w/3, 1, w/3*2); - box(sig[0], 0, 0); + curs_set(0); + + /* Info de teclas */ + wattron(padre, A_BOLD); + wattron(padre, COLOR_PAIR(COLOR_RED)); + mvwaddstr(padre, h-5, 5, "Teclas :"); + wattroff(padre, A_BOLD); + wattroff(padre, COLOR_PAIR(COLOR_RED)); + 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"); + + /* Info de leyenda */ + wattron(padre, A_BOLD); + wattron(padre, COLOR_PAIR(COLOR_RED)); + 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-3, 38, "[XXX] = Campo numerico"); + mvwaddstr(padre, h-2, 38, "(XXX) = ID de registro"); + + mvwaddnstr(actual[1], 0, 0, data, pos_actual); wattron(actual[1], A_BOLD); - mvwaddstr(actual[1], 0, 0, data); + waddnstr(actual[1], data+pos_actual, ancho_registro); wattroff(actual[1], A_BOLD); + waddnstr(actual[1], data+pos_actual+ancho_registro, size-(pos_actual+ancho_registro)); - wrefresh(sig[0]); - wrefresh(ant[0]); - wrefresh(actual[0]); wrefresh(actual[1]); + wrefresh(actual[0]); wrefresh(padre); scroll = 0; while ((c=getch()) != 13) { switch (c) { - case 'a': + case 'e': /* 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); + + /* 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)); + box(actual[0], 0, 0); + wrefresh(actual[0]); + break; + case 'a': /* Scroll */ scroll--; if (scroll < 0) scroll = 0; break; - case 'z': + case 'z': /* Scroll */ scroll++; + if (scroll > max_scroll) scroll = max_scroll; + case 'l': + if (ant_indice < total_indice) { + ant_indice++; + 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); + } + break; + case 'k': + if (ant_indice != EMUFS_NOT_FOUND) { + ant_indice--; + 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); + } + } + /* Borro las ventanas */ werase(actual[1]); - wattron(actual[1], A_BOLD); - mvwaddstr(actual[1], 0, 0, data+actual_ancho*scroll); - wattroff(actual[1], A_BOLD); + + /* Imprimo los registros */ + if (data) { + mvwaddnstr(actual[1], 0, 0, data, pos_actual); + wattron(actual[1], A_BOLD); + waddnstr(actual[1], data+pos_actual, ancho_registro); + wattroff(actual[1], A_BOLD); + waddnstr(actual[1], data+pos_actual+ancho_registro, size-(pos_actual+ancho_registro)); + } + wrefresh(actual[1]); - wrefresh(actual[0]); wrefresh(padre); } - werase(actual[1]); delwin(actual[1]); - werase(actual[0]); delwin(actual[0]); - werase(sig[0]); - delwin(sig[0]); - werase(ant[0]); - delwin(ant[0]); wrefresh(padre); + curs_set(1); } -static char *procesar_registro(char *ptr, size_t size) +static char *procesar_registro_articulo(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual) { - char *tmp, *salida, *tmp1; - salida = (char *)malloc(size-sizeof(unsigned int)+10+1); - sprintf(salida, "(%08d)", *((unsigned int *)ptr)); - tmp1 = salida+10; - tmp = ptr+sizeof(unsigned int); - while (tmp < (ptr+size)) { - if (*tmp == '\0') { - (*tmp1) = '|'; - } else { - (*tmp1) = (*tmp); + char *tmp, *salida, *tmp1, pos_actualizada; + int cant_header, i=0, j; + 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)); + /* El tamaño del nuevo array lo calculo asi : + * + * tamañoviejo - tamaño_headers_en_int - tamaño_ints_en_registro + * + 10*(cant_headers+cant_registros) +1 + * + * En tipo3, la cantidad de headers y cant de registros es la misma + * El 10 es por : (XXXXXXXX) + * +1 == Por el \0 + */ + salida = (char *)malloc((*size)-sizeof(unsigned int)*cant_header*2 + 2*cant_header*10+1); + tmp = ptr; + tmp1 = salida; + pos_actualizada = 0; + while (i