]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs_gui/facturas.c
Se pone bien la memoria en cero para la GUI en borrar_registro.
[z.facultad/75.06/emufs.git] / emufs_gui / facturas.c
index 1eefe8571c3ade81b3a1bfa820cd481800476393..254e35eadba38d0ab2d8e785d8bf0df613d98779 100644 (file)
@@ -97,8 +97,10 @@ t_Item *leer_items(xmlNode *node, int *cant, int size)
                                        prop = xml_get_prop(node, "NroArtículo");
                                        tmp[count-1].numero = atoi(prop);
                                        xmlFree(prop);
                                        prop = xml_get_prop(node, "NroArtículo");
                                        tmp[count-1].numero = atoi(prop);
                                        xmlFree(prop);
-                                       strcpy(tmp[count-1].cv, prop = xml_get_prop(node, "CV")); xmlFree(prop);
-                                       strcpy(tmp[count-1].pvu, prop = xml_get_prop(node, "PVU")); xmlFree(prop);
+                                       strncpy(tmp[count-1].cv, prop = xml_get_prop(node, "CV"), 8); xmlFree(prop);
+                                       tmp[count-1].cv[8] = '\0';
+                                       strncpy(tmp[count-1].pvu, prop = xml_get_prop(node, "PVU"), 8); xmlFree(prop);
+                                       tmp[count-1].pvu[8] = '\0';
                                }
                        }
                        node = node->next;
                                }
                        }
                        node = node->next;
@@ -118,8 +120,10 @@ t_Item *leer_items(xmlNode *node, int *cant, int size)
                                        prop = xml_get_prop(node, "NroArtículo");
                                        tmp[count].numero = atoi(prop);
                                        xmlFree(prop);
                                        prop = xml_get_prop(node, "NroArtículo");
                                        tmp[count].numero = atoi(prop);
                                        xmlFree(prop);
-                                       strcpy(tmp[count].cv, prop = xml_get_prop(node, "CV")); xmlFree(prop);
-                                       strcpy(tmp[count].pvu, prop = xml_get_prop(node, "PVU")); xmlFree(prop);
+                                       strncpy(tmp[count].cv, prop = xml_get_prop(node, "CV"), 8); xmlFree(prop);
+                                       tmp[count-1].cv[8] = '\0';
+                                       strncpy(tmp[count].pvu, prop = xml_get_prop(node, "PVU"), 8); xmlFree(prop);
+                                       tmp[count-1].pvu[8] = '\0';
                                        count++;
                                }
                        }
                                        count++;
                                }
                        }
@@ -155,7 +159,7 @@ char *leer_nota(xmlNode *node)
 }
 
 
 }
 
 
-t_LstFacturas *fact_cargar(const char *filename, int tipo, int tam_bloque)
+t_LstFacturas *fact_cargar(const char *filename, int tipo, int tam_bloque, int tipo_nota, int bloque_nota)
 {
        xmlDocPtr document;
        xmlNode *node, *inicio;
 {
        xmlDocPtr document;
        xmlNode *node, *inicio;
@@ -205,7 +209,11 @@ t_LstFacturas *fact_cargar(const char *filename, int tipo, int tam_bloque)
                        cant_items = 0;
                }
                tmp->fp = emufs_crear("facturas", tipo-1, tam_bloque, sizeof(t_Factura)-sizeof(char *)-sizeof(t_Item*)+cant_items*sizeof(t_Item));
                        cant_items = 0;
                }
                tmp->fp = emufs_crear("facturas", tipo-1, tam_bloque, sizeof(t_Factura)-sizeof(char *)-sizeof(t_Item*)+cant_items*sizeof(t_Item));
-               tmp->fp_texto = emufs_crear("notas", T2, 100, 0);
+#ifdef DEBUG
+               fprintf(stderr, "Facturas : Tipo=%d  Tam Bloque = %d\n", tipo-1, tam_bloque);
+               fprintf(stderr, "Notas : Tipo=%d  Tam Bloque = %d\n", tipo_nota-1, bloque_nota);
+#endif
+               tmp->fp_texto = emufs_crear("notas", tipo_nota-1, bloque_nota, 100);
                for (node=inicio ; node ; node = node->next) {
                        if (node->type == XML_ELEMENT_NODE) {
                                if (strcmp(node->name, "FACTURA") == 0) {
                for (node=inicio ; node ; node = node->next) {
                        if (node->type == XML_ELEMENT_NODE) {
                                if (strcmp(node->name, "FACTURA") == 0) {
@@ -768,7 +776,7 @@ static int procesar_leer_factura(t_Factura *dst, void *src, EMUFS_REG_SIZE size,
        return 0;
 }
 
        return 0;
 }
 
-void fact_reformatear(int tipo, int tam_bloque, int tam_reg)
+void fact_reformatear(int tipo, int tam_bloque, int tam_reg, int nota_tipo, int nota_tam_bloque, int nota_tam_registro)
 {
        EMUFS *nuevo, *old;
        EMUFS_REG_ID *indices, id;
 {
        EMUFS *nuevo, *old;
        EMUFS_REG_ID *indices, id;
@@ -797,6 +805,7 @@ void fact_reformatear(int tipo, int tam_bloque, int tam_reg)
        lst_nueva = (t_LstFacturas *)malloc(sizeof(t_LstFacturas));
        lst_nueva->primero = NULL;
        lst_nueva->fp = nuevo;
        lst_nueva = (t_LstFacturas *)malloc(sizeof(t_LstFacturas));
        lst_nueva->primero = NULL;
        lst_nueva->fp = nuevo;
+       lst_nueva->fp_texto = emufs_crear("nota_tmp", nota_tipo, nota_tam_bloque, nota_tam_registro);
 
        /* Leo los indices del archivo viejo */
        PERR("Obtengo Indices\n");
 
        /* Leo los indices del archivo viejo */
        PERR("Obtengo Indices\n");
@@ -815,6 +824,9 @@ void fact_reformatear(int tipo, int tam_bloque, int tam_reg)
                        PERR("Procese Leer Ok");
                        free(save);
                        /* Lei un registro Ok. Lo salvo en el archivo nuevo */
                        PERR("Procese Leer Ok");
                        free(save);
                        /* Lei un registro Ok. Lo salvo en el archivo nuevo */
+
+                       /* Actualizo el ID de la nota asociada */
+                       fact.reg_nota = lst_nueva->fp_texto->grabar_registro(lst_nueva->fp_texto, fact.nota, strlen(fact.nota)+1, &error);
                        save = procesar_guardar_factura(&fact, lst_nueva, &size);
                        PERR("Procese Grabar Ok");
                        if (save) {
                        save = procesar_guardar_factura(&fact, lst_nueva, &size);
                        PERR("Procese Grabar Ok");
                        if (save) {
@@ -845,6 +857,11 @@ void fact_reformatear(int tipo, int tam_bloque, int tam_reg)
        lst_facturas->fp->nombre = (char *)malloc(sizeof(char)*(strlen("facturas")+1));
        strcpy(lst_facturas->fp->nombre, "facturas");
        
        lst_facturas->fp->nombre = (char *)malloc(sizeof(char)*(strlen("facturas")+1));
        strcpy(lst_facturas->fp->nombre, "facturas");
        
+       /* Tambien actualizo el nombre para notas */
+       free(lst_facturas->fp_texto->nombre);
+       lst_facturas->fp_texto->nombre = (char *)malloc(sizeof(char)*(strlen("notas")+1));
+       strcpy(lst_facturas->fp_texto->nombre, "notas");
+       
        /* Muevo los archivos! */
        /* TODO : Poner en otro lugar mas generico! */
        PERR("Renombre!!\n");
        /* Muevo los archivos! */
        /* TODO : Poner en otro lugar mas generico! */
        PERR("Renombre!!\n");
@@ -852,6 +869,52 @@ void fact_reformatear(int tipo, int tam_bloque, int tam_reg)
        rename("emufs_tmp.idx", "facturas.idx");
        rename("emufs_tmp.fsc", "facturas.fsc");
        rename("emufs_tmp.did", "facturas.did");
        rename("emufs_tmp.idx", "facturas.idx");
        rename("emufs_tmp.fsc", "facturas.fsc");
        rename("emufs_tmp.did", "facturas.did");
+       rename("nota_tmp.dat", "notas.dat");
+       rename("nota_tmp.idx", "notas.idx");
+       rename("nota_tmp.fsc", "notas.fsc");
+       rename("nota_tmp.did", "notas.did");
        PERR("==== TERMINE ====\n");
 }
 
        PERR("==== TERMINE ====\n");
 }
 
+int fact_exportar_xml(const char *filename)
+{
+       int j;
+       t_Reg_Factura *nodo;
+       t_Factura *fact;
+       EMUFS_REG_ID id, id1;
+       FILE *fp;
+
+       if (lst_facturas->primero == NULL) return 0;
+
+       nodo = lst_facturas->primero;
+
+       if (!(fp = fopen(filename, "wt"))) return 0;
+       
+       fprintf(fp, "<?xml version=\"1.0\" encoding=\"ISO-8859-1\" ?>\n");
+       fprintf(fp, "<FACTURAS>\n");
+       while (nodo) {
+               fact = fact_buscar(lst_facturas, nodo->numero, &id, &id1);
+               fprintf(fp, "\t<FACTURA NroFac=\"%08d\" ", nodo->numero);
+               fprintf(fp, "FechaEmisión=\"%s\" ", fact->emision);
+               fprintf(fp, "FechaVto=\"%s\" ", fact->vencimiento);
+               fprintf(fp, "NroRemito=\"%08d\" ", fact->numero_remito);
+               fprintf(fp, "FP=\"%s\" ", fact->fp);
+               fprintf(fp, "Estado=\"%s\" ", fact->estado);
+               fprintf(fp, "NroCheque=\"%s\" ", fact->cheque);
+               fprintf(fp, "PorcDoI=\"%.2f\" ", fact->procdoi);
+               fprintf(fp, "NroCtaCte=\"%s\" ", fact->ctacte);
+               fprintf(fp, ">\n");
+               fprintf(fp, "\t\t<NOTA>%s</NOTA>\n", fact->nota);
+               for(j=0; j<fact->cant_items; j++) {
+                       if (fact->items[j].numero != 0)
+                               fprintf(fp, "\t\t<ITEMVENTA NroArtículo=\"%08d\" CV=\"%s\" PVU=\"%s\" />\n", fact->items[j].numero, fact->items[j].cv, fact->items[j].pvu);
+               }
+               fprintf(fp, "\t</FACTURA>\n");
+               nodo = nodo->sig;
+       }
+       fprintf(fp, "\t</FACTURAS>\n");
+
+       fclose(fp);
+       return 1;
+}
+