X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/840e216ee1d0b23864f75f44ba549899669d9595..2bbb263b7b66a8b883e1700cdf4552369b17696e:/emufs_gui/articulos.c diff --git a/emufs_gui/articulos.c b/emufs_gui/articulos.c index 96f6b3d..b9605c2 100644 --- a/emufs_gui/articulos.c +++ b/emufs_gui/articulos.c @@ -83,6 +83,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; } @@ -116,6 +118,7 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) /* 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) { + error = 0; id = tmp->fp->grabar_registro(tmp->fp, save, size, &error); agregar_nodo_articulo(tmp, crear_nodo_articulo(id, art.numero)); free(save); @@ -133,6 +136,7 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) t_Articulo art; void *save; /* Leo el registro */ + error = 0; save = tmp->fp->leer_registro(tmp->fp, indices[i], &size, &error); if (procesar_leer_articulo(&art, save, size, tmp) == 1) { agregar_nodo_articulo(tmp, crear_nodo_articulo(indices[i], art.numero)); @@ -149,9 +153,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; @@ -371,6 +380,7 @@ void art_agregar(char *s) /* 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) { + error = 0; id = lst_articulos->fp->grabar_registro(lst_articulos->fp, save, size, &error); if (error) { wattron(win, COLOR_PAIR(COLOR_YELLOW)); @@ -405,6 +415,7 @@ int procesar_leer_articulo(t_Articulo *dst, void *src, EMUFS_REG_SIZE size, t_Ls case T2: ini = (char *)src; /* Copio el primer campo, esto es facil :-) */ + memset(dst, '*', sizeof(t_Articulo)); memcpy(&dst->numero, ini, sizeof(unsigned int)); ini+=sizeof(unsigned int); /* Ahora empieza el juego */ @@ -430,7 +441,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: @@ -459,6 +470,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]); @@ -471,6 +483,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); } @@ -492,8 +505,6 @@ void art_reformatear(int tipo, int tam_bloque, int tam_reg) /* Si el tipo es el mismo, no tengo que hacer nada! */ if (old->tipo == tipo) return; - fprintf(stderr, "Me prepado para cambiar de archivo\n"); - /* Creo el nuevo file */ nuevo = emufs_crear("emufs_tmp", tipo, tam_bloque, sizeof(t_Articulo)); if (nuevo == NULL) { @@ -509,41 +520,39 @@ void art_reformatear(int tipo, int tam_bloque, int tam_reg) /* Leo los indices del archivo viejo */ indices = emufs_idx_get(old, &indices_total); if (indices == NULL) { - fprintf(stderr, "NO HAY INDICES!\n"); art_liberar(lst_nueva); return; } for(i=0; ileer_registro(old, indices[i], &size, &error); - fprintf(stderr, "Lei\n"); if (procesar_leer_articulo(&art, save, size, lst_articulos) == 1) { - fprintf(stderr, "Procese\n"); free(save); /* Lei un registro Ok. Lo salvo en el archivo nuevo */ save = procesar_guardar_articulo(&art, &size, lst_nueva); - fprintf(stderr, "Procese guardar\n"); if (save) { + error = 0; id = nuevo->grabar_registro(nuevo, save, size, &error); - fprintf(stderr, "Guarde\n"); agregar_nodo_articulo(lst_nueva, crear_nodo_articulo(id, art.numero)); free(save); } } } + ver_archivo_FS(old); + ver_archivo_FS(nuevo); + art_liberar(lst_articulos); lst_articulos = lst_nueva; fprintf(stderr, "Listo. Renombre y me voy\n"); /* Muevo los archivos! */ /* TODO : Poner en otro lugar mas generico! */ -/* rename("emufs_tmp.dat", "articulos.dat"); + rename("emufs_tmp.dat", "articulos.dat"); rename("emufs_tmp.idx", "articulos.idx"); rename("emufs_tmp.fsc", "articulos.fsc"); - rename("emufs_tmp.did", "articulos.did");*/ + rename("emufs_tmp.did", "articulos.did"); }