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;
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 */
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);
}