]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/did.c
* Mas normalizacion de nomenclaruta
[z.facultad/75.06/emufs.git] / emufs / did.c
index 407b123e418e1db47f92a6d080391d3ac2a03ebf..5c386b5d6654a9931e3e2f244f7d7f2cd6007761 100644 (file)
 #include <string.h>
 #include <unistd.h>
 
 #include <string.h>
 #include <unistd.h>
 
+/* Crea un archivo de ID's Liberados. */
 int emufs_did_crear(EMUFS* efs)
 {
        return emufs_crear_archivo_auxiliar(efs->nombre, EMUFS_DID_EXT);
 }
 
 int emufs_did_crear(EMUFS* efs)
 {
        return emufs_crear_archivo_auxiliar(efs->nombre, EMUFS_DID_EXT);
 }
 
-int emufs_did_get_last(EMUFS *emu)
+/* Devuelve el ID Libre, liberado mas recientemente (pila) */
+EMUFS_REG_ID emufs_did_get_last(EMUFS *efs)
 {
 {
-       FILE * f_did;
-       int id, offset;
+       FILE *f_did;
+       EMUFS_REG_ID n_RegId;
+       EMUFS_OFFSET n_Offset;
        char name_f_did[255];
        
        char name_f_did[255];
        
-       strcpy(name_f_did, emu->nombre);
+       strcpy(name_f_did, efs->nombre);
        strcat(name_f_did, EMUFS_DID_EXT);
        
        if ( (f_did = fopen(name_f_did,"r")) == NULL) return -1; /*ERROR*/
        strcat(name_f_did, EMUFS_DID_EXT);
        
        if ( (f_did = fopen(name_f_did,"r")) == NULL) return -1; /*ERROR*/
@@ -59,35 +62,35 @@ int emufs_did_get_last(EMUFS *emu)
        
        if (ftell(f_did) > 0){
                /* si el archivo no esta vacio es porque hay un nro disponible*/
        
        if (ftell(f_did) > 0){
                /* si el archivo no esta vacio es porque hay un nro disponible*/
-               fseek(f_did, -sizeof(int),SEEK_END);
+               fseek(f_did, -sizeof(EMUFS_REG_ID),SEEK_END);
                /* leo el ultimo numero */
                /* leo el ultimo numero */
-               fread(&id,sizeof(int),1,f_did);
+               fread(&n_RegId,sizeof(EMUFS_REG_ID),1,f_did);
                /* voy al final */
                fseek(f_did, 0, SEEK_END);
                /* mido el tamaño del archivo*/
                /* voy al final */
                fseek(f_did, 0, SEEK_END);
                /* mido el tamaño del archivo*/
-               offset = ftell(f_did);
+               n_Offset = ftell(f_did);
                fclose(f_did);
                /*lo trunco */
                fclose(f_did);
                /*lo trunco */
-               truncate(name_f_did, offset - sizeof(int));
+               truncate(name_f_did, n_Offset - sizeof(EMUFS_REG_ID));
        } else {
                fclose(f_did);
                /* si el archivo esta vacio */
        } else {
                fclose(f_did);
                /* si el archivo esta vacio */
-               id = -1;
+               n_RegId = -1;
        }
        }
-       return id;
+       return n_RegId;
 }
 
 }
 
-/*agrego un elemento al archivo */
-int emufs_did_agregar(EMUFS *emu, int ID)
+/* Agrega un registro al archivo de ID's Libres (pila) */
+int emufs_did_agregar(EMUFS *efs, EMUFS_REG_ID n_RegId)
 {
        FILE *f_did;
        char name_f_did[255];
        
 {
        FILE *f_did;
        char name_f_did[255];
        
-       strcpy(name_f_did, emu->nombre);
+       strcpy(name_f_did, efs->nombre);
        strcat(name_f_did,  EMUFS_DID_EXT);
        
        if ( (f_did = fopen(name_f_did,"a+")) == NULL) return -1;
        strcat(name_f_did,  EMUFS_DID_EXT);
        
        if ( (f_did = fopen(name_f_did,"a+")) == NULL) return -1;
-       fwrite(&ID, sizeof(int), 1, f_did);
+       fwrite(&n_RegId, sizeof(EMUFS_REG_ID), 1, f_did);
        fclose(f_did);
        
        return 0;
        fclose(f_did);
        
        return 0;