From 05ca3169ccbbf6c7bde9b7c7fe4749c25e6d9dc1 Mon Sep 17 00:00:00 2001 From: Ricardo Markiewicz Date: Sat, 17 Apr 2004 22:58:44 +0000 Subject: [PATCH] * Ver Registros de archivo de Factura (para tipo3) implementado. Falta probar y algunos cambios para registros partidos. --- emufs_gui/facturas.c | 5 +- emufs_gui/gui.c | 11 ++- emufs_gui/registros.c | 157 ++++++++++++++++++++++++++++++++++++++++-- emufs_gui/registros.h | 2 +- 4 files changed, 164 insertions(+), 11 deletions(-) diff --git a/emufs_gui/facturas.c b/emufs_gui/facturas.c index 2b0a305..83490bc 100644 --- a/emufs_gui/facturas.c +++ b/emufs_gui/facturas.c @@ -88,13 +88,14 @@ t_Item *leer_items(xmlNode *node, int *cant, int size) } else { (*cant) = size; tmp = (t_Item *)malloc(sizeof(t_Item)*size); - memset(tmp, '$', sizeof(t_Item)*size); + memset(tmp, 0, sizeof(t_Item)*size); count = 0; node = node->children; while (node) { if (node->type == XML_ELEMENT_NODE) { if (strcmp(node->name, "ITEMVENTA") == 0) { + memset(&tmp[count], '*', sizeof(t_Item)); prop = xml_get_prop(node, "NroArtículo"); tmp[count].numero = atoi(prop); xmlFree(prop); @@ -189,7 +190,7 @@ t_LstFacturas *fact_cargar(const char *filename, int tipo, int tam_bloque) if (strcmp(node->name, "FACTURA") == 0) { t_Factura fact; void *save; - memset(&fact, 0, sizeof(t_Factura)); + memset(&fact, '*', sizeof(t_Factura)); prop = xml_get_prop(node, "NroFac"); fact.numero = atoi(prop); xmlFree(prop); prop = xml_get_prop(node, "PorcDoI"); diff --git a/emufs_gui/gui.c b/emufs_gui/gui.c index 35ebc98..95c5fee 100644 --- a/emufs_gui/gui.c +++ b/emufs_gui/gui.c @@ -70,7 +70,6 @@ t_Param param_ok(int argc, char *argv[]) return BLOQUE_NO_DEFINIDO; parametros.tipo_arch_art = n; parametros.tam_bloque_art = atoi(argv[i+2]); - fprintf(stderr, "%d\n", parametros.tam_bloque_art); if (parametros.tam_bloque_art <= 0) return NULL_BLOCK_FOUND; parametros.xml_art = i; } else { @@ -233,7 +232,15 @@ int main(int argc, char *argv[]) break; case 2: dialog = derwin(stdscr, LINES-4, COLS-2, 2, 1); - ver_registros(dialog, COLS-2, LINES-4); + ver_registros(dialog, COLS-2, LINES-4, 0); + werase(dialog); + wrefresh(dialog); + delwin(dialog); + refresh(); + break; + case 3: + dialog = derwin(stdscr, LINES-4, COLS-2, 2, 1); + ver_registros(dialog, COLS-2, LINES-4, 1); werase(dialog); wrefresh(dialog); delwin(dialog); diff --git a/emufs_gui/registros.c b/emufs_gui/registros.c index aa9c867..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."); } @@ -142,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); @@ -158,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); @@ -219,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); @@ -427,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; +} diff --git a/emufs_gui/registros.h b/emufs_gui/registros.h index df31f8d..03ba038 100644 --- a/emufs_gui/registros.h +++ b/emufs_gui/registros.h @@ -7,7 +7,7 @@ #include "emufs.h" -void ver_registros(WINDOW *padre, int w, int h); +void ver_registros(WINDOW *padre, int w, int h, int cual); #endif -- 2.43.0