]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/tipo2.c
hice unos pequeños cambios en fsc e idx pero no creo que afecte en nada a los otros...
[z.facultad/75.06/emufs.git] / emufs / tipo2.c
index e640cf69d89a1f88edffab104c74782593b8691b..e1bdf868cfd85493293ce8832e4ae4e728034aca 100644 (file)
@@ -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);  
 }