X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/a7a781b6b1a260c882ad779a9ecdaa517d1a6846..46453eaa7a7cbd8a43d9bbebda683814b13a832c:/emufs/did.c diff --git a/emufs/did.c b/emufs/did.c index 90a200b..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$ @@ -39,50 +40,56 @@ #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, 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 (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; } -/*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); + 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; } +