if (encontrado) {
PERR("Clave encontrada, borrando ...");
- fprintf(stderr, "%s: La clave a borrar esta en el nodo %d\n", idx->nombre, nodo_id);
if (idx->funcion != IND_PRIMARIO) {
/* Debo borrar primero la clave desde el archivo de
* claves repetidas, y si recien ahi me quedo sin claves,
*/
PERR("Vamos a borrar duplicados");
encontrado = b_borrar_dup_clave(idx, claves[i].dato, dato);
- fprintf(stderr, "Listo, encontrado = %d\n", encontrado);
}
if (encontrado) {
b_borrar_clave(idx, nodo, nodo_id, k);
{
FILE *fp;
char *out;
- /*B_NodoHeader header;
- B_NodoEntry *claves;*/
+ B_NodoHeader header;
+ B_NodoEntry *claves;
if (id < 0) return NULL;
}
/* Si estoy manejando string tengo que sacar las abreviaturas */
-/* if (idx->tipo_dato == IDX_STRING) {
+ if (idx->tipo_dato == IDX_STRING) {
b_leer_header(out, &header);
claves = b_leer_claves(out, &header);
desabreviar_claves(idx, claves, &header);
- }*/
+ }
fclose(fp);
return out;
}
static void b_grabar_nodo(INDICE *idx, int id, char *data)
{
FILE *fp;
- /*B_NodoHeader header;
- B_NodoEntry *claves;*/
+ B_NodoHeader header;
+ B_NodoEntry *claves;
/* Si las claves son de tipo string debo abreviar antes de guardar */
-/* if (idx->tipo_dato == IDX_STRING) {
+ if (idx->tipo_dato == IDX_STRING) {
b_leer_header(data, &header);
claves = b_leer_claves(data, &header);
abreviar_claves(idx, claves, &header);
- }*/
+ }
fp = fopen(idx->filename, "r+");
fseek(fp, id*idx->tam_bloque, SEEK_SET);
fwrite(data, 1, idx->tam_bloque, fp);
hijo1 = nodo_id;
hijo2 = nuevo_id;
- fprintf(stderr, "Nodos espliteados = %d %d\n", hijo1, hijo2);
nodo = padre;
nodo_id = nodo_header.padre;
} else {
hijo1 = nuevo_id+1;
hijo2 = nuevo_id;
- fprintf(stderr, "Nodos espliteados = %d %d\n", hijo1, hijo2);
/* Limpio al padre */
nuevo = b_leer_nodo(idx, 0);
nuevo_header.padre = -1;
nuevo_header.nivel = nodo_header.nivel+1;
nuevo_header.hijo_izquierdo = -1;
- fprintf(stderr, "root.nivel=%d\n", nuevo_header.nivel);
memset(nuevo, -1, idx->tam_bloque);
b_actualizar_header(nuevo, &nuevo_header);
b_grabar_nodo(idx, 0, nuevo);
char* nuevo = b_leer_nodo(idx, hijo_izq);
if (nuevo != NULL) {
B_NodoHeader nuevo_header;
- fprintf(stderr, "Actualizo padre de %d a %d\n", hijo_izq, nodo_id);
b_leer_header(nuevo, &nuevo_header);
nuevo_header.padre = nodo_id;
b_actualizar_header(nuevo, &nuevo_header);
char* nuevo = b_leer_nodo(idx, hijo_der);
if (nuevo != NULL) {
B_NodoHeader nuevo_header;
- fprintf(stderr, "Actualizo padre de %d a %d\n", hijo_der, nodo_id);
b_leer_header(nuevo, &nuevo_header);
nuevo_header.padre = nodo_id;
b_actualizar_header(nuevo, &nuevo_header);
while (emufs_indice_es_menor(idx, claves[pos].clave, k)) pos++;
/* Es el nodo una hoja? */
- fprintf(stderr, "La clave esta en la pos = %d\n", pos);
if (header.hijo_izquierdo != -1) {
PERR("Nodo no es hoja, intercambio");
actual = b_leer_nodo(idx, claves[pos].hijo_derecho);
/* Se cumple la condicion de hijos? */
PERR("Dejo todo consistente");
- fprintf(stderr, "Condicion : %d >= %d\n", header_actual.cant, MIN_HIJOS(idx));
if ((header_actual.cant >= MIN_HIJOS(idx)) || (actual_id == 0)) {
PERR("Borrar completo sin fundir");
return;
padre = b_leer_nodo(idx, padre_id);
b_leer_header(padre, &header_padre);
claves_padre = b_leer_claves(padre, &header_padre);
- fprintf(stderr, "ID del padre = %d de nivel %d\n", padre_id, header_padre.nivel);
/* TODO Tengo el hijo_izquierdo para revisar!! XXX */
if (header_padre.hijo_izquierdo == actual_id) {
PERR("Soy el hijo izquierdo de padre");
PERR("Ta calcule lo que tengo que hacer");
if ((derecha_id != -1) && (header_der.cant > MIN_HIJOS(idx))) {
PERR("Le pido clave a derecha");
- fprintf(stderr, "ANTES DE PEDIR DERECHA TENGO %d claves\n", header_actual.cant);
- fprintf(stderr, "PEDIR DERECHA DATOS : yo=%d, padre=%d, der=%d, pos_clave=%d\n", actual_id, padre_id, derecha_id, pos_padre);
b_pedir_clave_derecha(der, derecha_id, padre, padre_id, actual, actual_id, pos_padre);
PERR("listo");
b_leer_header(der, &header_der);
b_leer_header(padre, &header_padre);
b_leer_header(actual, &header_actual);
- fprintf(stderr, "DESPUES DE PEDIR DERECHA TENGO %d claves\n", header_actual.cant);
} else if ((izquierda_id != -1) && (header_izq.cant > MIN_HIJOS(idx))) {
PERR("Le pido clave a izquierda");
b_pedir_clave_izquierda(izq, izquierda_id, padre, padre_id, actual, actual_id, pos_padre);
while ((i<header.cant) && (emufs_indice_es_menor(idx, claves[i].clave, k))) i++;
if ((i<header.cant) && (emufs_indice_es_igual(idx, claves[i].clave, k))) {
/* LA ENCONTRE! , ahora busco la siguiente clave!! */
- fprintf(stderr, "Me encontre en pos %d en el padre\n", i);
if ((i+1)<header.cant) {
PERR("Joya, hay lugar a la derecha");
if (claves[i].hijo_derecho == -1) {
*/
nodo = b_leer_nodo(idx, claves[header.cant-1].hijo_derecho);
free(tmp);
- b_leer_header(nodo, &header);
- claves = b_leer_claves(nodo, &header);
+ if (nodo != NULL) {
+ b_leer_header(nodo, &header);
+ claves = b_leer_claves(nodo, &header);
- salida = claves[0].clave;
+ salida = claves[0].clave;
+ } else
+ salida.i_clave = -1;
}
return salida;
}
claves = b_leer_claves(nodo, &header);
i = 0;
PERR("Busco mi siguiente en mi padre");
- fprintf(stderr, "Padre tiene %d claves\n", header.cant);
while ((i<header.cant) && (emufs_indice_es_menor(idx, claves[i].clave, k))) {
i++;
- fprintf(stderr, "Proximo i : %d\n", i);
}
if (i<header.cant) {
PERR("Siguiente clave encontrada");