memcpy(&ID_aux, bloque+iterador, sizeof(EMUFS_REG_ID));
iterador += sizeof(EMUFS_REG_ID);
if ( ID_aux == ID ){
memcpy(&ID_aux, bloque+iterador, sizeof(EMUFS_REG_ID));
iterador += sizeof(EMUFS_REG_ID);
if ( ID_aux == ID ){
memcpy(registro,bloque+iterador,emu->tam_reg);
else {
if ( cant_bloques-1 == i )
memcpy(registro,bloque+iterador,emu->tam_reg);
else {
if ( cant_bloques-1 == i )
strcpy(name_f,emu->nombre);
strcat(name_f,".dat");
if ( (f = fopen(name_f,"r")) == NULL){
strcpy(name_f,emu->nombre);
strcat(name_f,".dat");
if ( (f = fopen(name_f,"r")) == NULL){
- /*verificar el segentado*/
- stats.info_control = stats.tam_archivo*sizeof(EMUFS_REG_ID) + sizeof(EMUFS_Tipo) + sizeof(EMUFS_BLOCK_SIZE) + sizeof(EMUFS_REG_SIZE);
- stats.media_fs = stats.total_fs/stats.cant_bloques;
+ stats.media_fs = emufs_fsc_get_media_fs(emu);
+ emufs_fsc_get_max_min_fs(emu,&stats.min_fs,&stats.max_fs);
+
if (emu->tam_reg < emu->tam_bloque) {
/* Aca estoy en el caso de que 1 registro entra en 1 solo bloque */
block = emufs_idx_buscar_registro(emu,ID);
if (emu->tam_reg < emu->tam_bloque) {
/* Aca estoy en el caso de que 1 registro entra en 1 solo bloque */
block = emufs_idx_buscar_registro(emu,ID);
*size = emu->tam_bloque*cant_bloques + cant_bloques*2 - sizeof(EMUFS_REG_ID)*(cant_bloques-1);
bloque = (char *)malloc(*size);
cur = bloque;
*pos = 0;
/* El bloque 0 va completo */
*size = emu->tam_bloque*cant_bloques + cant_bloques*2 - sizeof(EMUFS_REG_ID)*(cant_bloques-1);
bloque = (char *)malloc(*size);
cur = bloque;
*pos = 0;
/* El bloque 0 va completo */
if ((tmp = emufs_tipo3_leer_bloque(emu, block, &err)) == NULL) {
/* Oops! ... un bloque no existe, todo mal! */
free(bloque);
if ((tmp = emufs_tipo3_leer_bloque(emu, block, &err)) == NULL) {
/* Oops! ... un bloque no existe, todo mal! */
free(bloque);
/* En resto de los bloques no pongo el ID porque ya esta en el primero */
for(i=1; i<cant_bloques; i++) {
/* En resto de los bloques no pongo el ID porque ya esta en el primero */
for(i=1; i<cant_bloques; i++) {
if ((tmp = emufs_tipo3_leer_bloque(emu, block+i, &err)) == NULL) {
/* Oops! ... un bloque no existe, todo mal! */
free(bloque);
if ((tmp = emufs_tipo3_leer_bloque(emu, block+i, &err)) == NULL) {
/* Oops! ... un bloque no existe, todo mal! */
free(bloque);