X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/c7cf7f97785bf9d5e49a3e2015233a8b222903db..f41ad014e7d68321ff67258b99817651ecdab0bb:/tipo3/emufs.c diff --git a/tipo3/emufs.c b/tipo3/emufs.c index 71e9dd0..53ba505 100644 --- a/tipo3/emufs.c +++ b/tipo3/emufs.c @@ -1,18 +1,19 @@ - #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 ".did" + +char *str_dup(const char *s); char *str_dup(const char *s) { + char *tmp; if (s == NULL) return NULL; - char *tmp = (char *)malloc(sizeof(char)*(strlen(s)+1)); + tmp = (char *)malloc(sizeof(char)*(strlen(s)+1)); strcpy(tmp, s); return tmp; } @@ -35,7 +36,7 @@ EMUFS *emufs_crear(const char *filename, char tipo, unsigned int tam_bloque, uns tmp->leer_bloque = leer_bloque; tmp->leer_registro = leer_registro; tmp->grabar_registro = grabar_registro; - tmp->borrar_registro = NULL; + tmp->borrar_registro = borrar_registro; tmp->nombre = str_dup(filename); strcpy(name, filename); @@ -67,11 +68,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); @@ -90,6 +87,8 @@ EMUFS *emufs_abrir(const char *filename) strcpy(name, filename); strcat(name, EXT_TIPO3_DATA); + + /* Trato de determinar el tipo de archivo */ fp = fopen(name, "r"); if (fp == NULL) return NULL; fread(&tipo, sizeof(char), 1, fp); @@ -99,7 +98,10 @@ EMUFS *emufs_abrir(const char *filename) } tmp = (EMUFS *)malloc(sizeof(EMUFS)); - if (tmp == NULL) return NULL; + if (tmp == NULL) { + fclose(fp); + return NULL; + } switch (tipo) { case T1: @@ -112,7 +114,7 @@ EMUFS *emufs_abrir(const char *filename) tmp->leer_bloque = leer_bloque; tmp->leer_registro = leer_registro; tmp->grabar_registro = grabar_registro; - tmp->borrar_registro = NULL; + tmp->borrar_registro = borrar_registro; tmp->nombre = str_dup(filename); } @@ -151,13 +153,13 @@ int ver_archivo_FS(EMUFS *emu) /* Imprimo la lista de bloques/registros */ strcpy(name_f_block_free,emu->nombre); - strcat(name_f_block_free,".id3"); + 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 %d en bloque %d\n", r.id_reg, r.block); + 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);