From: Alan Kennedy Date: Sun, 11 Apr 2004 03:11:27 +0000 (+0000) Subject: Tipo2 ya reutiliza ID's y Gaps en el archivo de datos. Aun falta fixear el borrado... X-Git-Tag: svn_import_r684~560 X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/commitdiff_plain/be4cb2ce4e27a069a22ff7e253ca60cd41b4d5de?ds=inline Tipo2 ya reutiliza ID's y Gaps en el archivo de datos. Aun falta fixear el borrado de un reg del .idx. --- diff --git a/emufs/tipo2.c b/emufs/tipo2.c index 6f05f66..194eee8 100644 --- a/emufs/tipo2.c +++ b/emufs/tipo2.c @@ -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) */ @@ -84,6 +84,22 @@ 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_tipo2_get_id(efs); + 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 */ + emufs_fsc_actualizar(efs,n_WrtOffset,n_FreeSpace-n_FisicSize); } /* Finalmente, actualizamos el indice de registros (offsets) */ @@ -117,8 +133,12 @@ int emufs_tipo2_borrar_registro(EMUFS *efs, EMUFS_REG_ID n_IdReg) 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 hayarlo. */ + /* 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);*/ diff --git a/emufs/tipo2_main.c b/emufs/tipo2_main.c index f0a5213..bdb4604 100644 --- a/emufs/tipo2_main.c +++ b/emufs/tipo2_main.c @@ -35,7 +35,7 @@ int main(int argc, char *argv[]) { EMUFS *fp; - EMUFS_REG_ID n1, n2, n3, n4, n5, n6, n7, n8; + EMUFS_REG_ID n0, n1, n2, n3, n4, n5, n6, n7, n8; char a[11]; char b[63]; char c[13]; @@ -62,36 +62,31 @@ int main(int argc, char *argv[]) fp = emufs_crear("articulos", T2, 0, 0); /* Grabamos un par de registros */ - n1 = fp->grabar_registro(fp, a, 11, &err); - n2 = fp->grabar_registro(fp, b, 63, &err); - n3 = fp->grabar_registro(fp, c, 13, &err); - n4 = fp->grabar_registro(fp, d, 8, &err); - n5 = fp->grabar_registro(fp, e, 39, &err); - n6 = fp->grabar_registro(fp, f, 9, &err); - n7 = fp->grabar_registro(fp, g, 41, &err); - n8 = fp->grabar_registro(fp, h, 63, &err); + n0 = fp->grabar_registro(fp, a, 11, &err); + n1 = fp->grabar_registro(fp, b, 63, &err); + n2 = fp->grabar_registro(fp, c, 13, &err); + n3 = fp->grabar_registro(fp, d, 8, &err); + n4 = fp->grabar_registro(fp, e, 39, &err); + n5 = fp->grabar_registro(fp, f, 9, &err); + n6 = fp->grabar_registro(fp, g, 41, &err); + n7 = fp->grabar_registro(fp, h, 63, &err); /* Borramos un registro del medio */ + printf("tipo2_main.c >> Borrando registro: %lu\n",n0); + fp->borrar_registro(fp, n0); + printf("tipo2_main.c >> Borrando registro: %lu\n",n5); + fp->borrar_registro(fp, n5); printf("tipo2_main.c >> Borrando registro: %lu\n",n1); fp->borrar_registro(fp, n1); + printf("tipo2_main.c >> Borrando registro: %lu\n",n7); + fp->borrar_registro(fp, n7); + printf("tipo2_main.c >> Borrando registro: %lu\n",n3); + fp->borrar_registro(fp, n3); printf("tipo2_main.c >> Borrando registro: %lu\n",n6); fp->borrar_registro(fp, n6); - printf("tipo2_main.c >> Borrando registro: %lu\n",n2); - fp->borrar_registro(fp, n2); - printf("tipo2_main.c >> Borrando registro: %lu\n",n8); - fp->borrar_registro(fp, n8); - printf("tipo2_main.c >> Borrando registro: %lu\n",n4); - fp->borrar_registro(fp, n4); - printf("tipo2_main.c >> Borrando registro: %lu\n",n7); - fp->borrar_registro(fp, n7); - - /*n8 = fp->grabar_registro(fp, i, 100); - fp->leer_registro(fp, n8, b, 100); - - printf("Recuperado : %s\n", b); - - ver_archivo_FS(fp);*/ + n8 = fp->grabar_registro(fp, f, 9, &err); + printf("tipo2_main.c >> Id recuperado: %lu\n",n8); emufs_destruir(fp);