X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/d810be9c12d7287014d4af8dfd480e27c64a325b..5c39a8b8061f2ae5c22a12e40d1b9f4ffea42c68:/emufs_gui/articulos.c?ds=sidebyside diff --git a/emufs_gui/articulos.c b/emufs_gui/articulos.c index 7fda604..8fcd2ee 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; @@ -83,6 +84,8 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) if (filename != NULL) { document = xmlReadFile(filename, "ISO-8859-1",0); if (document == NULL) { + free(tmp); + lst_articulos = NULL; return NULL; } @@ -106,13 +109,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) { @@ -151,9 +156,14 @@ int art_liberar(t_LstArticulos *l) { if (l == NULL) l = lst_articulos; if (l == NULL) return 1; + t_Reg_Articulo *del; emufs_destruir(l->fp); - /* TODO : Liberar lista */ + while (l->primero) { + del = l->primero; + l->primero = l->primero->sig; + free(del); + } free(l); lst_articulos = NULL; @@ -434,7 +444,7 @@ int procesar_leer_articulo(t_Articulo *dst, void *src, EMUFS_REG_SIZE size, t_Ls ini = fin+1; fin = (char *)src+size; - memcpy(dst->emin, ini, fin-ini+1); + memcpy(dst->emin, ini, fin-ini); break; case T3: @@ -463,6 +473,7 @@ void *procesar_guardar_articulo(t_Articulo *src, EMUFS_REG_SIZE *size, t_LstArti (*size) = i[0]+i[1]+i[2]+i[3]+i[4]+i[5]; tmp = (char *)malloc((*size)); if (tmp == NULL) return NULL; + memset(tmp, 0, *size); memcpy(tmp, &src->numero, i[0]); memcpy(tmp+i[0], src->desc, i[1]); memcpy(tmp+i[0]+i[1], src->presentacion, i[2]); @@ -475,6 +486,7 @@ void *procesar_guardar_articulo(t_Articulo *src, EMUFS_REG_SIZE *size, t_LstArti * registro se vea bien */ tmp = (char *)malloc(sizeof(t_Articulo)); + memset(tmp, '*', sizeof(t_Articulo)); memcpy(tmp, from, sizeof(t_Articulo)); (*size) = sizeof(t_Articulo); } @@ -491,12 +503,14 @@ void art_reformatear(int tipo, int tam_bloque, int tam_reg) int error; char *save; + 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)); if (nuevo == NULL) { fprintf(stderr, "ARCHIVO NUEVO NO CREADO\n"); @@ -509,14 +523,15 @@ void art_reformatear(int tipo, int tam_bloque, int tam_reg) lst_nueva->fp = nuevo; /* Leo los indices del archivo viejo */ + PERR("Obtengo Indices\n"); indices = emufs_idx_get(old, &indices_total); if (indices == NULL) { art_liberar(lst_nueva); return; } + PERR("Proceso datos\n"); for(i=0; ileer_registro(old, indices[i], &size, &error); if (procesar_leer_articulo(&art, save, size, lst_articulos) == 1) { @@ -532,18 +547,26 @@ void art_reformatear(int tipo, int tam_bloque, int tam_reg) } } - ver_archivo_FS(old); - ver_archivo_FS(nuevo); + free(indices); + PERR("Libero lo viejo\n"); art_liberar(lst_articulos); + + PERR("Ahora tengo lo nuevo\n"); lst_articulos = lst_nueva; - fprintf(stderr, "Listo. Renombre y me voy\n"); + /* El nuevo tiene como nombre emufs_tmp, lo cambio a mano! */ + free(lst_articulos->fp->nombre); + lst_articulos->fp->nombre = (char *)malloc(sizeof(char)*(strlen("articulos")+1)); + strcpy(lst_articulos->fp->nombre, "articulos"); + /* Muevo los archivos! */ /* TODO : Poner en otro lugar mas generico! */ + PERR("Renombre!!\n"); rename("emufs_tmp.dat", "articulos.dat"); rename("emufs_tmp.idx", "articulos.idx"); rename("emufs_tmp.fsc", "articulos.fsc"); rename("emufs_tmp.did", "articulos.did"); + PERR("==== TERMINE ====\n"); }