efs->leer_registro_raw = emufs_tipo1_leer_registro_raw;
efs->leer_estadisticas = emufs_tipo1_leer_estadisticas;
efs->compactar = emufs_tipo1_compactar;
+ efs->modificar_registro = emufs_tipo1_modificar_registro;
efs->tam_reg = 0;
return EMUFS_OK;
}
efs->leer_registro_raw = emufs_tipo1_leer_registro_raw;
efs->leer_estadisticas = emufs_tipo1_leer_estadisticas;
efs->compactar = emufs_tipo1_compactar;
+ efs->modificar_registro= emufs_tipo1_modificar_registro_plus;
+ efs->obtener_claver_raw= emufs_tipo1_obtener_claves_raw;
efs->tam_reg = 0;
return EMUFS_OK;
}
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->cant_keys = cant_reg;
keys->current_key = 0;
-
for (i=0; i<cant_reg; i++){
memcpy(&tam_reg, bloque+sizeof(EMUFS_REG_ID), sizeof(EMUFS_REG_SIZE));
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;
}