X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/e2d6cf91432b8e560b030b54645a9c41e703aea6..46453eaa7a7cbd8a43d9bbebda683814b13a832c:/emufs/did.c?ds=inline diff --git a/emufs/did.c b/emufs/did.c index ac09cab..2a071a6 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,35 +37,59 @@ */ #include "did.h" +#include +#include -int emufs_did_get_last(EMUFS *emu) +int emufs_did_crear(EMUFS* efs) { - FILE * f_did; - int id, offset; + return emufs_crear_archivo_auxiliar(efs->nombre, EMUFS_DID_EXT); +} + +EMUFS_REG_ID emufs_did_get_last(EMUFS *efs) +{ + FILE *f_did; + EMUFS_REG_ID n_regid; + EMUFS_OFFSET n_offset; char name_f_did[255]; - strcpy(name_f_did, emu->nombre); - strcat(name_f_did, ".did"); + 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 (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 */ - 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*/ - offset = ftell(f_did); + n_offset = ftell(f_did); 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 */ - id = -1; + n_regid = EMUFS_NOT_FOUND; } - return id; + return 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); + + if ( (f_did = fopen(name_f_did,"a+")) == NULL) return -1; + fwrite(&n_regid, sizeof(EMUFS_REG_ID), 1, f_did); + fclose(f_did); + + return 0; +} +