]> git.llucax.com Git - z.facultad/75.06/emufs.git/commitdiff
Stats Tipo2 Listas, con implementancion IDX nueva.
authorAlan Kennedy <kennedya@3dgames.com.ar>
Thu, 15 Apr 2004 06:01:02 +0000 (06:01 +0000)
committerAlan Kennedy <kennedya@3dgames.com.ar>
Thu, 15 Apr 2004 06:01:02 +0000 (06:01 +0000)
emufs/tipo2.c
emufs/tipo2.h
emufs/tipo2_main.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 */
 }
 
 /* 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 */
 }
 
 /* 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;
 
        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 */
        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.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);
        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);  
 }
        
        return(stats);  
 }
index 8e1857ac2b24e75a260009194fd3ea0b8649cdbb..fb5d9f23ce46e52c1b698fb0d82cf622ed5a6b53 100644 (file)
@@ -117,13 +117,13 @@ int emufs_tipo2_get_regsize(EMUFS *efs, EMUFS_OFFSET reg_pos, EMUFS_REG_SIZE *re
 int emufs_tipo2_dummyfill(EMUFS *efs, EMUFS_OFFSET reg_pos, EMUFS_REG_SIZE amount);
 
 /** Método para modificar un registro */
 int emufs_tipo2_dummyfill(EMUFS *efs, EMUFS_OFFSET reg_pos, EMUFS_REG_SIZE amount);
 
 /** Método para modificar un registro */
-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);
 
 /** Método para recolectar/obtener la estadisticas del archivo tipo 2
  *
  * \param efs Estructura que realiza el handling de archivos de cualquier tipo.
  * \return \b EMUFS_Estadisticas Estructura que alberga las stats recolectadas.
  */
 
 /** Método para recolectar/obtener la estadisticas del archivo tipo 2
  *
  * \param efs Estructura que realiza el handling de archivos de cualquier tipo.
  * \return \b EMUFS_Estadisticas Estructura que alberga las stats recolectadas.
  */
-EMUFS_Estadisticas emufs_tipo2_leer_estadisticas(EMUFS *emu);
+EMUFS_Estadisticas emufs_tipo2_leer_estadisticas(EMUFS *efs);
 
 #endif /* _EMUFS_TIPO2_H_ */
 
 #endif /* _EMUFS_TIPO2_H_ */
index 77c22b0ad4b0b4b91464b6f7b91bd7e0e587cfb3..b830069da75504659e11f5fc9e3e116814920eb4 100644 (file)
@@ -101,9 +101,12 @@ int main(int argc, char *argv[])
        /* Obtengo stats */
        stats = efs->leer_estadisticas(efs);
        printf("Size del Archivo de datos: %lu\n",stats.tam_archivo_bytes);
        /* Obtengo stats */
        stats = efs->leer_estadisticas(efs);
        printf("Size del Archivo de datos: %lu\n",stats.tam_archivo_bytes);
+       printf("Cantidad de Registros en el Archivo de datos: %lu\n",stats.tam_archivo);        
        printf("Total de espacio libre en el .dat: %lu\n",stats.total_fs);
        printf("Minimo espacio libre en bloque o gap: %lu\n",stats.min_fs);
        printf("Maximo espacio libre en bloque o gap: %lu\n",stats.max_fs);     
        printf("Total de espacio libre en el .dat: %lu\n",stats.total_fs);
        printf("Minimo espacio libre en bloque o gap: %lu\n",stats.min_fs);
        printf("Maximo espacio libre en bloque o gap: %lu\n",stats.max_fs);     
+       printf("Media de espacio libre en bloque o gap: %lu\n",stats.media_fs); 
+       printf("Cantidad en bytes de informacion de control: %lu\n",stats.info_control);
        
        emufs_destruir(efs);    
        
        
        emufs_destruir(efs);