+CLAVE emufs_indice_b_obtener_menor_clave(INDICE *idx)
+{
+ B_NodoHeader header;
+ B_NodoEntry *claves;
+ CLAVE k;
+ char *nodo;
+
+ nodo = b_leer_nodo(idx, 0);
+ b_leer_header(nodo, &header);
+ /* Tengo que ir siempre a la izquierda hasta una hora */
+ while (header.hijo_izquierdo != -1) {
+ free(nodo);
+ nodo = b_leer_nodo(idx, header.hijo_izquierdo);
+ b_leer_header(nodo, &header);
+ }
+
+ /* Listo, ahora solo leo la primer clave */
+ claves = b_leer_claves(nodo, &header);
+ k = claves[0].clave;
+ free(nodo);
+ return k;
+}
+
+CLAVE emufs_indice_b_obtener_mayor_clave(INDICE *idx)
+{
+ B_NodoHeader header;
+ B_NodoEntry *claves;
+ CLAVE k;
+ int i;
+ char *nodo;
+
+ nodo = b_leer_nodo(idx, 0);
+ b_leer_header(nodo, &header);
+ claves = b_leer_claves(nodo, &header);
+ /* Tengo que ir siempre a la izquierda hasta una hora */
+ while (claves[header.cant-1].hijo_derecho != -1) {
+ i = claves[header.cant-1].hijo_derecho;
+ free(nodo);
+ nodo = b_leer_nodo(idx, i);
+ b_leer_header(nodo, &header);
+ claves = b_leer_claves(nodo, &header);
+ }
+
+ /* Listo, ahora solo leo la primer clave */
+ k = claves[header.cant-1].clave;
+ free(nodo);
+ return k;
+}
+
+CLAVE emufs_indice_b_obtener_sig_clave(INDICE *idx, CLAVE k)
+{
+ int i;
+ B_NodoHeader header;
+ B_NodoEntry *claves;
+ char *nodo, *tmp;
+ int nodo_id;
+ CLAVE salida;
+
+ /* Primero busco la clave pasada por parametro */
+ nodo = b_leer_nodo(idx, 0);
+ nodo_id = 0;
+ while (nodo) {
+ b_leer_header(nodo, &header);
+ claves = b_leer_claves(nodo, &header);
+ i=0;
+ 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) {
+ PERR("Y soy hoja!!");
+ /* Joya!, fue facil, la siguiente va en camino! */
+ salida = claves[i+1].clave;
+ free(nodo);
+ return salida;
+ }
+
+ PERR("No soy hoja, busco la hoja de menor");
+ /* Mmmmm ... la siguiente esta en uno de mis hijo */
+ /* Necesito la mas chica de las siguientes, para eso
+ * me voy a mi hijo derecho y de ahi bajo siempre
+ * hacia la izquierda hacia una hoja */
+ i = claves[i].hijo_derecho;
+ free(nodo);
+ nodo = b_leer_nodo(idx, i);
+ b_leer_header(nodo, &header);
+ while (header.hijo_izquierdo != -1) {
+ free(nodo);
+ nodo = b_leer_nodo(idx, header.hijo_izquierdo);
+ b_leer_header(nodo, &header);
+ }
+ claves = b_leer_claves(nodo, &header);
+ salida = claves[0].clave;
+ free(nodo);
+ return salida;
+ }
+
+ PERR("Fuck, tengo que ir otro nodo a buscar");
+ /* Fuck, la siguiente clave la tengo que sacar de padre */
+ /* Busco al mi padre, perdido en un maremoto hace mucho,muchos
+ * aƱos
+ */
+ free(nodo);
+ if (header.padre == -1) {
+ salida.i_clave = -1;
+ return salida;
+ }
+ 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");
+ salida = claves[i].clave;
+ } else {
+ /* No hay mas claves! */
+ PERR("Busque y busque pero no aparecio");
+ salida.i_clave = -1;
+ }
+ return salida;
+ } else {
+ tmp = nodo;
+ b_grabar_nodo(idx, nodo_id, nodo);
+ if (i == 0) {
+ nodo = b_leer_nodo(idx, header.hijo_izquierdo);
+ nodo_id = header.hijo_izquierdo;
+ } else {
+ nodo = b_leer_nodo(idx, claves[i-1].hijo_derecho);
+ nodo_id = claves[i-1].hijo_derecho;
+ }
+ free(tmp);
+ }
+ }
+
+ /* No encontre la clave pasada, no existe */
+ PERR("No encontre la clave pasada!!");
+ salida.i_clave = -1;
+ return salida;
+}
+
+int b_borrar_dup_clave(INDICE *idx, INDICE_DATO k_dato, INDICE_DATO dato)
+{
+ int cant, pos, i;
+ EMUFS_REG_SIZE tam;
+ int error=0;
+ INDICE_DATO *array;
+ INDICE_DATO dummy1;
+ char *leido;
+ CLAVE k;
+
+ /* Leo el contenido actual */
+ error = 0;
+ k.i_clave = k_dato.id;
+ leido = (char *)idx->emu_mult->leer_registro(idx->emu_mult, k, &tam, &error);
+
+ if (leido == NULL) {
+ PERR("LEI CUALQUIER COSA, BUG?");
+ return 1;
+ }
+
+ cant = *((int *)leido);
+
+ /* Obtengo un nuevo lugar para el dato nuevo */
+ array = (INDICE_DATO *)(leido+sizeof(int));
+
+ /* busco pos de dato en array */
+ for(pos=0; pos<cant; pos++) {
+ if (array[pos].id == dato.id) break;
+ }
+
+ for(i=pos; i<cant-1; i++)
+ array[pos] = array[pos+1];
+
+ cant--;
+
+ if (cant == 0) {
+ free(leido);
+ /* No tengo mas cosas en esta clave, la borro */
+ PERR("EL REGISTRO MULTIPLE QUEDO VACIO, ELIMINANDO");
+ idx->emu_mult->borrar_registro(idx->emu_mult, k, dummy1);
+ return 0;
+ }
+
+ /* Quito el elemento */
+ leido = realloc(leido, sizeof(int)+cant*sizeof(INDICE_DATO));
+
+ /* Actualizo la cantidad */
+ (*((int *)leido)) = cant;
+
+ error = 0;
+ idx->emu_mult->modificar_registro(idx->emu_mult,
+ k,
+ leido,
+ cant*sizeof(INDICE_DATO)+sizeof(int),
+ &error,
+ dummy1
+ );
+
+ free(leido);
+
+ return cant;
+}
+
+#include "indice_b_asc.c"
+