X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/2ef63227431ca5dc261ef1b3186d0a30d5742f25..3a8f53e24ee5a692394590f6b9d4f135f6ca9d44:/tipo3/emufs.c diff --git a/tipo3/emufs.c b/tipo3/emufs.c index 9883f70..0cdd43d 100644 --- a/tipo3/emufs.c +++ b/tipo3/emufs.c @@ -1,13 +1,11 @@ - #include "emufs.h" #include "param_cte.h" /* Defino las extenciones que usan cada tipo de archivo */ -#define EXT_TIPO3_ID ".id3" +#define EXT_TIPO3_ID ".idx" #define EXT_TIPO3_DATA ".dat" #define EXT_TIPO3_DISP ".fsc" -#define EXT_TIPO3_IDS ".idc" -#define EXT_TIPO3_EXTRA ".ids" +#define EXT_TIPO3_IDS ".ids" char *str_dup(const char *s) { @@ -67,11 +65,7 @@ EMUFS *emufs_crear(const char *filename, char tipo, unsigned int tam_bloque, uns strcat(name, EXT_TIPO3_IDS); fp = fopen(name, "w"); fclose(fp); - - strcpy(name, filename); - strcat(name, EXT_TIPO3_EXTRA); - fp = fopen(name, "w"); - fclose(fp); + break; default: free(tmp); @@ -81,6 +75,44 @@ EMUFS *emufs_crear(const char *filename, char tipo, unsigned int tam_bloque, uns return tmp; } +EMUFS *emufs_abrir(const char *filename) +{ + EMUFS *tmp; + char name[255]; + char tipo; + FILE *fp; + + strcpy(name, filename); + strcat(name, EXT_TIPO3_DATA); + fp = fopen(name, "r"); + if (fp == NULL) return NULL; + fread(&tipo, sizeof(char), 1, fp); + if ((tipo < 0) || (tipo > 2)) { + fclose(fp); + return NULL; + } + + tmp = (EMUFS *)malloc(sizeof(EMUFS)); + if (tmp == NULL) return NULL; + + switch (tipo) { + case T1: + break; + case T2: + break; + case T3: + tmp->tipo = tipo; + fread(&tmp->tam_bloque, sizeof(int), 1, fp); + tmp->leer_bloque = leer_bloque; + tmp->leer_registro = leer_registro; + tmp->grabar_registro = grabar_registro; + tmp->borrar_registro = NULL; + tmp->nombre = str_dup(filename); + } + + fclose(fp); + return tmp; +} int emufs_destruir(EMUFS *e) { @@ -90,3 +122,41 @@ int emufs_destruir(EMUFS *e) return 0; } +int ver_archivo_FS(EMUFS *emu) +{ + FILE *f_block_free; + BLOCK_FREE_T reg; + char name_f_block_free[255]; + + strcpy(name_f_block_free,emu->nombre); + strcat(name_f_block_free,".fsc"); + + if ( (f_block_free = fopen(name_f_block_free,"r"))==NULL ){ + printf("no pude abrir el archivo %s\n",name_f_block_free); + return -1; + } + fread(®,sizeof(reg),1,f_block_free); + while ( !feof(f_block_free) ){ + printf(" Bloque = %d Espacio libre = %d\n",reg.block, reg.free_space); + fread(®,sizeof(reg),1,f_block_free); + } + + fclose(f_block_free); + + /* Imprimo la lista de bloques/registros */ + strcpy(name_f_block_free,emu->nombre); + strcat(name_f_block_free,".idx"); + { + BLOCK_REG_T r; + f_block_free = fopen(name_f_block_free, "r"); + fread(&r, sizeof(BLOCK_REG_T), 1, f_block_free); + while (!feof(f_block_free)) { + printf("ID %ld en bloque %d\n", r.id_reg, r.block); + fread(&r, sizeof(BLOCK_REG_T), 1, f_block_free); + } + fclose(f_block_free); + } + + + return 0; +}