/** Junta 2 nodos y hace uno solo */
static void b_fundir_nodo(char *, int, char *, int, char *, int, int);
-static void b_insertar_dup_en_pos(INDICE *idx, INDICE_DATO pos, INDICE_DATO nuevo);
+static EMUFS_REG_ID b_insertar_dup_en_pos(INDICE *idx, INDICE_DATO pos, INDICE_DATO nuevo);
void emufs_indice_b_crear(INDICE *idx)
{
B_NodoHeader header;
B_NodoEntry *claves;
char *nodo, *padre;
+ INDICE_DATO dummy;
/* Leo la raiz */
nodo = b_leer_nodo(idx, 0);
if (nodo) free(nodo);
nodo = padre;
nodo_id = padre_id;
+
+ if (idx->tipo != IND_PRIMARIO) {
+ /* Agrego el DATO real al archivo de claves repetiras
+ * y me guardo el ID para poner en el indice
+ */
+ dummy.id = -1;
+ dato.id = b_insertar_dup_en_pos(idx, dummy, dato);
+ }
b_insertar_en_nodo(idx, clave, dato, nodo_id, nodo, -1, -1);
return 1; /* Agregar OK! */
}
{
}
-static void b_insertar_dup_en_pos(INDICE *idx, INDICE_DATO pos, INDICE_DATO nuevo)
+static EMUFS_REG_ID b_insertar_dup_en_pos(INDICE *idx, INDICE_DATO pos, INDICE_DATO nuevo)
{
int cant;
EMUFS_REG_SIZE tam;
leido = (char *)idx->emu_mult->leer_registro(idx->emu_mult, k, &tam, &error);
/* Incremento en 1 la cantidad */
- cant = *((int *)leido);
+ if (leido != NULL)
+ cant = *((int *)leido);
+ else
+ cant = 0;
cant++;
/* Obtengo un nuevo lugar para el dato nuevo */
+ /* Aca todo bien, si leido es NULL se compota como malloc */
leido = realloc(leido, cant*sizeof(INDICE_DATO)+sizeof(int));
array = (INDICE_DATO *)(leido+sizeof(int));
(*((int *)leido)) = cant;
/* Salvo */
- idx->emu_mult->modificar_registro(idx->emu_mult,
- pos.id,
+ if (k.i_clave == -1) {
+ /* Creo uno nuevo */
+ k.i_clave = idx->emu_mult->grabar_registro(idx->emu_mult,
leido,
cant*sizeof(INDICE_DATO)+sizeof(int),
&error
);
-
+ } else {
+ /* Modifico el que ya existia! */
+ idx->emu_mult->modificar_registro(idx->emu_mult,
+ k.i_clave,
+ leido,
+ cant*sizeof(INDICE_DATO)+sizeof(int),
+ &error
+ );
+ }
/* Clean up! */
free(leido);
+ return k.i_clave;
}