#include "fsc.h"
#include "did.h"
#include "error.h"
+#include "common.h"
#include <unistd.h>
-#include <sys/types.h>
#include <stdio.h>
#include <string.h>
{
EMUFS_Estadisticas stats;
EMUFS_REG_ID *tmp;
- unsigned long fsc_size = 0,idx_size = 0;
+ int err = 0, err1 = 0, err2 = 0, err3 = 0;
char name_f[255];
- FILE *file;
-
- strcpy(name_f,efs->nombre);
- strcat(name_f,".dat");
/* Inicializo las stats por si hay error somewhere */
stats.tam_archivo = 0;
- stats.tam_archivo_bytes = 0;
- stats.tam_datos_bytes = 0;
- stats.info_control = 0;
+ stats.tam_archivo_aux = 0;
+ stats.tam_info_control_dat = 0;
stats.media_fs = 0;
stats.total_fs = 0;
stats.max_fs = 0;
stats.min_fs = 0;
stats.cant_bloques = 0;
+ stats.cant_registros = 0;
+
+ /* Obtengo el tamaño del .dat */
+ strcpy(name_f,efs->nombre);
+ strcat(name_f,".dat");
+ stats.tam_archivo = emufs_common_get_file_size(name_f,&err);
+ if (err) {
+ PERR("no se pudo obtener el tamaño del archivo");
+ return stats;
+ }
/* Obtengo las stats de FSC */
stats.total_fs = emufs_fsc_get_total_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);
-
- /* 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);
-
- /* Cantida de Bytes en Datos */
- stats.tam_datos_bytes = stats.tam_archivo_bytes - sizeof(EMUFS_Tipo) - (sizeof(EMUFS_REG_ID) + sizeof(EMUFS_REG_SIZE)) * stats.tam_archivo;
-
+ tmp = emufs_idx_get(efs,&stats.cant_registros);
+ if (tmp) free(tmp);
+
+ /* Cantidad de bytes de info de control del .dat */
+ stats.tam_info_control_dat = (sizeof(EMUFS_REG_ID) + sizeof(EMUFS_REG_SIZE)) * stats.cant_registros + sizeof(EMUFS_Tipo);
+
+ /* Cantidad de bytes en info de control archivos auxiliares */
+ stats.tam_archivo_aux = emufs_idx_get_file_size(efs,&err1) + emufs_fsc_get_file_size(efs,&err2) + emufs_did_get_file_size(efs,&err3);
+ if (err1 || err2 || err3) {
+ PERR("Hubo problemas en lectura de filesize archivos auxiliares");
+ return stats;
+ }
+
return(stats);
}