X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/840e216ee1d0b23864f75f44ba549899669d9595..a8dad3d5bafadb9bca3335952462f05192a5059c:/emufs_gui/articulos.c diff --git a/emufs_gui/articulos.c b/emufs_gui/articulos.c index 96f6b3d..ad5d9f4 100644 --- a/emufs_gui/articulos.c +++ b/emufs_gui/articulos.c @@ -1,6 +1,8 @@ #include "articulos.h" #include "idx.h" +#include "gui.h" +#include "common.h" static t_LstArticulos *lst_articulos; @@ -70,6 +72,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,8 +84,11 @@ 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); + lst_articulos = NULL; return NULL; } @@ -106,16 +112,24 @@ 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")); - /*strncpy(tmp->array[cant].ubicacion, xmlGetProp(node, "Ubicacion"), 30);*/ - strcpy(art.pvu, xmlGetProp(node, "PVU")); - strcpy(art.emin, xmlGetProp(node, "Emín")); + prop = xml_get_prop(node, "NroArtículo"); + art.numero = atoi(prop); + xmlFree(prop); + strncpy(art.desc, prop = xml_get_prop(node, "Descripción"), 50); xmlFree(prop); + art.desc[50] = '\0'; /* Me aseguro de que este */ + strncpy(art.presentacion, prop = xml_get_prop(node, "Presentación"), 30); xmlFree(prop); + 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.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); + art.emin[8] = '\0'; /* Me aseguro de que este */ /* 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); @@ -126,13 +140,21 @@ 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; ifp->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)); @@ -147,11 +169,16 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) int art_liberar(t_LstArticulos *l) { + t_Reg_Articulo *del; if (l == NULL) l = lst_articulos; if (l == NULL) return 1; 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; @@ -222,7 +249,7 @@ void art_modificar(char *s) EMUFS_REG_SIZE size; EMUFS_REG_ID id; - win = newwin(8, COLS-2, 13, 1); + win = newwin(9, COLS-2, 13, 1); box(win, 0, 0); wrefresh(win); @@ -255,6 +282,7 @@ void art_modificar(char *s) form_agregar_widget(form, INPUT, "Descripción", 50, articulo->desc); form_agregar_widget(form, INPUT, "Presentación", 30, articulo->presentacion); form_agregar_widget(form, INPUT, "Stock Actual", 8, articulo->existencia); + form_agregar_widget(form, INPUT, "Ubicacion", 30, articulo->ubicacion); form_agregar_widget(form, INPUT, "PVU", 8, articulo->pvu); form_agregar_widget(form, INPUT, "Stock Mínimo", 8, articulo->emin); form_ejecutar(form, 1,1); @@ -264,6 +292,7 @@ void art_modificar(char *s) strcpy(articulo->desc, form_obtener_valor_char(form, "Descripción")); strcpy(articulo->presentacion, form_obtener_valor_char(form, "Presentación")); strcpy(articulo->existencia, form_obtener_valor_char(form, "Stock Actual")); + strcpy(articulo->ubicacion, form_obtener_valor_char(form, "Ubicacion")); strcpy(articulo->pvu, form_obtener_valor_char(form, "PVU")); strcpy(articulo->emin, form_obtener_valor_char(form, "Stock Mínimo")); /* Ya actualice los datos, ahora veo de grabarlos */ @@ -336,7 +365,7 @@ void art_agregar(char *s) EMUFS_REG_SIZE size; EMUFS_REG_ID id; - win = newwin(8, COLS-2, 13, 1); + win = newwin(9, COLS-2, 13, 1); box(win, 0, 0); wrefresh(win); @@ -345,6 +374,7 @@ void art_agregar(char *s) form_agregar_widget(form, INPUT, "Descripción", 50, ""); form_agregar_widget(form, INPUT, "Presentación", 30, ""); form_agregar_widget(form, INPUT, "Stock Actual", 8, ""); + form_agregar_widget(form, INPUT, "Ubicacion", 30, ""); form_agregar_widget(form, INPUT, "PVU", 8, ""); form_agregar_widget(form, INPUT, "Stock Mínimo", 8, ""); form_ejecutar(form, 1,1); @@ -364,13 +394,14 @@ void art_agregar(char *s) strcpy(art.desc, form_obtener_valor_char(form, "Descripción")); strcpy(art.presentacion, form_obtener_valor_char(form, "Presentación")); strcpy(art.existencia, form_obtener_valor_char(form, "Stock Actual")); - /*strncpy(tmp->array[cant].ubicacion, xmlGetProp(node, "Ubicacion"), 30);*/ + strcpy(art.ubicacion, form_obtener_valor_char(form, "Ubicacion")); strcpy(art.pvu, form_obtener_valor_char(form, "PVU")); strcpy(art.emin, form_obtener_valor_char(form, "Stock Mínimo")); /* 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 +436,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, 0, sizeof(t_Articulo)); memcpy(&dst->numero, ini, sizeof(unsigned int)); ini+=sizeof(unsigned int); /* Ahora empieza el juego */ @@ -423,6 +455,11 @@ int procesar_leer_articulo(t_Articulo *dst, void *src, EMUFS_REG_SIZE size, t_Ls while (*fin!='\0') fin++; memcpy(dst->existencia, ini, fin-ini+1); + ini = fin+1; + fin = ini; + while (*fin!='\0') fin++; + memcpy(dst->ubicacion, ini, fin-ini+1); + ini = fin+1; fin = ini; while (*fin!='\0') fin++; @@ -430,7 +467,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: @@ -443,7 +480,7 @@ int procesar_leer_articulo(t_Articulo *dst, void *src, EMUFS_REG_SIZE size, t_Ls void *procesar_guardar_articulo(t_Articulo *src, EMUFS_REG_SIZE *size, t_LstArticulos *lst) { char *tmp=NULL; - int i[6]; + int i[7]; char *from = (char *)src; switch(lst->fp->tipo) { case T1: @@ -453,24 +490,27 @@ void *procesar_guardar_articulo(t_Articulo *src, EMUFS_REG_SIZE *size, t_LstArti i[1] = sizeof(char)*(strlen(src->desc)+1); i[2] = sizeof(char)*(strlen(src->presentacion)+1); i[3] = sizeof(char)*(strlen(src->existencia)+1); -/* i[4] = sizeof(char)*(strlen(src->ubicacion)+1); */ - i[4] = sizeof(char)*(strlen(src->pvu)+1); - i[5] = sizeof(char)*(strlen(src->emin)+1); - (*size) = i[0]+i[1]+i[2]+i[3]+i[4]+i[5]; + i[4] = sizeof(char)*(strlen(src->ubicacion)+1); + i[5] = sizeof(char)*(strlen(src->pvu)+1); + i[6] = sizeof(char)*(strlen(src->emin)+1); + (*size) = i[0]+i[1]+i[2]+i[3]+i[4]+i[5]+i[6]; 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]); memcpy(tmp+i[0]+i[1]+i[2], src->existencia, i[3]); - memcpy(tmp+i[0]+i[1]+i[2]+i[3], src->pvu, i[4]); - memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4], src->emin, i[5]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3], src->ubicacion, i[4]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4], src->pvu, i[5]); + memcpy(tmp+i[0]+i[1]+i[2]+i[3]+i[4]+i[5], src->emin, i[6]); break; case T3: /* Lleno el lugar no ocupado de los strings con *, para que el ver * 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); } @@ -487,17 +527,17 @@ 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; - fprintf(stderr, "Me prepado para cambiar de archivo\n"); - /* 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"); + PERR("ARCHIVO NUEVO NO CREADO"); return; } @@ -507,43 +547,50 @@ 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) { - fprintf(stderr, "NO HAY INDICES!\n"); art_liberar(lst_nueva); return; } + PERR("Proceso datos\n"); 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); } } } + 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! */ -/* rename("emufs_tmp.dat", "articulos.dat"); + 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");*/ + rename("emufs_tmp.did", "articulos.did"); + PERR("==== TERMINE ====\n"); }