/* Procesa una factura antes de enviarla al archivo para guardarla */
static void *procesar_guardar_factura(t_Factura *f, t_LstFacturas *lst, EMUFS_REG_SIZE *size);
+static int procesar_leer_factura(t_Factura *dst, void *src, EMUFS_REG_SIZE size, t_LstFacturas *lst);
static t_Reg_Factura *crear_nodo_factura(EMUFS_REG_ID reg, EMUFS_REG_ID texto, unsigned int num);
static int agregar_nodo_factura(t_LstFacturas *lst, t_Reg_Factura *nodo);
int eliminar_nodo_factura(t_LstFacturas *lst, t_Reg_Factura *nodo);
if (filename != NULL) {
document = xmlReadFile(filename, "ISO-8859-1",0);
if (document == NULL) {
- fprintf(stderr, "ERROR ABRIENDO %s\n", filename);
return NULL;
}
void *save;
memset(&fact, '*', sizeof(t_Factura));
fact.numero = atoi(xml_get_prop(node, "NroFac"));
- fact.procdoi = atoi(xml_get_prop(node, "porcDoI"));
+ fact.procdoi = atof(xml_get_prop(node, "PorcDoI"));
fact.numero_remito = atoi(xml_get_prop(node, "NroRemito"));
strcpy(fact.emision, xml_get_prop(node, "FechaEmisiĆ³n"));
strcpy(fact.vencimiento, xml_get_prop(node, "FechaVto"));
save = procesar_guardar_factura(&fact, lst_facturas, &size);
if (save != NULL) {
id = tmp->fp->grabar_registro(tmp->fp, save, size, &error);
- fprintf(stderr, "Voy a grabar el texto [%d]\n", strlen(fact.nota));
id_texto = tmp->fp_texto->grabar_registro(tmp->fp_texto, fact.nota, 400, &error);
- fprintf(stderr, "Todo ok : ID=%lu , txtID=%lu\n", id, id_texto);
agregar_nodo_factura(tmp, crear_nodo_factura(id, id_texto, fact.numero));
free(save);
}
return 0;
}
+t_Factura *fact_buscar(t_LstFacturas *lst, int numero)
+{
+ t_Factura *fact;
+ t_Reg_Factura *reg;
+ char *leo;
+ EMUFS_REG_SIZE size;
+ int error;
+ if (lst == NULL) return NULL;
+
+ fact = NULL;
+ reg = lst->primero;
+ while (reg) {
+ if (reg->numero == numero) {
+ leo = lst->fp->leer_registro(lst->fp, reg->num_reg, &size, &error);
+ if (leo != NULL) {
+ fact = (t_Factura *)malloc(sizeof(t_Factura));
+ procesar_leer_factura(fact, leo, size, lst);
+ }
+ break;
+ }
+ reg = reg->sig;
+ }
+ return fact;
+}
+
+t_Factura *fact_form_buscar(WINDOW *win, EMUFS_REG_ID *id)
+{
+ t_Form *form;
+ t_Factura *fact;
+
+ form = form_crear(win);
+ form_agregar_widget(form, INPUT, "Numero de Factura", 8, "");
+ form_ejecutar(form, 1,1);
+ fact = fact_buscar(lst_facturas, form_obtener_valor_int(form, "Numero de Factura"));
+ form_destruir(form);
+
+ return fact;
+}
+
+void fact_modificar(char *s)
+{
+ WINDOW *win, *items;
+ t_Form *form;
+ t_Factura *fact;
+ /*EMUFS_REG_SIZE size;*/
+ EMUFS_REG_ID id; /*, id_texto;*/
+/* int y_actual, cant, error;*/
+ char tmp_str[10];
+
+
+ win = newwin(LINES-4, COLS-2, 2, 1);
+ box(win, 0, 0);
+
+ fact = fact_form_buscar(win, &id);
+
+ if (fact == NULL) {
+ werase(win);
+ wrefresh(win);
+ delwin(win);
+ return;
+ }
+
+ mvwaddch(win, 10, 0, ACS_LTEE);
+ mvwhline(win, 10, 1, ACS_HLINE, COLS-3);
+ mvwaddch(win, 10, COLS-3, ACS_RTEE);
+ wrefresh(win);
+
+ items = derwin(win, LINES-20, COLS-4, 15, 1);
+ wrefresh(items);
+
+ form = form_crear(win);
+ sprintf(tmp_str, "%08d", fact->numero);
+ form_agregar_widget(form, INPUT, "Numero de Factura", 8, tmp_str);
+ form_agregar_widget(form, INPUT, "Fecha Emision", 8, fact->emision);
+ form_agregar_widget(form, INPUT, "Fecha Vto", 8, fact->vencimiento);
+ sprintf(tmp_str, "%08d", fact->numero_remito);
+ form_agregar_widget(form, INPUT, "Nro Remito", 8, tmp_str);
+ form_agregar_widget(form, RADIO, "Estado", 6, "PN,CD,CM,SF,PM,NC");
+ form_agregar_widget(form, RADIO, "Forma de pago", 3, "CO,CR,CH");
+ sprintf(tmp_str, "%02.2f", fact->procdoi);
+ form_agregar_widget(form, INPUT, "%% Descuento", 5, tmp_str);
+ form_agregar_widget(form, INPUT, "Cuenta Cte", 5, fact->ctacte);
+ form_agregar_widget(form, INPUT, "Cheque Nro", 18, fact->cheque);
+
+ form_ejecutar(form, 1,1);
+
+ fact->numero = form_obtener_valor_int(form, "Numero de Factura");
+ strcpy(fact->emision, form_obtener_valor_char(form, "Fecha Emision"));
+ strcpy(fact->vencimiento, form_obtener_valor_char(form, "Fecha Vto"));
+ fact->numero_remito = form_obtener_valor_int(form, "Nro Remito");
+ strcpy(fact->estado, form_obtener_valor_char(form, "Estado"));
+ strcpy(fact->fp, form_obtener_valor_char(form, "Forma de pago"));
+ fact->procdoi = form_obtener_valor_float(form, "%% Descuento");
+ strcpy(fact->ctacte, form_obtener_valor_char(form, "Cuenta Cte"));
+ strcpy(fact->cheque, form_obtener_valor_char(form, "Cheque Nro"));
+
+ form_destruir(form);
+
+ /* TODO MODIFICAR */
+
+/* entrada = procesar_guardar_factura(&fact,lst_facturas, &size);
+ if (entrada) {
+ id = lst_facturas->fp->grabar_registro(lst_facturas->fp, entrada, size, &error);*/
+ /*id_texto = tmp->fp_texto->grabar_registro(tmp->fp_texto, fact.nota, 400, &error);*/
+ /* TODO : -1 == id_texto !!!!!!!! XXX XXX XXX XXX XXX XXX XXX */
+ /*agregar_nodo_factura(lst_facturas, crear_nodo_factura(id, -1, fact.numero));
+ free(entrada);
+ }
+ */
+/* form_destruir(form); */
+
+ free(fact->items);
+ free(fact);
+
+ werase(win);
+ wrefresh(win);
+ delwin(items);
+ delwin(win);
+}
+
+void fact_agregar(char *s)
+{
+ WINDOW *win, *items;
+ t_Form *form;
+ t_Item *its = NULL;
+ t_Factura fact;
+ EMUFS_REG_SIZE size;
+ EMUFS_REG_ID id, id_texto;
+ int y_actual, cant, error;
+ char *entrada;
+
+ win = newwin(LINES-4, COLS-2, 2, 1);
+ box(win, 0, 0);
+ mvwaddch(win, 10, 0, ACS_LTEE);
+ mvwhline(win, 10, 1, ACS_HLINE, COLS-3);
+ mvwaddch(win, 10, COLS-3, ACS_RTEE);
+ wrefresh(win);
+
+ items = derwin(win, LINES-20, COLS-4, 15, 1);
+ wrefresh(items);
+
+ form = form_crear(win);
+ form_agregar_widget(form, INPUT, "Numero de Factura", 8, "");
+ form_agregar_widget(form, INPUT, "Fecha Emision", 8, "");
+ form_agregar_widget(form, INPUT, "Fecha Vto", 8, "");
+ form_agregar_widget(form, INPUT, "Nro Remito", 8, "");
+ form_agregar_widget(form, RADIO, "Estado", 6, "PN,CD,CM,SF,PM,NC");
+ form_agregar_widget(form, RADIO, "Forma de pago", 3, "CO,CR,CH");
+ form_agregar_widget(form, INPUT, "%% Descuento", 5, "");
+ form_agregar_widget(form, INPUT, "Cuenta Cte", 5, "");
+ form_agregar_widget(form, INPUT, "Cheque Nro", 18, "");
+
+ form_ejecutar(form, 1,1);
+
+ fact.numero = form_obtener_valor_int(form, "Numero de Factura");
+ fprintf(stderr, "Agregando numero %d\n", fact.numero);
+ strcpy(fact.emision, form_obtener_valor_char(form, "Fecha Emision"));
+ strcpy(fact.vencimiento, form_obtener_valor_char(form, "Fecha Vto"));
+ fact.numero_remito = form_obtener_valor_int(form, "Nro Remito");
+ strcpy(fact.estado, form_obtener_valor_char(form, "Estado"));
+ strcpy(fact.fp, form_obtener_valor_char(form, "Forma de pago"));
+ fact.procdoi = form_obtener_valor_float(form, "%% Descuento");
+ strcpy(fact.ctacte, form_obtener_valor_char(form, "Cuenta Cte"));
+ strcpy(fact.cheque, form_obtener_valor_char(form, "Cheque Nro"));
+
+ form_destruir(form);
+
+ form = form_crear(win);
+ form_agregar_widget(form, INPUT, "Nro de Articulo (* == fin)", 8, "");
+ form_agregar_widget(form, INPUT, "CV", 8, "");
+ form_agregar_widget(form, INPUT, "PVU", 8, "");
+ y_actual = 0;
+ scrollok(items, 1);
+ mvwaddstr(win, 15, 2, "Numero");
+ mvwaddstr(win, 15, 11, "CV");
+ mvwaddstr(win, 15, 21, "PVU");
+ do {
+ form_set_valor(form, "Nro de Articulo (* == fin)", "");
+ form_set_valor(form, "CV", "");
+ form_set_valor(form, "PVU", "");
+ form_ejecutar(form, 2, 11);
+
+ entrada = form_obtener_valor_char(form, "Nro de Articulo (* == fin)");
+
+ if (entrada[0] != '\0') {
+ y_actual++;
+ if (y_actual > LINES-22) {
+ y_actual = LINES-22;
+ wscrl(items, 1);
+ }
+ mvwaddstr(items, y_actual, 1, entrada);
+ mvwaddstr(items, y_actual, 10, form_obtener_valor_char(form, "CV"));
+ mvwaddstr(items, y_actual, 20, form_obtener_valor_char(form, "PVU"));
+ wrefresh(items);
+ /* Agrego el Item */
+ cant++;
+ its = (t_Item *)realloc(its, cant*sizeof(t_Item));
+ its[cant-1].numero = form_obtener_valor_int(form, entrada);
+ strcpy(its[cant-1].cv, form_obtener_valor_char(form, "CV"));
+ strcpy(its[cant-1].pvu, form_obtener_valor_char(form, "PVU"));
+ }
+ } while (strcmp(entrada, "*") != 0);
+
+ if (lst_facturas->fp->tipo == 3) {
+ if (cant != 10) {
+ /* TODO Limitar en la GUI en lugar de truncar! */
+ its = (t_Item *)realloc(its, 10*sizeof(t_Item));
+ cant = 10;
+ }
+ }
+ fact.items = its;
+ fact.cant_items = cant;
+
+ entrada = procesar_guardar_factura(&fact,lst_facturas, &size);
+ if (entrada) {
+ id = lst_facturas->fp->grabar_registro(lst_facturas->fp, entrada, size, &error);
+ /*id_texto = tmp->fp_texto->grabar_registro(tmp->fp_texto, fact.nota, 400, &error);*/
+ /* TODO : -1 == id_texto !!!!!!!! XXX XXX XXX XXX XXX XXX XXX */
+ agregar_nodo_factura(lst_facturas, crear_nodo_factura(id, -1, fact.numero));
+ free(entrada);
+ }
+
+ if (its) free(its);
+ form_destruir(form);
+
+ werase(win);
+ wrefresh(win);
+ delwin(items);
+ delwin(win);
+}
void *procesar_guardar_factura(t_Factura *f, t_LstFacturas *lst, EMUFS_REG_SIZE *size)
{
char *tmp=NULL;
- int i[9];
+ int i[11];
switch (lst->fp->tipo) {
case T1:
case T2:
/* Calculo el tamaƱo que voy a necesitar */
i[0] = sizeof(int);
- i[1] = sizeof(char)*(strlen(f->emision)+1); /* +1 por el \0 para separar */
- i[2] = sizeof(char)*(strlen(f->vencimiento)+1); /* +1 por el \0 para separar */
+ i[1] = sizeof(float);
+ i[2] = sizeof(int);
i[3] = sizeof(int);
- i[4] = sizeof(char)*(strlen(f->estado)+1); /* +1 por el \0 para separar */
- i[5] = sizeof(char)*(strlen(f->fp)+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 */
- (*size) = i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8];
+ i[4] = sizeof(char)*(strlen(f->emision)+1); /* +1 por el \0 para separar */
+ i[5] = sizeof(char)*(strlen(f->vencimiento)+1); /* +1 por el \0 para separar */
+ i[6] = sizeof(char)*(strlen(f->estado)+1); /* +1 por el \0 para separar */
+ i[7] = sizeof(char)*(strlen(f->fp)+1); /* +1 por el \0 para separar */
+ i[8] = sizeof(char)*(strlen(f->ctacte)+1); /* +1 por el \0 para separar */
+ i[9] = sizeof(char)*(strlen(f->cheque)+1); /* +1 por el \0 para separar */
+ i[10] = sizeof(t_Item)*f->cant_items;
+ (*size) = i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8]+i[9]+i[10];
tmp = (char *)malloc(*size);
if (tmp == NULL) return NULL;
/* Ahora copio la info */
memcpy(tmp, &f->numero, i[0]);
- memcpy(tmp+i[0], f->emision, i[1]);
- memcpy(tmp+i[0]+i[1], f->vencimiento, i[2]);
- memcpy(tmp+i[0]+i[1]+i[2], &f->numero_remito, i[3]);
- memcpy(tmp+i[0]+i[1]+i[2]+i[3], f->estado, i[4]);
- memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4], f->fp, i[5]);
- memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5], &f->procdoi, i[6]);
- memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6], f->ctacte, i[7]);
- memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7], f->cheque, i[8]);
+ memcpy(tmp, &f->procdoi, i[1]);
+ memcpy(tmp, &f->numero_remito, i[2]);
+ memcpy(tmp, &f->cant_items, i[3]);
+ memcpy(tmp+i[0]+i[1]+i[2]+i[3], f->emision, i[4]);
+ memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4], f->vencimiento, i[5]);
+ memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5], f->estado, i[6]);
+ memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6], f->fp, i[7]);
+ memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7], f->ctacte, i[8]);
+ memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8], f->cheque, i[9]);
+ memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]+i[7]+i[8]+i[9], f->items, i[10]);
break;
case T3:
(*size) = sizeof(t_Factura)-sizeof(char *)-sizeof(t_Item *) + f->cant_items*sizeof(t_Item);
return tmp;
}
+static int procesar_leer_factura(t_Factura *dst, void *src, EMUFS_REG_SIZE size, t_LstFacturas *lst)
+{
+ switch (lst->fp->tipo) {
+ case T1:
+ case T2:
+ return 0;
+ case T3:
+ /* Se que tengo 10 items */
+ /* TODO : Ver porque leer_registro_tipo3 tira mal el size */
+ size = lst->fp->tam_reg;
+ memcpy(dst, src, size-sizeof(t_Item)*10);
+ dst->items = (t_Item *)malloc(10*sizeof(t_Item));
+ memcpy(dst->items, src+size-sizeof(t_Item)*10, 10*sizeof(t_Item));
+ }
+ return 0;
+}
+