X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/8665a7da4441e79f72cb35246be42f094c54bdc6..6a1af16bedb847cc08ce70484b417bfc89c7c7fc:/emufs/tipo2.c diff --git a/emufs/tipo2.c b/emufs/tipo2.c index ed8b163..d195835 100644 --- a/emufs/tipo2.c +++ b/emufs/tipo2.c @@ -44,7 +44,7 @@ /* void *ptr // Puntero al buffer (registro) a guardar */ /* EMUFS_REG_SIZE n_RegSize // Size del reg en cuestion */ /**********************************************************************/ -EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr, EMUFS_REG_SIZE n_RegSize) +EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr, EMUFS_REG_SIZE n_RegSize, int* err) { EMUFS_REG_ID n_IdReg; EMUFS_FREE n_FreeSpace; @@ -57,7 +57,7 @@ EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr, EMUFS_REG_SIZE n strcpy(name_f,efs->nombre); strcat(name_f,".dat"); - if ( (f_data = fopen(name_f,"a+"))==NULL ) return -1; /*ERROR*/ + if ( (f_data = fopen(name_f,"r+"))==NULL ) return -1; /*ERROR*/ /* Obtengo un offset en donde iniciar la escritura de mi registro */ /* de manera segura (habra espacio suficiente) */ @@ -69,7 +69,7 @@ EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr, EMUFS_REG_SIZE n if (n_WrtOffset == -1) { /* Obtengo un ID libre para el registro y luego grabo a disco */ - n_IdReg = emufs_tipo2_get_id(efs); + n_IdReg = emufs_idx_get_new_id(efs, err); fseek(f_data, 0, SEEK_END); n_RegOffset = ftell(f_data); @@ -84,6 +84,23 @@ EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr, EMUFS_REG_SIZE n } else { + /* Obtengo un ID libre para el registro y luego grabo en disco */ + n_IdReg = emufs_idx_get_new_id(efs, err); + n_RegOffset = n_WrtOffset; + fseek(f_data,n_RegOffset,0); + + /* Escribo [RegId]|[RegSize]|[RegData] */ + fwrite(&n_IdReg,sizeof(EMUFS_REG_ID),1,f_data); + fwrite(&n_RegSize,sizeof(EMUFS_REG_SIZE),1,f_data); + fwrite(ptr,n_RegSize,1,f_data); + + /* Bye */ + printf("Tipo2.c >> RegNr: %lu with FisicSize: %lu inserted at Offset: %lu\n",n_IdReg,n_FisicSize,n_RegOffset); + fclose(f_data); + + /* Actualizo el espacio libre en el GAP donde puse el registro */ + if ((n_FreeSpace-n_FisicSize) == 0) emufs_fsc_remove_gap(efs,n_RegOffset); + else emufs_fsc_actualizar_gap(efs,n_RegOffset,n_FreeSpace-n_FisicSize); } /* Finalmente, actualizamos el indice de registros (offsets) */ @@ -101,8 +118,6 @@ EMUFS_REG_ID emufs_tipo2_grabar_registro(EMUFS *efs, void *ptr, EMUFS_REG_SIZE n /**********************************************************************/ int emufs_tipo2_borrar_registro(EMUFS *efs, EMUFS_REG_ID n_IdReg) { - FILE *f_data; - char name_f[255]; EMUFS_OFFSET n_RegOffset,n_RegSize; /* Obtenemos el offset donde arranca el registro */ @@ -116,6 +131,16 @@ int emufs_tipo2_borrar_registro(EMUFS *efs, EMUFS_REG_ID n_IdReg) printf ("tipo2.c >> About to delete Reg %lu of Size: %lu\n",n_IdReg,n_RegSize); emufs_tipo2_dummyfill(efs,n_RegOffset,n_RegSize); + /* Agregamos el GAP en el archivo de FSC, el cual hara un merge con */ + /* otro GAP por delante y/o por detras en caso de hallarlo. */ + emufs_fsc_agregar_gap(efs,n_RegOffset,n_RegSize+sizeof(EMUFS_REG_ID)+sizeof(EMUFS_REG_SIZE)); + + /* Agrego el ID que se ha liberado al archivo de ID's Libres */ + emufs_did_agregar(efs,n_IdReg); + + /* Borramos el registro del indice de posiciones relativas */ + /*emufs_idx_borrar(efs,n_IdReg);*/ + return(0); } @@ -181,18 +206,3 @@ int emufs_tipo2_dummyfill(EMUFS *efs, EMUFS_OFFSET n_RegPos, EMUFS_REG_SIZE n_Am return (0); } -/**********************************************************************/ -/* EMUFS_REG_ID emufs_tipo2_get_id(EMUFS *efs) */ -/* Objetivo: Devuelve un Id apropiado y disponible para un nuevo reg */ -/* Parametros: EMUFS *emu // Struct con handlers + info del openfile. */ -/**********************************************************************/ -EMUFS_REG_ID emufs_tipo2_get_id(EMUFS *efs) -{ - EMUFS_REG_ID n_RegId; - - /* Si no se hallo un id libre, entonces debo usar el maximo + 1 */ - if ( (n_RegId = emufs_did_get_last(efs)) == -1 ) - n_RegId = emufs_idx_buscar_mayor_id(efs); - - return n_RegId; -}