if (lst == NULL) lst = lst_articulos;
if (lst == NULL) return NULL;
- fprintf(stderr, "Me piden que busque en el indice el codigo=%d\n", numero);
(*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;
- PERR("Genero clave");
k = emufs_indice_generar_clave_desde_valor(lst->fp->indices, (char *)&numero);
- PERR("Buscando en archivo");
tmp = lst->fp->leer_registro(lst->fp, k, &size, &error);
- PERR("Lo encontre?");
if (error) {
free(art);
return NULL;
}
- printf("SI LO ENCONTRE!!!!");
if (procesar_leer_articulo(art, tmp, size, lst_articulos) != 1) {
free(art);
free(tmp);
return NULL;
}
- printf("RETORNANDO el articulo procesado");
free(tmp);
return art;
}
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);
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"));
wattroff(win, COLOR_PAIR(COLOR_YELLOW));
wrefresh(win);
getch();
- } else {
- agregar_nodo_articulo(lst_articulos, crear_nodo_articulo(id, art.numero));
}
free(save);
}