memcpy(bloque, &header, sizeof(B_NodoHeader));
fwrite(bloque, idx->tam_bloque, 1, fp);
memcpy(bloque, &header, sizeof(B_NodoHeader));
fwrite(bloque, idx->tam_bloque, 1, fp);
-
- b_insertar_dup_en_pos(idx, claves[i].dato, dato);
+
+ if ((idx->funcion == IND_SELECCION) && (!emufs_indice_es_clave_nula(idx, clave)))
+ b_insertar_dup_en_pos(idx, claves[i].dato, dato);
+ if ((idx->funcion == IND_SELECCION) && (emufs_indice_es_clave_nula(idx, clave)))
+ /* UPS!, la clave que se va a insertar por primera vez es nula
+ * y soy un indice selectivo!, no lo puedo permitir, ciao!!
+ */
+ return 1;
if (idx->funcion != IND_PRIMARIO) {
/* Debo borrar primero la clave desde el archivo de
* claves repetidas, y si recien ahi me quedo sin claves,
if (idx->funcion != IND_PRIMARIO) {
/* Debo borrar primero la clave desde el archivo de
* claves repetidas, y si recien ahi me quedo sin claves,
*/
PERR("Vamos a borrar duplicados");
encontrado = b_borrar_dup_clave(idx, claves[i].dato, dato);
*/
PERR("Vamos a borrar duplicados");
encontrado = b_borrar_dup_clave(idx, claves[i].dato, dato);
}
if (encontrado) {
b_borrar_clave(idx, nodo, nodo_id, k);
}
if (encontrado) {
b_borrar_clave(idx, nodo, nodo_id, k);
b_leer_header(out, &header);
claves = b_leer_claves(out, &header);
desabreviar_claves(idx, claves, &header);
b_leer_header(out, &header);
claves = b_leer_claves(out, &header);
desabreviar_claves(idx, claves, &header);
b_leer_header(data, &header);
claves = b_leer_claves(data, &header);
abreviar_claves(idx, claves, &header);
b_leer_header(data, &header);
claves = b_leer_claves(data, &header);
abreviar_claves(idx, claves, &header);
fp = fopen(idx->filename, "r+");
fseek(fp, id*idx->tam_bloque, SEEK_SET);
fwrite(data, 1, idx->tam_bloque, fp);
fp = fopen(idx->filename, "r+");
fseek(fp, id*idx->tam_bloque, SEEK_SET);
fwrite(data, 1, idx->tam_bloque, fp);
memset(nuevo, -1, idx->tam_bloque);
b_actualizar_header(nuevo, &nuevo_header);
b_grabar_nodo(idx, 0, nuevo);
memset(nuevo, -1, idx->tam_bloque);
b_actualizar_header(nuevo, &nuevo_header);
b_grabar_nodo(idx, 0, nuevo);
char* nuevo = b_leer_nodo(idx, hijo_izq);
if (nuevo != NULL) {
B_NodoHeader nuevo_header;
char* nuevo = b_leer_nodo(idx, hijo_izq);
if (nuevo != NULL) {
B_NodoHeader nuevo_header;
b_leer_header(nuevo, &nuevo_header);
nuevo_header.padre = nodo_id;
b_actualizar_header(nuevo, &nuevo_header);
b_leer_header(nuevo, &nuevo_header);
nuevo_header.padre = nodo_id;
b_actualizar_header(nuevo, &nuevo_header);
char* nuevo = b_leer_nodo(idx, hijo_der);
if (nuevo != NULL) {
B_NodoHeader nuevo_header;
char* nuevo = b_leer_nodo(idx, hijo_der);
if (nuevo != NULL) {
B_NodoHeader nuevo_header;
b_leer_header(nuevo, &nuevo_header);
nuevo_header.padre = nodo_id;
b_actualizar_header(nuevo, &nuevo_header);
b_leer_header(nuevo, &nuevo_header);
nuevo_header.padre = nodo_id;
b_actualizar_header(nuevo, &nuevo_header);
while (emufs_indice_es_menor(idx, claves[pos].clave, k)) pos++;
/* Es el nodo una hoja? */
while (emufs_indice_es_menor(idx, claves[pos].clave, k)) pos++;
/* Es el nodo una hoja? */
if (header.hijo_izquierdo != -1) {
PERR("Nodo no es hoja, intercambio");
actual = b_leer_nodo(idx, claves[pos].hijo_derecho);
if (header.hijo_izquierdo != -1) {
PERR("Nodo no es hoja, intercambio");
actual = b_leer_nodo(idx, claves[pos].hijo_derecho);
if ((header_actual.cant >= MIN_HIJOS(idx)) || (actual_id == 0)) {
PERR("Borrar completo sin fundir");
return;
if ((header_actual.cant >= MIN_HIJOS(idx)) || (actual_id == 0)) {
PERR("Borrar completo sin fundir");
return;
padre = b_leer_nodo(idx, padre_id);
b_leer_header(padre, &header_padre);
claves_padre = b_leer_claves(padre, &header_padre);
padre = b_leer_nodo(idx, padre_id);
b_leer_header(padre, &header_padre);
claves_padre = b_leer_claves(padre, &header_padre);
/* TODO Tengo el hijo_izquierdo para revisar!! XXX */
if (header_padre.hijo_izquierdo == actual_id) {
PERR("Soy el hijo izquierdo de padre");
/* TODO Tengo el hijo_izquierdo para revisar!! XXX */
if (header_padre.hijo_izquierdo == actual_id) {
PERR("Soy el hijo izquierdo de padre");
PERR("Ta calcule lo que tengo que hacer");
if ((derecha_id != -1) && (header_der.cant > MIN_HIJOS(idx))) {
PERR("Le pido clave a derecha");
PERR("Ta calcule lo que tengo que hacer");
if ((derecha_id != -1) && (header_der.cant > MIN_HIJOS(idx))) {
PERR("Le pido clave a derecha");
- fprintf(stderr, "ANTES DE PEDIR DERECHA TENGO %d claves\n", header_actual.cant);
- fprintf(stderr, "PEDIR DERECHA DATOS : yo=%d, padre=%d, der=%d, pos_clave=%d\n", actual_id, padre_id, derecha_id, pos_padre);
b_pedir_clave_derecha(der, derecha_id, padre, padre_id, actual, actual_id, pos_padre);
PERR("listo");
b_leer_header(der, &header_der);
b_leer_header(padre, &header_padre);
b_leer_header(actual, &header_actual);
b_pedir_clave_derecha(der, derecha_id, padre, padre_id, actual, actual_id, pos_padre);
PERR("listo");
b_leer_header(der, &header_der);
b_leer_header(padre, &header_padre);
b_leer_header(actual, &header_actual);
} else if ((izquierda_id != -1) && (header_izq.cant > MIN_HIJOS(idx))) {
PERR("Le pido clave a izquierda");
b_pedir_clave_izquierda(izq, izquierda_id, padre, padre_id, actual, actual_id, pos_padre);
} else if ((izquierda_id != -1) && (header_izq.cant > MIN_HIJOS(idx))) {
PERR("Le pido clave a izquierda");
b_pedir_clave_izquierda(izq, izquierda_id, padre, padre_id, actual, actual_id, pos_padre);
b_leer_header(der, &der_h);
padre_entries = b_leer_claves(padre, &padre_h);
/* Inserto en el hijo derecho la clave del padre */
b_leer_header(der, &der_h);
padre_entries = b_leer_claves(padre, &padre_h);
/* Inserto en el hijo derecho la clave del padre */
b_insertar_en_nodo_con_lugar(idx, padre_entries[padre_pos].clave, padre_entries[padre_pos].dato,
der_id, der, der_h.hijo_izquierdo, entry.hijo_derecho);
/* Reemplazo clave del padre por clave nueva */
b_insertar_en_nodo_con_lugar(idx, padre_entries[padre_pos].clave, padre_entries[padre_pos].dato,
der_id, der, der_h.hijo_izquierdo, entry.hijo_derecho);
/* Reemplazo clave del padre por clave nueva */
/* lleno el lado derecho e izquierdo */
for(i=0, j=0; i<cant_claves/3; i++, j++)
c_izq[j] = buffer[i];
/* lleno el lado derecho e izquierdo */
for(i=0, j=0; i<cant_claves/3; i++, j++)
c_izq[j] = buffer[i];
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!! */
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!! */
if ((i+1)<header.cant) {
PERR("Joya, hay lugar a la derecha");
if (claves[i].hijo_derecho == -1) {
if ((i+1)<header.cant) {
PERR("Joya, hay lugar a la derecha");
if (claves[i].hijo_derecho == -1) {
+ if (nodo_id == 0) {
+ /* Bien, son el nodo raiz y aca tendria que ir hacia mi hijo
+ * derecho
+ */
+ nodo = b_leer_nodo(idx, claves[header.cant-1].hijo_derecho);
+ free(tmp);
+ if (nodo != NULL) {
+ b_leer_header(nodo, &header);
+ claves = b_leer_claves(nodo, &header);
+
+ salida = claves[0].clave;
+ } else
+ salida.i_clave = -1;
+ }
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");
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");
-#include "indice_b_asc.c"
+#ifdef NO_TERMINAOD
+EMUFS_Estadisticas emufs_indice_b_obtener_estadisticas(INDICE *idx)
+{
+ EMUFS_Estadisticas stats, st_string, st_multiples;
+
+ stats.tam_archivo = emufs_common_get_file_size(idx->filename);
+ stats.cant_bloques = stats.tam_archivo/idx->tam_bloque;