12 typedef struct _b_nodo_header_ {
13 int nivel; /* Numero de nivel. Si es hoja debe ser 0 */
14 int cant; /* Cantidad de items en el nivel */
17 /* Nodo al que debo ir si la clave a insertar/buscar/borrar
18 * es menor que la primera del nodo
23 typedef struct _b_nodo_entry_ {
24 /* FIXME usar tipo CLAVE */
26 /* Si el nivel del nodo == 0, quiere decir que es el
27 * bloque del archivo de datos donde esta el registro.
28 * Si el nivel != 0, es el siguiente bloque dentro
29 * del archivo de indice donde buscar
35 void emufs_indice_b_crear(INDICE *idx);
37 /* Inserta un par clave-ubicacion */
38 int emufs_indice_b_insertar(INDICE *idx, CLAVE clave, INDICE_DATO dato);
40 /* Busca una clave, retorna ubicacion o -1 si no existe */
41 INDICE_DATO emufs_indice_b_buscar(INDICE *idx, CLAVE clave);
43 INDICE_DATO *emufs_indice_b_buscar_muchos(INDICE *idx, CLAVE clave, int *cant);