return 0;
} else {
if (i == 0) {
- if (header.nivel != 0) {
- nodo = b_leer_nodo(idx, header.hijo_izquierdo);
- nodo_id = header.hijo_izquierdo;
- } else {
- nodo = NULL;
- nodo_id = -1;
- }
+ nodo = b_leer_nodo(idx, header.hijo_izquierdo);
+ nodo_id = header.hijo_izquierdo;
} else {
- if (header.nivel != 0) {
- nodo = b_leer_nodo(idx, claves[i-1].dato.bloque);
- nodo_id = claves[i-1].dato.bloque;
- } else {
- nodo = NULL;
- nodo_id = -1;
- }
+ nodo = b_leer_nodo(idx, claves[i-1].hijo_derecho);
+ nodo_id = claves[i-1].hijo_derecho;
}
}
}
if (i == 0) {
nodo = b_leer_nodo(idx, header.hijo_izquierdo);
} else {
- nodo = b_leer_nodo(idx, claves[i-1].dato.bloque);
+ nodo = b_leer_nodo(idx, claves[i-1].hijo_derecho);
}
free(tmp);
}
}
tmp_claves[i].clave = clave;
tmp_claves[i].dato = dato;
+ tmp_claves[i].hijo_derecho = hijo1;
+ tmp_claves[i+1].hijo_derecho = hijo2;
while (i < nodo_header.cant) {
tmp_claves[i+1] = claves[i];
i++;
if (nodo_id != 0) {
clave = tmp_claves[total/2].clave;
- dato.bloque = nuevo_id;
+ /* XXX dato.bloque = nuevo_id; */
b_grabar_nodo(idx, nodo_id, nodo);
b_grabar_nodo(idx, nuevo_id, nuevo);
nodo = tmp_nuevo;
clave = tmp_claves[total/2].clave;
- dato.bloque = nuevo_id;
+ /* XXX dato.bloque = nuevo_id; */
b_grabar_nodo(idx, nuevo_id+1, nodo);
b_grabar_nodo(idx, nuevo_id, nuevo);
nodo_header.cant++;
claves[i].clave = clave;
claves[i].dato = dato;
- nodo_header.hijo_izquierdo = b_elegir_izquierdo(idx, nodo_header.hijo_izquierdo, hijo1);
+ claves[i].hijo_derecho = hijo2;
+ nodo_header.hijo_izquierdo = hijo1; /*b_elegir_izquierdo(idx, nodo_header.hijo_izquierdo, hijo1);*/
b_actualizar_header(nodo, &nodo_header);
b_grabar_nodo(idx, nodo_id, nodo);
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);
}