X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/35c84de4b6d96cf3505ad2c075ff3998be04441b..9da17243492426daba1cf11c353f4216e7e34ca1:/emufs_gui/articulos.c?ds=inline diff --git a/emufs_gui/articulos.c b/emufs_gui/articulos.c index 519ea4c..0fd92b1 100644 --- a/emufs_gui/articulos.c +++ b/emufs_gui/articulos.c @@ -75,6 +75,7 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) char *prop; EMUFS_REG_SIZE size; t_LstArticulos *tmp; + t_Articulo *un_articulo; lst_articulos = NULL; EMUFS_REG_ID id; @@ -111,6 +112,7 @@ t_LstArticulos *art_cargar(const char *filename, int tipo, int tam_bloque) 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, "desc", IND_EXAHUSTIVO, IND_B, IDX_STRING, STRUCT_OFFSET(un_articulo, desc), 512); emufs_agregar_indice(tmp->fp, "codigo", IND_PRIMARIO, IND_B, IDX_INT, 0, 512); if (!tmp->fp) { PERR("NO SE PUDO CREAR ARCHIVO ARTICULOS"); @@ -209,13 +211,17 @@ t_Articulo *art_obtener(t_LstArticulos *lst, int numero, EMUFS_REG_ID *id) void *tmp; int error = 0; EMUFS_REG_SIZE size; + CLAVE k; + + if (lst == NULL) lst = lst_articulos; + if (lst == NULL) return NULL; (*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; - tmp = lst->fp->leer_registro(lst->fp, emufs_indice_generar_clave_desde_valor(lst->fp->indices, (char *)&numero), &size, &error); - + 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; @@ -261,7 +267,9 @@ void art_modificar(char *s) wrefresh(win); if (s == NULL) { + PERR("Voy a buscar con el formulario"); articulo = art_form_buscar(win, &codigo); + PERR("Ya lo tengo!!!!!!"); } else { codigo = atoi(s); /* Leo el registro directamente */ @@ -329,8 +337,8 @@ void art_eliminar(char *s) { WINDOW *win; t_Articulo *articulo; - t_Reg_Articulo *nodo; EMUFS_REG_ID id; + CLAVE k; win = newwin(8, COLS-2, 13, 1); box(win, 0, 0); @@ -345,15 +353,8 @@ void art_eliminar(char *s) wrefresh(win); getch(); } else { - nodo = lst_articulos->primero; - while (nodo) { - if (nodo->numero == articulo->numero) { - lst_articulos->fp->borrar_registro(lst_articulos->fp, nodo->num_reg); - eliminar_nodo_articulo(lst_articulos, nodo); - break; - } - nodo = nodo->sig; - } + k = emufs_indice_generar_clave_desde_valor(lst_articulos->fp->indices, (char *)&(articulo->numero)); + lst_articulos->fp->borrar_registro(lst_articulos->fp, k); free(articulo); } @@ -367,11 +368,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); @@ -389,15 +391,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")); @@ -417,8 +415,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); } @@ -637,3 +633,7 @@ int art_exportar_xml(const char *filename) return 1; } +void art_consultas(char *s) +{ +} +