]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs_gui/facturas.c
* Mas cambios GUI
[z.facultad/75.06/emufs.git] / emufs_gui / facturas.c
index fbf1b25e9e0516d0de21452726b5131c74d87e4b..7114dce39fc140aab5f2d57a140eb2b4c7b1a037 100644 (file)
@@ -8,22 +8,26 @@ static int al_azar(int min, int max);
 static void *procesar_guardar_factura(t_Factura *f, t_LstFacturas *lst, int *size);
 
 /* es por cada mes a generar */
 static void *procesar_guardar_factura(t_Factura *f, t_LstFacturas *lst, int *size);
 
 /* es por cada mes a generar */
-#define CANT_FACTURAS 500
+#define CANT_FACTURAS 1500
 
 t_LstFacturas *fact_cargar(const char *filename)
 {
 
 t_LstFacturas *fact_cargar(const char *filename)
 {
-       int i, numero, size;
+       int i, numero, size, error, cant;
        char *estados[6] = {"PN", "CD", "CM", "CF", "PM", "NC"}; 
        char *fps[6] = {"CO", "CR", "CH"}; 
        void *save;
        t_Factura fact;
 
        char *estados[6] = {"PN", "CD", "CM", "CF", "PM", "NC"}; 
        char *fps[6] = {"CO", "CR", "CH"}; 
        void *save;
        t_Factura fact;
 
-       if (filename == NULL) {
+       lst_facturas = (t_LstFacturas *)malloc(sizeof(t_LstFacturas));
+
+       if (filename != NULL) {
+               lst_facturas->fp = emufs_crear("facturas", T3, sizeof(t_Factura)*20, sizeof(t_Factura));
                /* Genero las facturas en forma automática */
                /* Genero las facturas de fecha Abril 2004 */
                srand(time(NULL));
                numero = 0;
                /* Genero las facturas en forma automática */
                /* Genero las facturas de fecha Abril 2004 */
                srand(time(NULL));
                numero = 0;
-               for(i=0; i<CANT_FACTURAS*0.1; i++) {
+               cant = 0;
+               for(i=0; i<CANT_FACTURAS; i++) {
                        /* Entre 10 y 15 ITEMS! */
                        fact.numero = numero;
                        sprintf(fact.emision, "200404%02d", al_azar(1, 30));
                        /* Entre 10 y 15 ITEMS! */
                        fact.numero = numero;
                        sprintf(fact.emision, "200404%02d", al_azar(1, 30));
@@ -39,9 +43,11 @@ t_LstFacturas *fact_cargar(const char *filename)
                        /* Guardo */
                        save = procesar_guardar_factura(&fact, lst_facturas, &size);
                        if (save != NULL) {
                        /* Guardo */
                        save = procesar_guardar_factura(&fact, lst_facturas, &size);
                        if (save != NULL) {
-                               lst_facturas->fp->grabar_registro(lst_facturas->fp, save, size);
+                               lst_facturas->array[cant].numero = numero;
+                               lst_facturas->array[cant].num_reg = lst_facturas->fp->grabar_registro(lst_facturas->fp, save, size, &error);
                        }
                }
                        }
                }
+               lst_facturas->cant = cant;
        } else {
                /* Cargo un archivo existente */
        }
        } else {
                /* Cargo un archivo existente */
        }
@@ -49,6 +55,19 @@ t_LstFacturas *fact_cargar(const char *filename)
        return lst_facturas;
 }
 
        return lst_facturas;
 }
 
+int fact_liberar(t_LstFacturas *l)
+{
+       if (l == NULL) l = lst_facturas;
+       if (l == NULL) return 1;
+
+       emufs_destruir(l->fp);
+/*     free(l->array); */
+       free(l);
+
+       lst_facturas = NULL;
+       return 0;
+}
+
 int al_azar(int min, int max)
 {
        return (min + rand()%(max-min));
 int al_azar(int min, int max)
 {
        return (min + rand()%(max-min));
@@ -72,7 +91,8 @@ void *procesar_guardar_factura(t_Factura *f, t_LstFacturas *lst, int *size)
                        i[6] = sizeof(float);
                        i[7] = sizeof(char)*(strlen(f->ctacte)+1); /* +1 por el \0 para separar */
                        i[8] = sizeof(char)*(strlen(f->cheque)+1); /* +1 por el \0 para separar */
                        i[6] = sizeof(float);
                        i[7] = sizeof(char)*(strlen(f->ctacte)+1); /* +1 por el \0 para separar */
                        i[8] = sizeof(char)*(strlen(f->cheque)+1); /* +1 por el \0 para separar */
-                       tmp = (char *)malloc(i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8]);
+                       (*size) = i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8];
+                       tmp = (char *)malloc(*size);
                        if (tmp == NULL) return NULL;
                        /* Ahora copio la info */
                        memcpy(tmp, &f->numero, i[0]);
                        if (tmp == NULL) return NULL;
                        /* Ahora copio la info */
                        memcpy(tmp, &f->numero, i[0]);