X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/58b3f3fa3da8e49a8b54cbdb9d390f88c943d8d3..7ea1065532dc62464c0172076c8985aaec617e90:/emufs/tipo1_main.c diff --git a/emufs/tipo1_main.c b/emufs/tipo1_main.c index 9c45fc3..f50456e 100644 --- a/emufs/tipo1_main.c +++ b/emufs/tipo1_main.c @@ -62,21 +62,21 @@ int main(int argc, char* argv[]) { id1 = efs->grabar_registro(efs, reg1, sizeof(reg1), &err); if (err) { printf("No se pudo grabar el registro 1 (%d).\n", err); - goto error; + goto out; } printf("Se grabó el registro 1 (size: %u) con el id %lu.\n", sizeof(reg1), id1); id2 = efs->grabar_registro(efs, reg2, sizeof(reg2), &err); if (err) { printf("No se pudo grabar el registro 2 (%d).\n", err); - goto error; + goto out; } printf("Se grabó el registro 2 (size: %u) con el id %lu.\n", sizeof(reg2), id2); id3 = efs->grabar_registro(efs, reg3, sizeof(reg3), &err); if (err) { printf("No se pudo grabar el registro 3 (%d).\n", err); - goto error; + goto out; } printf("Se grabó el registro 3 (size: %u) con el id %lu.\n", sizeof(reg3), id3); @@ -84,7 +84,7 @@ int main(int argc, char* argv[]) { reg = efs->leer_registro(efs, id1, &size, &err); if (err) { printf("No se pudo leer el registro 1 (%d).\n", err); - goto error; + goto out; } printf("El contenido del registro 1 es: '%s'.\n", reg); free(reg); @@ -92,7 +92,7 @@ int main(int argc, char* argv[]) { reg = efs->leer_registro(efs, id2, &size, &err); if (err) { printf("No se pudo leer el registro 2 (%d).\n", err); - goto error; + goto out; } printf("El contenido del registro 2 es: '%s'.\n", reg); free(reg); @@ -100,7 +100,7 @@ int main(int argc, char* argv[]) { reg = efs->leer_registro(efs, id3, &size, &err); if (err) { printf("No se pudo leer el registro 3 (%d).\n", err); - goto error; + goto out; } printf("El contenido del registro 3 es: '%s'.\n", reg); free(reg); @@ -108,12 +108,59 @@ int main(int argc, char* argv[]) { /* Ve archivos auxiliares */ printf("\nArchivos auxiliares:\n\n"); ver_archivo_FS(efs); + printf("\n--------------------------------------------------\n\n"); - emufs_destruir(efs); - return 0; + /* Borra registro */ + err = efs->borrar_registro(efs, id2); + if (err) { + printf("No se pudo borrar el registro 2 (%d).\n", err); + goto out; + } + printf("Registro 2 (id = %lu) borrado!.\n", id2); + + /* Lee registro 3 (desplazado a izquierda) */ + reg = efs->leer_registro(efs, id3, &size, &err); + if (err) { + printf("No se pudo leer el registro 3 (%d).\n", err); + goto out; + } + printf("El contenido del registro 3 es: '%s'.\n", reg); + free(reg); + + /* Ve archivos auxiliares */ + printf("\n--------------------------------------------------\n"); + printf("Archivos auxiliares:\n\n"); + ver_archivo_FS(efs); + + /* compacta archivo */ + printf("\n--------------------------------------------------\n"); + printf("Compactando archivo.......\n\n"); + efs->compactar(efs); + + /* Ve archivos auxiliares */ + printf("Archivos auxiliares:\n\n"); + ver_archivo_FS(efs); + printf("\n--------------------------------------------------\n"); + + /* Lee registros */ + reg = efs->leer_registro(efs, id1, &size, &err); + if (err) { + printf("No se pudo leer el registro 1 (%d).\n", err); + goto out; + } + printf("El contenido del registro 1 es: '%s'.\n", reg); + free(reg); + + reg = efs->leer_registro(efs, id3, &size, &err); + if (err) { + printf("No se pudo leer el registro 3 (%d).\n", err); + goto out; + } + printf("El contenido del registro 3 es: '%s'.\n", reg); + free(reg); -error: +out: emufs_destruir(efs); - return 2; + return err; }