X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/46453eaa7a7cbd8a43d9bbebda683814b13a832c..a680ab304d20541f4bf03709354b7b7c2ffdf993:/emufs/did.c diff --git a/emufs/did.c b/emufs/did.c index 2a071a6..d2b14af 100644 --- a/emufs/did.c +++ b/emufs/did.c @@ -37,43 +37,84 @@ */ #include "did.h" -#include +#include "error.h" +#include "common.h" #include +#include int emufs_did_crear(EMUFS* efs) { return emufs_crear_archivo_auxiliar(efs->nombre, EMUFS_DID_EXT); } -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; 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 = 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; } @@ -84,7 +125,7 @@ int emufs_did_agregar(EMUFS *efs, EMUFS_REG_ID n_regid) 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); @@ -93,3 +134,10 @@ int emufs_did_agregar(EMUFS *efs, EMUFS_REG_ID n_regid) 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); +}