#include <stdio.h>
#include <stdlib.h>
+#include "common.h"
#include "indices.h"
typedef struct _b_nodo_header_ {
typedef struct _b_nodo_entry_ {
/* FIXME usar tipo CLAVE */
- int clave;
+ CLAVE clave;
/* Si el nivel del nodo == 0, quiere decir que es el
* bloque del archivo de datos donde esta el registro.
* Si el nivel != 0, es el siguiente bloque dentro
* del archivo de indice donde buscar
*/
- long ubicacion;
+ INDICE_DATO dato;
} B_NodoEntry;
/* Crea un arbol */
-void b_crear();
+void emufs_indice_b_crear(INDICE *idx);
/* Inserta un par clave-ubicacion */
-int b_insertar(int clave, int ubicacion);
+int emufs_indice_b_insertar(INDICE *idx, CLAVE clave, INDICE_DATO dato);
/* Busca una clave, retorna ubicacion o -1 si no existe */
-int b_buscar(int clave);
+INDICE_DATO emufs_indice_b_buscar(INDICE *idx, CLAVE clave);
+INDICE_DATO *emufs_indice_b_buscar_muchos(INDICE *idx, CLAVE clave, int *cant);
#endif