]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - tipo3/emufs.c
limpio un poquito el codigo, sale con fritas esto./main./main... falta borrar_registr...
[z.facultad/75.06/emufs.git] / tipo3 / emufs.c
index a76974116286e2ef87a5ee299858db12722518ac..4d7409706876cf9b249ad81d182ecb619c811058 100644 (file)
@@ -1,18 +1,17 @@
-
 #include "emufs.h"
 #include "param_cte.h"
 
 /* Defino las extenciones que usan cada tipo de archivo */
 #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_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)
 {
 
 char *str_dup(const char *s)
 {
+       char *tmp;
        if (s == NULL) return NULL;
        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;
 }
        strcpy(tmp, s);
        return tmp;
 }
@@ -67,11 +66,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);
                        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);
                break;
                default:
                        free(tmp);
@@ -128,3 +123,41 @@ int emufs_destruir(EMUFS *e)
        return 0;
 }
 
        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(&reg,sizeof(reg),1,f_block_free);
+       while ( !feof(f_block_free) ){
+               printf(" Bloque = %d   Espacio libre = %d\n",reg.block, reg.free_space);
+               fread(&reg,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;
+}