]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/tipo3_main.c
Se termina el fatidico tipo1.
[z.facultad/75.06/emufs.git] / emufs / tipo3_main.c
index 367bb7e4912092f644b1af300cfef88c5ff49e70..e94a05eab84cb018e184880ae0c6fb2074b2729b 100644 (file)
@@ -53,7 +53,7 @@ int main(int argc, char *argv[])
        char* b_ptr;
        int err = 0, max, min, j;
        
-       EMUFS_Estadisticas s;
+       EMUFS_Estadisticas stats;
        if (argc != 2) {
                printf("Modo de uso : %s tam_bloque\n", argv[0]);
                return 1;
@@ -87,6 +87,7 @@ int main(int argc, char *argv[])
        v[5] = fp->grabar_registro(fp, g, 100, &err);
        v[6] = fp->grabar_registro(fp, h, 100, &err);
        v[7] = fp->grabar_registro(fp, i, 100, &err);
+       
        for (j=0; j<8; j++)     
                printf("Grabado : %d\n", v[j]);
        
@@ -97,10 +98,24 @@ int main(int argc, char *argv[])
        }
        ver_archivo_FS(fp);     
        printf("BORRANDO REGISTROS....\n");
-       for (j=0; j<8; j++){    
+       for (j=0; j<8; j+=2){   
                fp->borrar_registro(fp, v[j]);
                printf("borrado : %d\n", v[j]);
        }
+
+       for (j=1; j<8; j+=2){   
+               b_ptr = fp->leer_registro(fp, v[j], &reg_size, &err);
+               printf("Recuperado : %s\n", b_ptr);
+       }
+
+       printf("COMPACTANDO........\n");
+       fp->compactar(fp);
+ver_archivo_FS(fp);
+       for (j=1; j<8; j+=2){   
+               b_ptr = fp->leer_registro(fp, v[j], &reg_size, &err);
+               printf("Recuperado : %s\n", b_ptr);
+       }
+
        printf("GRABANDO REGISTROS....\n");
        v[0] = fp->grabar_registro(fp, a, 100, &err);
        v[1] = fp->grabar_registro(fp, c, 100, &err);
@@ -110,11 +125,32 @@ int main(int argc, char *argv[])
        v[5] = fp->grabar_registro(fp, g, 100, &err);
        v[6] = fp->grabar_registro(fp, h, 100, &err);
        v[7] = fp->grabar_registro(fp, i, 100, &err);
-       for (j=0; j<8; j++){    
-               b_ptr = fp->leer_registro(fp, v[j], &reg_size, &err);
-               printf("Recuperado : %s\n", b_ptr);
+       v[4] = fp->grabar_registro(fp, f, 100, &err);
+       v[5] = fp->grabar_registro(fp, g, 100, &err);
+       v[6] = fp->grabar_registro(fp, h, 100, &err);
+       v[7] = fp->grabar_registro(fp, i, 100, &err);
+
+
+       printf("BORRANDO REGISTROS....\n");
+       for (j=0; j<16; j+=3){  
+               fp->borrar_registro(fp, v[j]);
+               printf("borrado : %d\n", v[j]);
        }
-               
+       
+
+       printf("COMPACTANDO........\n");
+       fp->compactar(fp);
+       
+       
+       stats = fp->leer_estadisticas(fp);
+       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("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);
+
        free(b_ptr);
        ver_archivo_FS(fp);