X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/3719f9bdbbeb0b8573b5887edc0aa2c9e835760a..e8fa2ccccf10bdfcff1aedbaf919f3bc823f1ecf:/emufs_gui/articulos.c?ds=sidebyside diff --git a/emufs_gui/articulos.c b/emufs_gui/articulos.c index 83f4522..59a3f35 100644 --- a/emufs_gui/articulos.c +++ b/emufs_gui/articulos.c @@ -2,6 +2,7 @@ #include "articulos.h" #include "idx.h" #include "gui.h" +#include "common.h" static t_LstArticulos *lst_articulos; @@ -70,12 +71,12 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) { xmlDocPtr document; xmlNode *node, *inicio; - int error = 0, i; + int error = 0; char *prop; EMUFS_REG_SIZE size; t_LstArticulos *tmp; lst_articulos = NULL; - EMUFS_REG_ID id, *indices, indices_cant; + EMUFS_REG_ID id; tmp = (t_LstArticulos *)malloc(sizeof(t_LstArticulos)); if (tmp == NULL) return NULL; @@ -103,14 +104,28 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) } node = node->next; } - +#ifdef DEBUG + fprintf(stderr, "Articulos : Tipo=%d Bloque=%d\n", tipo-1, tam_bloque); +#endif + /* Creo el FS */ tmp->fp = emufs_crear("articulos", tipo-1, tam_bloque, sizeof(t_Articulo)); + /* Agrego los indices */ + PERR("Voy a agregar un indice"); + emufs_agregar_indice(tmp->fp, "codigo", IND_PRIMARIO, IND_B, IDX_INT, 0, 512); + if (!tmp->fp) { + PERR("NO SE PUDO CREAR ARCHIVO ARTICULOS"); + free(tmp); + xmlFreeDoc(document); + xmlCleanupParser(); + lst_articulos = NULL; + return NULL; + } for (node=inicio ; node ; node = node->next) { if (node->type == XML_ELEMENT_NODE) { if (strcmp(node->name, "ARTICULO") == 0) { t_Articulo art; void *save; - memset(&art, '*', sizeof(t_Articulo)); + memset(&art, 0, sizeof(t_Articulo)); prop = xml_get_prop(node, "NroArtículo"); art.numero = atoi(prop); xmlFree(prop); @@ -120,7 +135,7 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) art.presentacion[30] = '\0'; /* Me aseguro de que este */ strncpy(art.existencia, prop = xml_get_prop(node, "Existencia"), 8); xmlFree(prop); art.existencia[8] = '\0'; /* Me aseguro de que este */ - strncpy(art.ubicacion, prop = xml_get_prop(node, "Ubicacion"), 30); xmlFree(prop); + strncpy(art.ubicacion, prop = xml_get_prop(node, "Ubicación"), 30); xmlFree(prop); strncpy(art.pvu, prop = xml_get_prop(node, "PVU"), 8); xmlFree(prop); art.pvu[8] = '\0'; /* Me aseguro de que este */ strncpy(art.emin, prop = xml_get_prop(node, "Emín"), 8); xmlFree(prop); @@ -139,7 +154,10 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) xmlFreeDoc(document); xmlCleanupParser(); } else { - PERR("Voy a recuperar desde un archivo"); +/* XXX Ahora no necesito leer nada del archivo cuando lo cargo + * pues tengo todo en los indices + * + * PERR("Voy a recuperar desde un archivo"); tmp->fp = emufs_abrir("articulos"); if (tmp->fp == NULL) { PERR("No se pudo cargar archivo de articulos."); @@ -147,12 +165,12 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) lst_articulos = NULL; return NULL; } - /* Ahora trato de recuperar la info */ + Ahora trato de recuperar la info indices = emufs_idx_get(tmp->fp, &indices_cant); for(i=0; ifp->leer_registro(tmp->fp, indices[i], &size, &error); if (procesar_leer_articulo(&art, save, size, tmp) == 1) { @@ -161,6 +179,7 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) } } free(indices); +*/ } return tmp; @@ -184,43 +203,36 @@ int art_liberar(t_LstArticulos *l) return 0; } -t_Articulo *art_obtener(t_LstArticulos *lst, const char *numero, EMUFS_REG_ID *id) +t_Articulo *art_obtener(t_LstArticulos *lst, int numero, EMUFS_REG_ID *id) { t_Articulo *art; - t_Reg_Articulo *nodo; void *tmp; int error = 0; EMUFS_REG_SIZE size; - int n = atoi(numero); + CLAVE k; if (lst == NULL) lst = lst_articulos; if (lst == NULL) return NULL; - nodo = lst->primero; - while (nodo) { - if (n == nodo->numero) { - (*id) = nodo->num_reg; - art = (t_Articulo *)malloc(sizeof(t_Articulo)); - /* Ya se cual tengo que retornar. Ahora veo si lo cargo desde el archivo */ - error = 0; - tmp = lst->fp->leer_registro(lst->fp, nodo->num_reg, &size, &error); - - if (error) { - free(art); - return NULL; - } - if (procesar_leer_articulo(art, tmp, size, lst_articulos) != 1) { - free(art); - free(tmp); - return NULL; - } - free(tmp); - return art; - } - nodo = nodo->sig; + (*id) = -1; /* XXX Ver que se hacia con esto */ + art = (t_Articulo *)malloc(sizeof(t_Articulo)); + /* Ya se cual tengo que retornar. Ahora veo si lo cargo desde el archivo */ + error = 0; + k = emufs_indice_generar_clave_desde_valor(lst->fp->indices, (char *)&numero); + tmp = lst->fp->leer_registro(lst->fp, k, &size, &error); + if (error) { + free(art); + return NULL; + } + + if (procesar_leer_articulo(art, tmp, size, lst_articulos) != 1) { + free(art); + free(tmp); + return NULL; } - return NULL; + free(tmp); + return art; } t_Articulo *art_form_buscar(WINDOW *win, EMUFS_REG_ID *id) @@ -231,7 +243,7 @@ t_Articulo *art_form_buscar(WINDOW *win, EMUFS_REG_ID *id) form = form_crear(win); form_agregar_widget(form, INPUT, "Numero de Artículo", 8, ""); form_ejecutar(form, 1,1); - articulo = art_obtener(NULL, form_obtener_valor_char(form, "Numero de Artículo"), id); + articulo = art_obtener(NULL, form_obtener_valor_int(form, "Numero de Artículo"), id); form_destruir(form); return articulo; @@ -246,21 +258,24 @@ void art_modificar(char *s) void *tmp; int error; EMUFS_REG_SIZE size; - EMUFS_REG_ID id; + EMUFS_REG_ID codigo; win = newwin(9, COLS-2, 13, 1); box(win, 0, 0); wrefresh(win); if (s == NULL) { - articulo = art_form_buscar(win, &id); + PERR("Voy a buscar con el formulario"); + articulo = art_form_buscar(win, &codigo); + PERR("Ya lo tengo!!!!!!"); } else { - id = atoi(s); + codigo = atoi(s); /* Leo el registro directamente */ articulo = (t_Articulo *)malloc(sizeof(t_Articulo)); /* Ya se cual tengo que retornar. Ahora veo si lo cargo desde el archivo */ error = 0; - tmp = lst_articulos->fp->leer_registro(lst_articulos->fp, id, &size, &error); + tmp = lst_articulos->fp->leer_registro(lst_articulos->fp, + emufs_indice_generar_clave_desde_valor(lst_articulos->fp->indices, (char *)&codigo), &size, &error); if (error) { free(articulo); articulo = NULL; @@ -298,7 +313,7 @@ void art_modificar(char *s) tmp = procesar_guardar_articulo(articulo, &size, lst_articulos); if (tmp) { error = 0; - lst_articulos->fp->modificar_registro(lst_articulos->fp, id, tmp, size, &error); + lst_articulos->fp->modificar_registro(lst_articulos->fp, codigo, tmp, size, &error); free(tmp); } @@ -358,11 +373,12 @@ void art_agregar(char *s) WINDOW *win; t_Form *form; t_Articulo art; - t_Reg_Articulo *nuevo; void *save; int error = 0, existe; EMUFS_REG_SIZE size; EMUFS_REG_ID id; + INDICE_DATO dato; + CLAVE k; win = newwin(9, COLS-2, 13, 1); box(win, 0, 0); @@ -380,15 +396,11 @@ void art_agregar(char *s) art.numero = atoi(form_obtener_valor_char(form, "Numero de Artículo")); existe = 0; - nuevo = lst_articulos->primero; - while (nuevo) { - if (art.numero == nuevo->numero) { - existe = 1; - break; - } - nuevo = nuevo->sig; - } - + /* Me dijo que no existe el codigo */ + k = emufs_indice_generar_clave_desde_valor(lst_articulos->fp->indices, (char *)&art.numero); + dato = lst_articulos->fp->indices->existe_entrada(lst_articulos->fp->indices, k); + if (dato.id != -1) existe = 1; + if (!existe) { strcpy(art.desc, form_obtener_valor_char(form, "Descripción")); strcpy(art.presentacion, form_obtener_valor_char(form, "Presentación")); @@ -408,8 +420,6 @@ void art_agregar(char *s) wattroff(win, COLOR_PAIR(COLOR_YELLOW)); wrefresh(win); getch(); - } else { - agregar_nodo_articulo(lst_articulos, crear_nodo_articulo(id, art.numero)); } free(save); } @@ -518,6 +528,7 @@ void *procesar_guardar_articulo(t_Articulo *src, EMUFS_REG_SIZE *size, t_LstArti void art_reformatear(int tipo, int tam_bloque, int tam_reg) { +#ifdef NO_SE_PUEDE_USAR EMUFS *nuevo, *old; EMUFS_REG_ID *indices, id; EMUFS_REG_SIZE indices_total, i, size; @@ -529,9 +540,6 @@ void art_reformatear(int tipo, int tam_bloque, int tam_reg) PERR("==== EMPIEZO ====\n"); old = lst_articulos->fp; - /* Si el tipo es el mismo, no tengo que hacer nada! */ - if (old->tipo == tipo) return; - /* Creo el nuevo file */ PERR("Creo el archivo\n"); nuevo = emufs_crear("emufs_tmp", tipo, tam_bloque, sizeof(t_Articulo)); @@ -591,5 +599,42 @@ void art_reformatear(int tipo, int tam_bloque, int tam_reg) rename("emufs_tmp.fsc", "articulos.fsc"); rename("emufs_tmp.did", "articulos.did"); PERR("==== TERMINE ====\n"); +#endif +} + +int art_exportar_xml(const char *filename) +{ + t_Reg_Articulo *nodo; + t_Articulo *art; + EMUFS_REG_ID id; + FILE *fp; + + if (lst_articulos->primero == NULL) return 0; + + nodo = lst_articulos->primero; + + if (!(fp = fopen(filename, "wt"))) return 0; + + fprintf(fp, "\n\n"); + fprintf(fp, "\n"); + while (nodo) { + art = art_obtener(lst_articulos, nodo->numero, &id); + if (art != NULL) { + fprintf(fp, "\tnumero); + fprintf(fp, "Descripción=\"%s\" ", art->desc); + fprintf(fp, "Presentación=\"%s\" ", art->presentacion); + fprintf(fp, "Ubicación=\"%s\" ", art->ubicacion); + fprintf(fp, "Existencia=\"%s\" ", art->existencia); + fprintf(fp, "PVU=\"%s\" ", art->pvu); + fprintf(fp, "Emín=\"%s\" />\n", art->emin); + free(art); + } + nodo = nodo->sig; + } + fprintf(fp, "\n"); + + fclose(fp); + return 1; }