X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/415f6c3133586644278dbbe5fd2b1c566ededa45..1a91316f990d419553dcad3b40074f6484d28b28:/emufs_gui/articulos.c?ds=sidebyside diff --git a/emufs_gui/articulos.c b/emufs_gui/articulos.c index fbe6fa3..f3df42d 100644 --- a/emufs_gui/articulos.c +++ b/emufs_gui/articulos.c @@ -70,6 +70,7 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) xmlDocPtr document; xmlNode *node, *inicio; int error = 0, i; + char *prop; EMUFS_REG_SIZE size; t_LstArticulos *tmp; lst_articulos = NULL; @@ -81,6 +82,7 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) tmp->primero = NULL; if (filename != NULL) { + PERR("Voy a crear desde un XML"); document = xmlReadFile(filename, "ISO-8859-1",0); if (document == NULL) { free(tmp); @@ -101,6 +103,7 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) node = node->next; } + fprintf(stderr, "Creando articulos con bloque = %d\n", tam_bloque); tmp->fp = emufs_crear("articulos", tipo-1, tam_bloque, sizeof(t_Articulo)); for (node=inicio ; node ; node = node->next) { if (node->type == XML_ELEMENT_NODE) { @@ -108,13 +111,15 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) t_Articulo art; void *save; memset(&art, '*', sizeof(t_Articulo)); - art.numero = atoi(xmlGetProp(node, "NroArtículo")); - strcpy(art.desc, xmlGetProp(node, "Descripción")); - strcpy(art.presentacion, xmlGetProp(node, "Presentación")); - strcpy(art.existencia, xmlGetProp(node, "Existencia")); + prop = xmlGetProp(node, "NroArtículo"); + art.numero = atoi(prop); + xmlFree(prop); + strcpy(art.desc, prop = xmlGetProp(node, "Descripción")); xmlFree(prop); + strcpy(art.presentacion, prop = xmlGetProp(node, "Presentación")); xmlFree(prop); + strcpy(art.existencia, prop = xmlGetProp(node, "Existencia")); xmlFree(prop); /*strncpy(tmp->array[cant].ubicacion, xmlGetProp(node, "Ubicacion"), 30);*/ - strcpy(art.pvu, xmlGetProp(node, "PVU")); - strcpy(art.emin, xmlGetProp(node, "Emín")); + strcpy(art.pvu, prop = xmlGetProp(node, "PVU")); xmlFree(prop); + strcpy(art.emin, prop = xmlGetProp(node, "Emín")); xmlFree(prop); /* Ya leido el articulo ahora paso a guardarlo en el archivo y agregarlo a la lista */ save = procesar_guardar_articulo(&art, &size, lst_articulos); if (save != NULL) { @@ -129,7 +134,14 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) xmlFreeDoc(document); xmlCleanupParser(); } else { + PERR("Voy a recuperar desde un archivo"); tmp->fp = emufs_abrir("articulos"); + if (tmp->fp == NULL) { + PERR("No se pudo cargar archivo de articulos."); + free(tmp); + lst_articulos = NULL; + return NULL; + } /* Ahora trato de recuperar la info */ indices = emufs_idx_get(tmp->fp, &indices_cant); for(i=0; inumero, ini, sizeof(unsigned int)); ini+=sizeof(unsigned int); /* Ahora empieza el juego */ @@ -427,6 +439,7 @@ int procesar_leer_articulo(t_Articulo *dst, void *src, EMUFS_REG_SIZE size, t_Ls ini = fin+1; fin = ini; while (*fin!='\0') fin++; + fprintf(stderr, "INI=%s\n", ini); memcpy(dst->presentacion, ini, fin-ini+1); ini = fin+1;