X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/3579dcf7da4edf3ba729e1d71fbe91d1e1f0b5ad..ebffcefec9ec5f0ea19f842d42f828055c9bc3c7:/emufs/emufs.c?ds=sidebyside diff --git a/emufs/emufs.c b/emufs/emufs.c index 8f68f82..0c55064 100644 --- a/emufs/emufs.c +++ b/emufs/emufs.c @@ -142,6 +142,7 @@ EMUFS *emufs_crear(const char *filename, EMUFS_TYPE tipo, EMUFS_BLOCK_SIZE tam_b switch (tipo) { case T1: + /* Asigna punteros a funciones. */ emufs_tipo1_inicializar(efs); /* Guarda cabeceras propias. */ @@ -151,10 +152,7 @@ EMUFS *emufs_crear(const char *filename, EMUFS_TYPE tipo, EMUFS_BLOCK_SIZE tam_b case T2: /* Asigna punteros a funciones. */ - efs->grabar_registro = emufs_tipo2_grabar_registro; - efs->borrar_registro = emufs_tipo2_borrar_registro; - efs->nombre = str_dup(filename); - /*efs->leer_registro = emufs_tipo2_leer_registro;*/ + emufs_tipo2_inicializar(efs); break; case T3: @@ -207,6 +205,7 @@ EMUFS *emufs_abrir(const char *filename) switch (tipo) { case T1: + /* Asigna punteros a funciones. */ emufs_tipo1_inicializar(efs); /* Lee cabeceras propias. */ if (!fread(&(efs->tam_bloque), sizeof(EMUFS_BLOCK_SIZE), 1, fp)) { @@ -217,6 +216,8 @@ EMUFS *emufs_abrir(const char *filename) } break; case T2: + /* Asigna punteros a funciones. */ + emufs_tipo2_inicializar(efs); break; case T3: if ((!fread(&(efs->tam_bloque), sizeof(EMUFS_BLOCK_SIZE), 1, fp)) || @@ -227,10 +228,11 @@ EMUFS *emufs_abrir(const char *filename) fclose(fp); return NULL; } + /* Asigna punteros a funciones. */ efs->leer_bloque = emufs_tipo3_leer_bloque; efs->leer_registro = emufs_tipo3_leer_registro; efs->grabar_registro = emufs_tipo3_grabar_registro; - /*efs->borrar_registro = emufs_tipo3_borrar_registro;*/ + efs->borrar_registro = emufs_tipo3_borrar_registro; break; } @@ -276,7 +278,7 @@ int ver_archivo_FS(EMUFS *emu) f_block_free = fopen(name_f_block_free, "r"); fread(&r, sizeof(EMUFS_IDX), 1, f_block_free); while (!feof(f_block_free)) { - fprintf(stderr, "ID %li en bloque %li\n", r.n_idreg, r.n_location); + fprintf(stderr, "ID %li en bloque %li\n", r.id_reg, r.location); fread(&r, sizeof(EMUFS_IDX), 1, f_block_free); } fclose(f_block_free);