X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/681f9d807b6f486e251e49401abe40c09b7855c1..0e4db6997a0ac80650f3ec37ba58f7e9a8083147:/emufs_gui/registros.c?ds=inline diff --git a/emufs_gui/registros.c b/emufs_gui/registros.c index 7d3dfda..325b3e2 100644 --- a/emufs_gui/registros.c +++ b/emufs_gui/registros.c @@ -2,10 +2,15 @@ #include "registros.h" #include "idx.h" #include "articulos.h" +#include "facturas.h" /* Se encarga de reemplazar los \0 un caracter visual, y segurar un \0 al final */ static char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho); static char *procesar_registro_articulo_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho); + +static char *procesar_registro_factura_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho); +static char *procesar_registro_factura_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho); + static int preguntar_id(WINDOW *win, EMUFS *fp); void mostrar_info(WINDOW *padre, int h, int offset_alto) @@ -49,7 +54,7 @@ void mostrar_info(WINDOW *padre, int h, int offset_alto) mvwaddstr(padre, h-offset_alto+7, 48, " < > = Separador Bloques"); } -void ver_registros(WINDOW *padre, int w, int h) +void ver_registros(WINDOW *padre, int w, int h, int cual) { /* Ventanas donde mostrar las cosas */ char *(*procesar)(EMUFS*, char*, EMUFS_REG_SIZE*, int*, int*); @@ -63,21 +68,31 @@ void ver_registros(WINDOW *padre, int w, int h) char codigo[50]; /* Variable para guardar el codigo actual para mandar a modificar */ EMUFS *fp; int pos_actual, ancho_registro, offset, pos; - - fp = emufs_abrir("articulos"); + + if (cual == 0) + fp = emufs_abrir("articulos"); + else + fp = emufs_abrir("facturas"); + wattron(padre, COLOR_PAIR(COLOR_BLUE)); mvwaddstr(padre, 0, 0, "Tipo de archivo : "); wattroff(padre, COLOR_PAIR(COLOR_BLUE)); switch (fp->tipo) { case T1: waddstr(padre, "Registro variable con bloque parametrizado."); - procesar = procesar_registro_articulo_tipo1; + if (cual == 0) + procesar = procesar_registro_articulo_tipo1; + else + procesar = procesar_registro_factura_tipo1; break; case T2: waddstr(padre, "Registro variable sin bloques."); break; case T3: - procesar = procesar_registro_articulo_tipo3; + if (cual == 0) + procesar = procesar_registro_articulo_tipo3; + else + procesar = procesar_registro_factura_tipo3; waddstr(padre, "Registro fijo con bloque parametrizado."); } @@ -142,7 +157,10 @@ void ver_registros(WINDOW *padre, int w, int h) break; case 'g': case 'G': - art_agregar(NULL); + if (cual == 0) + art_agregar(NULL); + else + fact_agregar(NULL); free(data); data = (char *)fp->leer_registro_raw(fp, indices[indices_actual], &size, &pos_actual); data = procesar(fp, data, &size, &pos_actual, &ancho_registro); @@ -158,7 +176,10 @@ void ver_registros(WINDOW *padre, int w, int h) case 'M': case 'm': /* Quiero editar !!! */ sprintf(codigo, "%lu", indices[indices_actual]); - art_modificar(codigo); + if (cual == 0) + art_modificar(codigo); + else + fact_modificar(codigo); /* Vuelvo a cargar el articulo actual */ free(data); @@ -219,6 +240,7 @@ void ver_registros(WINDOW *padre, int w, int h) if (indices) free(indices); if (data) free(data); + emufs_destruir(fp); delwin(actual[0]); wrefresh(padre); curs_set(1); @@ -251,14 +273,12 @@ char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si */ 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) { + 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 = emu->tam_reg-sizeof(int)*3-sizeof(float)-sizeof(EMUFS_BLOCK_ID); + } else { + cant_header = 1; + tam_data = (*size) - sizeof(EMUFS_REG_ID)-sizeof(int)*3-sizeof(float)-sizeof(EMUFS_BLOCK_ID); + } + + /* El tamaño del nuevo array lo calculo asi : + * + */ + tmp1 = salida = (char *)malloc(1000000); /*(*size)-(sizeof(char *)+sizeof(t_Item *)+sizeof(EMUFS_REG_ID)+sizeof(int)*3+sizeof(float)+sizeof(EMUFS_BLOCK_ID))*cant_header + 5*cant_header*10+1);*/ + if (salida == NULL) { + PERR("Error de malloc en salida"); + return NULL; + } + tmp = ptr; + pos_actualizada = 0; + (*ancho) = 0; + while (itam_bloque > emu->tam_reg) { + (*size) = tmp1-salida; + } else { + (*size) = tmp1-salida; + (*ancho) = tmp1-salida; + } + salida[*size-1] = '\0'; + + return salida; +} + +char *procesar_registro_factura_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho) +{ + char *tmp, *salida, *tmp1, pos_actualizada, ant; + EMUFS_REG_SIZE offset, curr_size; + char flotante[10]; + int cant_header, i=0, j, tam_data, k; + int cant_items; + if (ptr == NULL) return NULL; + + PERR("Empieza el baile"); + cant_header = 0; + offset = 0; + do { + /* Me salto el ID, que no me interesa saber su valor */ + offset += sizeof(EMUFS_REG_ID); + /* Copio el tamaño del registro de la cabecera. */ + memcpy(&curr_size, ptr + offset, sizeof(EMUFS_REG_SIZE)); + offset += sizeof(EMUFS_REG_SIZE); + + /* Desplazo el offset */ + if (curr_size == 0) { + /* Si el tamaño de registro es 0, quiere decir que llegue a la + * parte que esta vacia */ + break; + } else { + cant_header++; + offset += curr_size; + } + } while (offset+sizeof(EMUFS_REG_SIZE)+sizeof(EMUFS_REG_ID) < (*size)); + + /* El tamaño del nuevo array lo calculo asi : + * + */ + tmp1 = salida = (char *)malloc(1000000); /*(*size)-(sizeof(char *)+sizeof(t_Item *)+sizeof(EMUFS_REG_ID)+sizeof(int)*3+sizeof(float)+sizeof(EMUFS_BLOCK_ID))*cant_header + 5*cant_header*10+1);*/ + if (salida == NULL) { + PERR("Error de malloc en salida"); + return NULL; + } + tmp = ptr; + pos_actualizada = 0; + (*ancho) = 0; + i = 0; + while (itam_bloque > emu->tam_reg) { + (*size) = tmp1-salida; + } else { + (*size) = tmp1-salida; + (*ancho) = tmp1-salida; + } + salida[*size-1] = '\0'; + + return salida; +} +