EMUFS_REG_ID emufs_tipo1_modificar_registro(EMUFS* efs, CLAVE k,
void *data, EMUFS_REG_SIZE size, int* err, INDICE_DATO dato)
{
+ PERR("Tipo1 Modificar Borrando");
emufs_tipo1_borrar_registro(efs, k, dato);
+ PERR("Tipo1 Modificar Agregando de nuevo");
return emufs_tipo1_grabar_registro(efs, data, size, err);
}
B_PLUS_KEYBUCKET *emufs_tipo1_obtener_claves_raw(EMUFS *emu, int num_bloque)
{
B_PLUS_KEYBUCKET *keys;
- char *bloque;
+ char *bloque, *aux;;
int err = 0, cant_reg, i;
EMUFS_REG_SIZE tam_reg;
PERR("NO SE PUDO LEER EL BLOQUE");
return NULL;
}
+ aux = bloque;
/*leo la cantidad de registros*/
memcpy(&cant_reg, bloque+emu->tam_bloque-sizeof(int), sizeof(int));
/*ya se cuanto guardarle al vector*/
keys->claves = (CLAVE*)malloc(cant_reg*sizeof(CLAVE));
if (keys->claves == NULL){
PERR("NO SE PUDO CREAR EL ARRAY DE CLAVES");
+ free(bloque);
free(keys);
return NULL;
}
keys->claves[i] = emufs_indice_generar_clave(emu->indices, bloque+sizeof(EMUFS_TIPO1_REG_HEADER));
bloque += tam_reg+sizeof(EMUFS_TIPO1_REG_HEADER);
}
- free(bloque);
+ free(aux);
return keys;
}