]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs_gui/registros.c
* Se restaura el control del scroll al ver registros.
[z.facultad/75.06/emufs.git] / emufs_gui / registros.c
index 2ec087166cc3f9df5ae18fdb654947d20fa0cb49..4877b884a1c77c1be576a3a331bb9b53583fe471 100644 (file)
@@ -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(char *ptr, EMUFS_REG_SIZE *size);
+static char *procesar_registro_articulo(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual);
 
 #define ACT 0
 #define ANT 1
@@ -13,95 +13,86 @@ static char *procesar_registro_articulo(char *ptr, EMUFS_REG_SIZE *size);
 void ver_registros(WINDOW *padre, int w, int h)
 {
        /* Ventanas donde mostrar las cosas */
-       WINDOW *actual[2], *ant[2], *sig[2];
+       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[3]; /* Registros a mostrar en pantalla */
+       char *data; /* Registros a mostrar en pantalla */
        char codigo[50]; /* Variable para guardar el codigo actual para mandar a modificar */
        EMUFS *fp;
-       int error;
+       int pos_actual, ancho_registro, offset, pos;
        fp = emufs_abrir("articulos");
 
        total_indice = emufs_idx_get_count(fp);
 
-       ant_indice = 0;
-       data[ANT] = (char *)fp->leer_registro(fp, ant_indice, &size, &error);
-       data[ANT] = procesar_registro_articulo(data[ANT], &size);
-       
-       data[ACT] = (char *)fp->leer_registro(fp, ant_indice+1, &size, &error);
-       data[ACT] = procesar_registro_articulo(data[ACT], &size);
-       
-       data[SIG] = (char *)fp->leer_registro(fp, ant_indice+2, &size, &error);
-       data[SIG] = procesar_registro_articulo(data[SIG], &size);
+       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;
 
-       max_scroll = size / (w/3-2) - (h-7);
+       max_scroll = size / (w-4) - (h-8);
        if (max_scroll < 0) max_scroll = 0;
 
-       actual[0] = derwin(padre, h-5, w/3, 1, w/3);
-       actual_ancho = w/3-2;
-       actual[1] = derwin(actual[0], h-7, 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-5, w/3, 1, 0);
-       ant[1] = derwin(ant[0], h-7, w/3-2, 1, 1);
-       box(ant[0], 0, 0);
-       sig[0] = derwin(padre, h-5, w/3, 1, w/3*2);
-       sig[1] = derwin(sig[0], h-7, w/3-2, 1, 1);
-       box(sig[0], 0, 0);
 
        curs_set(0);
-       /* Pongo algunos titulos */
-       mvwaddstr(actual[0], 0, w/6-3, "Actual");
-       mvwaddstr(ant[0], 0, w/6-4, "Anterior");
-       mvwaddstr(sig[0], 0, w/6-4, "Siguiente");
 
        /* Info de teclas */
        wattron(padre, A_BOLD);
        wattron(padre, COLOR_PAIR(COLOR_RED));
-       mvwaddstr(padre, h-4, 5, "Teclas :");
+       mvwaddstr(padre, h-5, 5, "Teclas :");
        wattroff(padre, A_BOLD);
        wattroff(padre, COLOR_PAIR(COLOR_RED));
-       mvwaddstr(padre, h-3, 8, "Salir = ENTER");
-       mvwaddstr(padre, h-2, 8, "Scroll = A/Z");
-       mvwaddstr(padre, h-1, 8, "Mover registros = K/L");
+       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-4, 35, "Leyenda :");
+       mvwaddstr(padre, h-5, 35, "Leyenda :");
        wattroff(padre, A_BOLD);
        wattroff(padre, COLOR_PAIR(COLOR_RED));
-       mvwaddstr(padre, h-3, 38, "| = Separador de campos");
-       mvwaddstr(padre, h-2, 38, "(XXX) = Campo numerico");
-       mvwaddstr(padre, h-1, 38, "* = Relleno en registros fijos");
-       
+       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[ACT]);
+       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));
        
-       mvwaddstr(sig[1], 0, 0, data[SIG]);
-       mvwaddstr(ant[1], 0, 0, data[ANT]);
-       
+       wrefresh(actual[1]);
+       wrefresh(actual[0]);
        wrefresh(padre);
        scroll = 0;
        while ((c=getch()) != 13) {
                switch (c) {
                        case 'e': /* Quiero editar !!! */
-                               sprintf(codigo, "%lu", ant_indice+1);
-                               fprintf(stderr, "%s", codigo);
+                               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);
-                               box(sig[0], 0, 0);
-                               box(ant[0], 0, 0);
-                               mvwaddstr(actual[0], 0, w/6-3, "Actual");
-                               mvwaddstr(ant[0], 0, w/6-4, "Anterior");
-                               mvwaddstr(sig[0], 0, w/6-4, "Siguiente");
                                wrefresh(actual[0]);
-                               wrefresh(sig[0]);
-                               wrefresh(ant[0]);
                        break;
                        case 'a': /* Scroll */
                                scroll--;
@@ -110,83 +101,101 @@ void ver_registros(WINDOW *padre, int w, int h)
                        case 'z': /* Scroll */
                                scroll++;
                                if (scroll > max_scroll) scroll = max_scroll;
-                       case 'k': /* Desplano los registros a derecha! */
+                       break;
+                       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) {
-                                       if (data[ANT]) free(data[ANT]);
-                                       if (data[ACT]) free(data[ACT]);
-                                       if (data[SIG]) free(data[SIG]);
                                        ant_indice--;
-
-                                       data[ANT] = (char *)fp->leer_registro(fp, ant_indice, &size, &error);
-                                       data[ANT] = procesar_registro_articulo(data[ANT], &size);
-                                       data[ACT] = (char *)fp->leer_registro(fp, ant_indice+1, &size, &error);
-                                       data[ACT] = procesar_registro_articulo(data[ACT], &size);
-                                       data[SIG] = (char *)fp->leer_registro(fp, ant_indice+2, &size, &error);
-                                       data[SIG] = procesar_registro_articulo(data[SIG], &size);
+                                       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);
                                }
-                       break;
-                       case 'l': /* Desplazo los registros a izquieda!! */
-                               if (ant_indice+1 < total_indice-1) {
-                                       if (data[ANT]) free(data[ANT]);
-                                       if (data[ACT]) free(data[ACT]);
-                                       if (data[SIG]) free(data[SIG]);
-                                       ant_indice++;
 
-                                       data[ANT] = (char *)fp->leer_registro(fp, ant_indice, &size, &error);
-                                       data[ANT] = procesar_registro_articulo(data[ANT], &size);
-                                       data[ACT] = (char *)fp->leer_registro(fp, ant_indice+1, &size, &error);
-                                       data[ACT] = procesar_registro_articulo(data[ACT], &size);
-                                       data[SIG] = (char *)fp->leer_registro(fp, ant_indice+2, &size, &error);
-                                       data[SIG] = procesar_registro_articulo(data[SIG], &size);
-                               }
                }
                /* Borro las ventanas */
                werase(actual[1]);
-               werase(sig[1]);
-               werase(ant[1]);
 
                /* Imprimo los registros */
-               wattron(actual[1], A_BOLD);
-               if (data[ACT]) mvwaddstr(actual[1], 0, 0, data[ACT]+actual_ancho*scroll);
-               wattroff(actual[1], A_BOLD);
-               if (data[SIG]) mvwaddstr(sig[1], 0, 0, data[SIG]);
-               if (data[ANT]) mvwaddstr(ant[1], 0, 0, data[ANT]);
+               if (data) {
+                       offset = scroll*actual_ancho;
+                       pos = pos_actual - offset;
+                       mvwaddnstr(actual[1], 0, 0, data+offset, pos);
+                       offset += pos;
+                       wattron(actual[1], A_BOLD);
+                       waddnstr(actual[1], data+offset, ancho_registro);
+                       wattroff(actual[1], A_BOLD);
+                       offset += ancho_registro;
+                       waddnstr(actual[1], data+offset, size-offset);
+               }
 
                wrefresh(actual[1]);
-               wrefresh(sig[1]);
-               wrefresh(ant[1]);
                wrefresh(padre);
        }
        delwin(actual[1]);
-       delwin(ant[1]);
-       delwin(sig[1]);
        delwin(actual[0]);
-       delwin(sig[0]);
-       delwin(ant[0]);
        wrefresh(padre);
        curs_set(1);
 }
 
-static char *procesar_registro_articulo(char *ptr, EMUFS_REG_SIZE *size)
+static char *procesar_registro_articulo(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual)
 {
-       char *tmp, *salida, *tmp1;
+       char *tmp, *salida, *tmp1, pos_actualizada;
+       int cant_header, i=0, j;
        if (ptr == NULL) return NULL;
-       salida = (char *)malloc((*size)-sizeof(unsigned int)+11);
-       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);
+
+       /* 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<cant_header) {
+               if (((tmp - ptr) == *pos_actual) && (!pos_actualizada)) {
+                       (*pos_actual) = tmp1-salida;
+                       pos_actualizada = 1;
+               }
+               /* Pongo el ID del registro */
+               sprintf(tmp1, "(%08d)", *((unsigned int *)tmp));
+               tmp1 += 10;
+               tmp += sizeof(unsigned int);
+               /* Pongo el campo numero del registro */
+               sprintf(tmp1, "[%08d]", *((unsigned int *)tmp));
+               tmp1 += 10;
+               tmp += sizeof(unsigned int);
+               j = 0;
+               while (j < (sizeof(t_Articulo)-sizeof(unsigned int))) {
+                       if (*tmp == '\0') {
+                               (*tmp1) = '|';
+                       } else {
+                               (*tmp1) = (*tmp);
+                       }
+                       tmp++;
+                       tmp1++;
+                       j++;
                }
-               tmp++;
-               tmp1++;
+               i++;
        }
        free(ptr);
        (*tmp1) = '\0';
-       (*size) = (*size)-sizeof(unsigned int)+11;
+       (*size) = (*size)-sizeof(unsigned int)*cant_header*2+2*cant_header*10+1;
        return salida;
 }