]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/tipo3_main.c
Se arregla memory leak (aunque en el ejemplo no importe demasiado :)
[z.facultad/75.06/emufs.git] / emufs / tipo3_main.c
index feff81fdd27d7bc81246c611eb62c535f37705b4..7e84c6337e719a54103aaf17e1b68e4034d2c727 100644 (file)
@@ -87,7 +87,13 @@ 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=1; j<8; j+=2){   
+               b_ptr = fp->leer_registro(fp, v[j], &reg_size, &err);
+               printf("Recuperado : %s\n", b_ptr);
+               free(b_ptr);
+       }
+
        for (j=0; j<8; j++)     
                printf("Grabado : %lu\n", v[j]);
        
@@ -98,20 +104,16 @@ int main(int argc, char *argv[])
                free(b_ptr);
        }
        ver_archivo_FS(fp);     
+
        printf("BORRANDO REGISTROS....\n");
        for (j=0; j<8; j+=2){   
                fp->borrar_registro(fp, v[j]);
                printf("borrado : %lu\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);
-               free(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);
@@ -154,10 +156,8 @@ ver_archivo_FS(fp);
        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);
 
-emufs_destruir(fp);
-       
+       emufs_destruir(fp);
        return 0;
 }