X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/fd6fd64c670641da85e91b3e4c9416bc18ad49e6..1f0a5491c2a344be25f017cf185dded855913d29:/emufs_gui/registros.c diff --git a/emufs_gui/registros.c b/emufs_gui/registros.c index 2dde456..983858d 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,8 +68,12 @@ 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)); @@ -77,7 +86,10 @@ void ver_registros(WINDOW *padre, int w, int h) 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."); } @@ -85,11 +97,8 @@ void ver_registros(WINDOW *padre, int w, int h) indices_actual = 0; if (indices) { - fprintf(stderr, "LEO REGISTRO %lu\n", indices[indices_actual]); data = (char *)fp->leer_registro_raw(fp, indices[indices_actual], &size, &pos_actual); - fprintf(stderr, "Data leida %p (%s)\n",data, data); data = procesar(fp, data, &size, &pos_actual, &ancho_registro); - fprintf(stderr, "Tamanio = %lu\n", size); } @@ -145,7 +154,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); @@ -161,7 +173,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); @@ -222,6 +237,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); @@ -306,7 +322,7 @@ char *procesar_registro_articulo_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si (*ancho) = (*size); } memset(tmp1, '.', (*size)-(tmp1-salida)); - salida[*size] = '\0'; + salida[*size-1] = '\0'; return salida; } @@ -337,10 +353,12 @@ char *procesar_registro_articulo_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si } else { cant_header++; offset += curr_size; + fprintf(stderr, "Sume %lu\n", curr_size); } - } while (offset < (*size)); + } while (offset+sizeof(EMUFS_REG_SIZE)+sizeof(EMUFS_REG_ID) < (*size)); /* Proceso */ + fprintf(stderr, "Cantidad de headers = %d\n", cant_header); salida = (char *)malloc((*size)-sizeof(unsigned int)*cant_header*3 + 3*cant_header*10+1); tmp = ptr; tmp1 = salida; @@ -370,7 +388,9 @@ char *procesar_registro_articulo_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si sprintf(tmp1, "[%08d]", *((unsigned int *)tmp)); tmp1 += 10; tmp += sizeof(unsigned int); - j = sizeof(unsigned int);; + j = sizeof(unsigned int); + PERR("Voy aca"); + fprintf(stderr, "son %lu\n", curr_size); while (j < curr_size) { if (*tmp == '\0') { if (ant == (*tmp)) @@ -385,13 +405,14 @@ char *procesar_registro_articulo_tipo1(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *si tmp1++; j++; } + PERR("Y hasta todo bien"); i++; } /* Tengo que trabajar sobre lo que me falte (seguro es espacio libre) */ (*size) = (*size)-sizeof(unsigned int)*cant_header*3+3*cant_header*10+1; memset(tmp1, '.', (*size)-(tmp1-salida)); free(ptr); - salida[*size] = '\0'; + salida[*size-1] = '\0'; return salida; } @@ -425,3 +446,129 @@ int preguntar_id(WINDOW *win, EMUFS *fp) return n; } +char *procesar_registro_factura_tipo3(EMUFS *emu, char *ptr, EMUFS_REG_SIZE *size, int *pos_actual, int *ancho) +{ + char *tmp, *salida, *tmp1, pos_actualizada, ant; + char flotante[10]; + int cant_header, i=0, j, tam_data, k; + int cant_items; + if (ptr == NULL) return NULL; + + PERR("Empieza el baile"); + + /* Calculo cuantos headers de registros va a haber en el archivo */ + if (emu->tam_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(unsigned int); + } + + fprintf(stderr, "Tengo %d headers\n", cant_header); + /* 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; + while (itam_bloque > emu->tam_reg) { + (*size) = tmp1-salida; + (*ancho) = tam_data + 15*cant_header + cant_items*10 - cant_items*sizeof(int); + } else { + (*size) = (*size)-sizeof(EMUFS_REG_ID)-sizeof(unsigned int)+21; + (*ancho) = (*size); + } + memset(tmp1, '.', (*size)-(tmp1-salida)); + salida[*size-1] = '\0'; + + return salida; +}