+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
+ *
+ * // Creo un buffer con todos los entries (las claves) de ambos nodos, mas el padre y la nueva, ordenadas
+ * buffer_size = 2*MAX_ENTRIES+2
+ * buffer = new entries[buffer_size]
+ * copiar_entries(buffer, nodo_izq)
+ * concatenar_entries(buffer, padre)
+ * concatenar_entries(buffer, nodo_der)
+ * insertar_ordenado(buffer, nuevo_entry)
+ * // Borro los 2 nodos viejos para reutilizarlos y creo el tercero
+ * borrar_entries(nodo_izq)
+ * borrar_entries(nodo_der)
+ * nodo_nuevo = new nodo()
+ * // Copio de a tercios del buffer en los nuevos nodos, excluyendo las 2 claves 'limítrofes' para insertarlas luego en el padre
+ * copiar_algunos_entries(nodo_izq, buffer, 0, (buffer_size/3)-1)
+ * entry_promovido1 = buffer[buffer_size/3]
+ * copiar_algunos_entries(nodo_izq, buffer, (buffer_size/3)+1, 2*(buffer_size/3))
+ * entry_promovido2 = buffer[(2*(buffer_size/3))+1]
+ * copiar_algunos_entries(nodo_nuevo, buffer, (2*(buffer_size/3))+2, buffer_size-1))
+ * // Finalmente inserto (recursivamente, porque esta funcion es llamada desde b_insertar_en_nodo()) las claves promovidas en el padre
+ * b_insertar_en_nodo(idx, entry_promovido.clave, entry_promovido.dato, entry_promovido.id, entry_promovido, nodo_izq.id, nodo_der.id)
+ * b_insertar_en_nodo(idx, entry_promovido.clave, entry_promovido.dato, entry_promovido.id, entry_promovido, nodo_der.id, nodo_nuevo.id)
+ *
+ */
+}
+
+CLAVE emufs_indice_b_obtener_menor_clave(INDICE *idx)