memcpy(bloque, &header, sizeof(B_NodoHeader));
fwrite(bloque, idx->tam_bloque, 1, fp);
+ free(bloque);
fclose(fp);
}
PERR(idx->nombre);
return 0;
}
-
- b_insertar_dup_en_pos(idx, claves[i].dato, dato);
+
+ if ((idx->funcion == IND_SELECCION) && (!emufs_indice_es_clave_nula(idx, clave)))
+ b_insertar_dup_en_pos(idx, claves[i].dato, dato);
if (idx->tipo_dato == IDX_STRING) {
/* Tengo que sacar el texto repetido del archivo de textos */
/* Agrego el DATO real al archivo de claves repetiras
* y me guardo el ID para poner en el indice
*/
+ if ((idx->funcion == IND_SELECCION) && (emufs_indice_es_clave_nula(idx, clave)))
+ /* UPS!, la clave que se va a insertar por primera vez es nula
+ * y soy un indice selectivo!, no lo puedo permitir, ciao!!
+ */
+ return 1;
dummy.id = -1;
dato.id = b_insertar_dup_en_pos(idx, dummy, dato);
}
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);
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);
b_leer_header(der, &der_h);
padre_entries = b_leer_claves(padre, &padre_h);
/* Inserto en el hijo derecho la clave del padre */
+ PERR("PASAR CLAVE DERECHA");
b_insertar_en_nodo_con_lugar(idx, padre_entries[padre_pos].clave, padre_entries[padre_pos].dato,
der_id, der, der_h.hijo_izquierdo, entry.hijo_derecho);
/* Reemplazo clave del padre por clave nueva */
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) {
/* Busco al mi padre, perdido en un maremoto hace mucho,muchos
* años
*/
- free(nodo);
+ tmp = nodo;
if (header.padre == -1) {
- salida.i_clave = -1;
+ if (nodo_id == 0) {
+ /* Bien, son el nodo raiz y aca tendria que ir hacia mi hijo
+ * derecho
+ */
+ nodo = b_leer_nodo(idx, claves[header.cant-1].hijo_derecho);
+ free(tmp);
+ if (nodo != NULL) {
+ b_leer_header(nodo, &header);
+ claves = b_leer_claves(nodo, &header);
+
+ salida = claves[0].clave;
+ } else
+ salida.i_clave = -1;
+ }
return salida;
}
+ free(nodo);
nodo = b_leer_nodo(idx, header.padre);
b_leer_header(nodo, &header);
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");
return cant;
}
-#include "indice_b_asc.c"
+#ifdef NO_TERMINAOD
+EMUFS_Estadisticas emufs_indice_b_obtener_estadisticas(INDICE *idx)
+{
+ EMUFS_Estadisticas stats, st_string, st_multiples;
+
+ stats.tam_archivo = emufs_common_get_file_size(idx->filename);
+ stats.cant_bloques = stats.tam_archivo/idx->tam_bloque;
+}
+#endif
+
+#include "indice_b_asc.c"