X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/c407055e1cc6ff4c435114091c3a5430486aa659..6fbc46ce4632b59358a971178cabe01ab9e639b3:/emufs/did.c?ds=inline diff --git a/emufs/did.c b/emufs/did.c index 5c386b5..6e13fd5 100644 --- a/emufs/did.c +++ b/emufs/did.c @@ -37,61 +37,108 @@ */ #include "did.h" -#include +#include "error.h" +#include "common.h" #include +#include -/* Crea un archivo de ID's Liberados. */ int emufs_did_crear(EMUFS* efs) { return emufs_crear_archivo_auxiliar(efs->nombre, EMUFS_DID_EXT); } -/* Devuelve el ID Libre, liberado mas recientemente (pila) */ -EMUFS_REG_ID emufs_did_get_last(EMUFS *efs) +EMUFS_REG_ID emufs_did_get_last(EMUFS *efs, int* err) { FILE *f_did; - EMUFS_REG_ID n_RegId; - EMUFS_OFFSET n_Offset; + EMUFS_REG_ID n_regid; + EMUFS_OFFSET n_offset; char name_f_did[255]; + long pos; 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*/ - fseek(f_did, 0, SEEK_END); + if ((f_did = fopen(name_f_did, "rb")) == NULL) { + PERR("No se puede abrir archivo"); + *err = EMUFS_ERROR_CANT_OPEN_FILE; + return EMUFS_NOT_FOUND; + } + if (fseek(f_did, 0l, SEEK_END)) { + PERR("No se pudo hacer fseek()"); + fclose(f_did); + *err = EMUFS_ERROR_SEEK_FILE; + return EMUFS_NOT_FOUND; + } - if (ftell(f_did) > 0){ + if ((pos = ftell(f_did)) > 0){ /* si el archivo no esta vacio es porque hay un nro disponible*/ - fseek(f_did, -sizeof(EMUFS_REG_ID),SEEK_END); + if (fseek(f_did, -sizeof(EMUFS_REG_ID), SEEK_END)) { + PERR("No se pudo hacer fseek()"); + fclose(f_did); + *err = EMUFS_ERROR_SEEK_FILE; + return EMUFS_NOT_FOUND; + } /* leo el ultimo numero */ - fread(&n_RegId,sizeof(EMUFS_REG_ID),1,f_did); + if (fread(&n_regid, sizeof(EMUFS_REG_ID), 1, f_did) != 1) { + fclose(f_did); + PERR("Error al leer did"); + *err = EMUFS_ERROR_FILE_READ; + return EMUFS_NOT_FOUND; + } /* voy al final */ - fseek(f_did, 0, SEEK_END); - /* mido el tamaño del archivo*/ - n_Offset = ftell(f_did); + if (fseek(f_did, 0l, SEEK_END)) { + PERR("No se pudo hacer fseek()"); + fclose(f_did); + *err = EMUFS_ERROR_SEEK_FILE; + return EMUFS_NOT_FOUND; + } + /* mido el tamaño del archivo */ + if ((n_offset = ftell(f_did)) == -1) { + PERR("No se pudo hacer ftell()"); + fclose(f_did); + *err = EMUFS_ERROR_TELL_FILE; + return EMUFS_NOT_FOUND; + } fclose(f_did); - /*lo trunco */ - truncate(name_f_did, n_Offset - sizeof(EMUFS_REG_ID)); - } else { + /* lo trunco */ + if (truncate(name_f_did, n_offset - sizeof(EMUFS_REG_ID))) { + PERR("No se pudo truncar el archivo did"); + *err = EMUFS_ERROR_TRUNCATE_FILE; + return EMUFS_NOT_FOUND; + } + } else if (!pos) { fclose(f_did); /* si el archivo esta vacio */ - n_RegId = -1; + n_regid = EMUFS_NOT_FOUND; + } else { + PERR("No se pudo hacer ftell()"); + fclose(f_did); + *err = EMUFS_ERROR_TELL_FILE; + return EMUFS_NOT_FOUND; } - return n_RegId; + return n_regid; } -/* Agrega un registro al archivo de ID's Libres (pila) */ -int emufs_did_agregar(EMUFS *efs, EMUFS_REG_ID n_RegId) +int emufs_did_agregar(EMUFS *efs, EMUFS_REG_ID n_regid) { FILE *f_did; char name_f_did[255]; strcpy(name_f_did, efs->nombre); - strcat(name_f_did, EMUFS_DID_EXT); + strcat(name_f_did, EMUFS_DID_EXT); if ( (f_did = fopen(name_f_did,"a+")) == NULL) return -1; - fwrite(&n_RegId, sizeof(EMUFS_REG_ID), 1, f_did); + fwrite(&n_regid, sizeof(EMUFS_REG_ID), 1, f_did); fclose(f_did); return 0; } + +long emufs_did_get_file_size(EMUFS* efs, int* err) +{ + char name[255]; + strcpy(name, efs->nombre); + strcat(name, EMUFS_DID_EXT); + return emufs_common_get_file_size(name, err); +} +