+ raiz = b_plus_crearnodo(idx);
+ error = b_plus_grabar_nodo(idx,raiz,0);
+
+ /* Liberamos areas de memoria reservadas */
+ free(raiz->claves);
+ free(raiz->hijos);
+ free(raiz);
+
+ return error;
+}
+
+
+/** Busca el nro de bloque donde se debe guardar un reg con clave X.
+ * Posibilidades: return 0 - Encontro un bloque potencial
+ * return -1 - No hay clave, inserto clave de nuevo bloques
+ * return 1 - Hubo falla de lectura de un nodo, Abortar
+ */
+int emufs_b_plus_get_bloque(INDEX *idx, INDEX_DAT *query, int num_node) {
+
+ NODO_B_PLUS *nodo;
+ nodo = b_plus_leer_nodo(idx,num_node);
+ if (nodo == NULL) return 1;
+ int i = nodo->cant_claves - 1;
+ int exitcode = 0;
+
+ /* Si es un hoja, busco dentro de la hoja, otherwise, busco la hoja */
+ if (nodo->nivel == 0) {
+ /* Vemos en que bloque deberia ir */
+ while ( i >= 0 && query->clave.i_clave < nodo->claves[i] ) i--;
+ if (i < 0) {
+ /* La clave es menor que todas, debo insertarla */
+ b_plus_destruir_nodo(nodo);
+ emufs_b_plus_insertar(idx,query);
+ return -1;
+ }
+ else {
+ /* Encontre un bloque potencial */
+ query->num_bloque = nodo->hijos[i];
+ b_plus_destruir_nodo(nodo);
+ return 0;
+ }
+ }
+ else {
+ /* Buscamos por donde descender al siguiente nivel */
+ while ( i >= 0 && query->clave.i_clave < nodo->claves[i] ) i--;
+ i++;
+ num_node = nodo->hijos[i];
+ b_plus_destruir_nodo(nodo);
+ exitcode = emufs_b_plus_get_bloque(idx,query,num_node);
+ return exitcode;
+ }
+}
+
+NODO_B_PLUS *b_plus_leer_nodo(INDEX *idx, int num_node) {
+
+ /*int i = 0;*/
+ FILE *fp;
+ NODO_B_PLUS *memnode = b_plus_crearnodo(idx);
+ char *disknode = (char*)malloc(idx->tam_bloque);
+
+ if (num_node < 0) {
+ PERR("Se intento leer nodo negativo!!\n");
+ exit(1);
+ }
+ if (disknode == NULL) return NULL;
+ if (memnode == NULL) return NULL;
+
+ /* Open up file */
+ fp = fopen(idx->filename, "r+");
+ if (fp == NULL) {
+ free(disknode);
+ b_plus_destruir_nodo(memnode);
+ return NULL;
+ }
+
+ /* Intentamos leer un nodo, sino podemos error! */
+ fseek(fp, num_node*idx->tam_bloque, SEEK_SET);
+ if (fread(disknode, idx->tam_bloque, 1, fp) != 1) {
+ free(disknode);
+ fclose(fp);
+ return NULL;
+ }
+ fclose(fp);
+
+ /* Pudimos leer un nodo de disco, ahora lo transformamos a nodo mem */
+ memcpy(memnode,disknode,SIZE_B_PLUS_HEADER);
+ memcpy(memnode->claves,disknode+SIZE_B_PLUS_HEADER,idx->size_claves);
+ memcpy(memnode->hijos,disknode+SIZE_B_PLUS_HEADER+idx->size_claves,idx->size_hijos);
+ free(disknode);
+
+ /*printf("Dumping Node_%i\n",num_node);
+ printf("Nivel: %i Cant Claves: %i\n",memnode->nivel,memnode->cant_claves);
+ printf("Claves:");
+ for (i = 0; i < idx->size_claves/sizeof(int); ++i) printf(" %i",memnode->claves[i]);
+ printf("\nHijos:");
+ for (i = 0; i < idx->size_hijos/sizeof(int); ++i) printf(" %i",memnode->hijos[i]);
+ printf("\nEnd Dump\n"); */
+
+ return memnode;
+
+}
+
+int b_plus_grabar_nodo(INDEX *idx, NODO_B_PLUS *nodo, int num_node)
+{
+ FILE *fp;
+
+ fp = fopen(idx->filename, "r+");
+ if (fp == NULL) return -1;
+
+ fseek(fp,num_node*(SIZE_B_PLUS_HEADER+idx->size_claves+idx->size_hijos),SEEK_SET);
+ fwrite(nodo,SIZE_B_PLUS_HEADER,1,fp);
+ fwrite(nodo->claves,idx->size_claves,1,fp);
+ fwrite(nodo->hijos,idx->size_hijos,1,fp);