X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/6effd0769b012b1ac78cfeda307cec54802f9b58..f60bd6b2e681ddce2841392ab10618bb148ca24e:/emufs/tipo2.c diff --git a/emufs/tipo2.c b/emufs/tipo2.c index e640cf6..e1bdf86 100644 --- a/emufs/tipo2.c +++ b/emufs/tipo2.c @@ -232,20 +232,22 @@ int emufs_tipo2_dummyfill(EMUFS *efs, EMUFS_OFFSET reg_pos, EMUFS_REG_SIZE amoun } /* Realiza la actualizacin de un registro ya existente */ -EMUFS_REG_ID emufs_tipo2_modificar_registro(EMUFS *emu, EMUFS_REG_ID id, void *data, EMUFS_REG_SIZE size, int *error) +EMUFS_REG_ID emufs_tipo2_modificar_registro(EMUFS *efs, EMUFS_REG_ID id, void *data, EMUFS_REG_SIZE size, int *error) { - emufs_tipo2_borrar_registro(emu, id); - return emufs_tipo2_grabar_registro(emu, data, size, error); + emufs_tipo2_borrar_registro(efs, id); + return emufs_tipo2_grabar_registro(efs, data, size, error); } /* Recompila y devuelve ciertas estadisticas del archivo indicado */ -EMUFS_Estadisticas emufs_tipo2_leer_estadisticas(EMUFS *emu) +EMUFS_Estadisticas emufs_tipo2_leer_estadisticas(EMUFS *efs) { - EMUFS_Estadisticas stats; + EMUFS_Estadisticas stats; + EMUFS_REG_ID *tmp; + unsigned long fsc_size = 0,idx_size = 0; char name_f[255]; FILE *file; - strcpy(name_f,emu->nombre); + strcpy(name_f,efs->nombre); strcat(name_f,".dat"); /* Inicializo las stats por si hay error somewhere */ @@ -259,17 +261,44 @@ EMUFS_Estadisticas emufs_tipo2_leer_estadisticas(EMUFS *emu) stats.cant_bloques = 0; /* Obtengo las stats de FSC */ - stats.total_fs = emufs_fsc_get_total_fs(emu); - stats.media_fs = emufs_fsc_get_media_fs(emu); - emufs_fsc_get_max_min_fs(emu,&stats.min_fs,&stats.max_fs); + stats.total_fs = emufs_fsc_get_total_fs(efs); + stats.media_fs = emufs_fsc_get_media_fs(efs); + emufs_fsc_get_max_min_fs(efs,&stats.min_fs,&stats.max_fs); + + /* Cant registros */ + tmp = emufs_idx_get(efs,&stats.tam_archivo); + free(tmp); - /* Faltan stats pero como cambia el API Idx, espero... */ + /* Size del archivo de datos */ if ( (file = fopen(name_f,"ab")) == NULL){ PERR("No se pudo abrir el archivo"); return stats; } stats.tam_archivo_bytes = ftell(file); fclose(file); + + /* Size del archivo de Espacio Libre */ + strcpy(name_f,efs->nombre); + strcat(name_f,EMUFS_FSC_EXT); + if ( (file = fopen(name_f,"ab")) == NULL){ + PERR("No se pudo abrir el archivo"); + return stats; + } + fsc_size = ftell(file); + fclose(file); + + /* Size del archivo Indice */ + strcpy(name_f,efs->nombre); + strcat(name_f,EMUFS_IDX_EXT); + if ( (file = fopen(name_f,"ab")) == NULL){ + PERR("No se pudo abrir el archivo"); + return stats; + } + idx_size = ftell(file); + fclose(file); + + /* Cantidad de Bytes en info de control */ + stats.info_control = idx_size + fsc_size + sizeof(EMUFS_REG_ID)*stats.tam_archivo + sizeof(EMUFS_REG_SIZE)*stats.tam_archivo + sizeof(EMUFS_Tipo); return(stats); }