]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/indice_b.c
Partir 2 en 3 milagrosamente anda (con este pequeño cambio que fue
[z.facultad/75.06/emufs.git] / emufs / indice_b.c
index 82fa4665952f9b63ecc8fc9847208aea6ef020de..f18312ac87da9b54dc75c02a3d1acf89e923b40d 100644 (file)
@@ -43,7 +43,7 @@ static void b_pasar_clave_a_izquierda(INDICE*, char*, int, char*, int, int, B_No
 /** Junta 2 nodos y hace uno solo */
 static void b_fundir_nodo(INDICE *,char *, int, char *, int, char *, int, int);
 /** Crea 3 nodos a partir de 2 llenos */
-static void b_partir_dos_nodos_en_tres(INDICE*, int nodo_izq, int nodo_der, int padre, B_NodoEntry nuevo_entry);
+static void b_partir_dos_nodos_en_tres(INDICE* idx, int nodo_izq, int nodo_der, B_NodoEntry padre_entry, B_NodoEntry nuevo_entry, int id_padre);
                        
 static EMUFS_REG_ID b_insertar_dup_en_pos(INDICE *idx, INDICE_DATO pos, INDICE_DATO nuevo);
 
@@ -846,7 +846,7 @@ void b_pasar_clave_a_derecha(INDICE *idx, char *der, int der_id, char *padre, in
        padre_entries = b_leer_claves(padre, &padre_h);
        /* Inserto en el hijo derecho la clave del padre */
        b_insertar_en_nodo_con_lugar(idx, padre_entries[padre_pos].clave, padre_entries[padre_pos].dato,
-                       der_id, der, entry.hijo_derecho, der_h.hijo_izquierdo);
+                       der_id, der, der_h.hijo_izquierdo, entry.hijo_derecho);
        /* Reemplazo clave del padre por clave nueva */
        entry.hijo_derecho = der_id;
        padre_entries[padre_pos] = entry;
@@ -1073,8 +1073,83 @@ static void desabreviar_claves(INDICE *idx, B_NodoEntry *array, B_NodoHeader *he
        free(primera);
 }
 
-static void b_partir_dos_nodos_en_tres(INDICE* idx, int nodo_izq, int nodo_der, int padre, B_NodoEntry nuevo_entry)
+void insertar_ordenado(INDICE *idx, B_NodoEntry *buffer, int cant, B_NodoEntry nuevo_entry)
 {
+       int i, pos;
+       for(i=0; (i<cant) && emufs_indice_es_menor(idx, buffer[i].clave, nuevo_entry.clave); i++) {}
+       pos = i;
+
+       for(i=cant; i>pos; i--)
+               buffer[i] = buffer[i-1];
+
+       buffer[pos] = nuevo_entry;
+}
+
+static void b_partir_dos_nodos_en_tres(INDICE* idx, int nodo_izq, int nodo_der, B_NodoEntry padre_entry, B_NodoEntry nuevo_entry, int id_padre)
+{
+       PERR("PARTIR 2 EN 3");
+       B_NodoEntry *buffer;
+       char *izq, *der, *padre, *nuevo;
+       B_NodoEntry *c_der, *c_izq, *c_nuevo, prom1, prom2;
+       B_NodoHeader h_der, h_izq, h_nuevo;
+       int i, j, nodo_nuevo;
+       int cant_claves;
+
+       /* Leo los nodos y los datos */
+       der = b_leer_nodo(idx, nodo_der);
+       izq = b_leer_nodo(idx, nodo_izq);
+
+       b_leer_header(der, &h_der);
+       b_leer_header(izq, &h_izq);
+
+       c_der = b_leer_claves(der, &h_der);
+       c_izq = b_leer_claves(izq, &h_izq);
+
+       cant_claves = 2*CANT_HIJOS(idx)+2;
+       buffer = malloc(cant_claves*sizeof(B_NodoEntry));
+       
+       for(i=0, j=0; i<h_izq.cant; i++, j++)
+               buffer[j] = c_izq[i];
+
+       buffer[j++] = padre_entry;
+
+       for(i=0; i<h_der.cant; i++, j++)
+               buffer[j] = c_der[i];
+
+       insertar_ordenado(idx, buffer, cant_claves-1, nuevo_entry);
+
+       nuevo = b_crear_nodo(idx, &nodo_nuevo);
+       b_leer_header(nuevo, &h_nuevo);
+       c_nuevo = b_leer_claves(nuevo, &h_nuevo);
+
+       /* lleno el lado derecho e izquierdo */
+       for(i=0, j=0; i<cant_claves/3; i++, j++)
+               c_izq[j] = buffer[i];
+       prom1 = buffer[i++];
+       h_izq.cant = j;
+       for(j=0; i<2*cant_claves/3; i++, j++)
+               c_der[j] = buffer[i];
+       h_der.cant = j;
+       prom2 = buffer[i++];
+       for(j=0; i<cant_claves; i++,j++)
+               c_nuevo[j] = buffer[i];
+       h_nuevo.cant = j;
+
+       /* Actualizo headers y salvo */
+       b_actualizar_header(der, &h_der);
+       b_actualizar_header(izq, &h_izq);
+       b_actualizar_header(nuevo, &h_nuevo);
+       b_grabar_nodo(idx, nodo_izq, izq);
+       b_grabar_nodo(idx, nodo_der, der);
+       b_grabar_nodo(idx, nodo_nuevo, nuevo);
+
+       free(der);
+       free(izq);
+       free(nuevo);
+       padre = b_leer_nodo(idx, id_padre);
+       b_insertar_en_nodo(idx, prom1.clave, prom1.dato, id_padre, padre, nodo_izq, nodo_der);
+       b_insertar_en_nodo(idx, prom2.clave, prom2.dato, id_padre, padre, nodo_der, nodo_nuevo);
+       
        /*
         * PSEUDOCODIGO    TODO FIXME XXX TODO FIXME XXX TODO FIXME XXX
         *
@@ -1313,3 +1388,5 @@ int b_borrar_dup_clave(INDICE *idx, INDICE_DATO k_dato, INDICE_DATO dato)
        return cant;
 }
 
+#include "indice_b_asc.c"
+