X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/6c5fe1e15e441c27ba01b22b91bf1e5843ae53f2..502a6f92fd7acf3c942a92b41bf0ed788a128515:/emufs/did.c?ds=sidebyside diff --git a/emufs/did.c b/emufs/did.c index f193025..6e13fd5 100644 --- a/emufs/did.c +++ b/emufs/did.c @@ -20,6 +20,7 @@ *---------------------------------------------------------------------------- * Creado: jue abr 8 18:07:57 ART 2004 * Autores: Nicolás Dimov + * Leandro Lucarella *---------------------------------------------------------------------------- * * $Id$ @@ -36,55 +37,108 @@ */ #include "did.h" -#include +#include "error.h" +#include "common.h" #include +#include -#define EMUFS_DID_EXT ".did" +int emufs_did_crear(EMUFS* efs) +{ + return emufs_crear_archivo_auxiliar(efs->nombre, EMUFS_DID_EXT); +} -int emufs_did_get_last(EMUFS *emu) +EMUFS_REG_ID emufs_did_get_last(EMUFS *efs, int* err) { - FILE * f_did; - int id, offset; + FILE *f_did; + EMUFS_REG_ID n_regid; + EMUFS_OFFSET n_offset; char name_f_did[255]; + long pos; - strcpy(name_f_did, emu->nombre); - strcat(name_f_did, EMUFS_DID_EXT); + 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(int),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(&id,sizeof(int),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*/ - 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, offset - sizeof(int)); - } 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 */ - id = -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 id; + return n_regid; } -/*agrego un elemento al archivo */ -int emufs_did_agregar(EMUFS *emu, int ID) +int emufs_did_agregar(EMUFS *efs, EMUFS_REG_ID n_regid) { FILE *f_did; char name_f_did[255]; - strcpy(name_f_did, emu->nombre); - strcat(name_f_did, EMUFS_DID_EXT); + strcpy(name_f_did, efs->nombre); + 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; } + +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); +} +