X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/ee1e9c0b0bf3af3579980b6cda4237efbc37e876..f00458382f8b687eeef68f9f5fe9e9245a4d5fb5:/emufs/tipo1.h diff --git a/emufs/tipo1.h b/emufs/tipo1.h index 830e60c..946d36e 100644 --- a/emufs/tipo1.h +++ b/emufs/tipo1.h @@ -40,32 +40,37 @@ #include "emufs.h" -int emufs_tipo1_inicializar(EMUFS*); +/** Inicializa un EMUFS para poder ser utilizado como un archivo tipo1. + * + * \param efs Estructura a inicializar. + * \return Código de error o EMUFS_OK si no hubo error. + */ +int emufs_tipo1_inicializar(EMUFS* efs); -/** Lee el registro \param id_reg y lo almacena en \param ptr */ +/** Lee el registro \c reg_id y devolviendo su contenido. */ void* emufs_tipo1_leer_registro(EMUFS*, EMUFS_REG_ID, EMUFS_REG_SIZE*, int*); -/** Lee el bloque \param num_bloque y lo almacena en \param ptr */ -void* emufs_tipo1_leer_bloque(EMUFS*, EMUFS_BLOCK_ID, int*); - -/** Graba el registro apuntado por \param ptr en el archivo */ +/** Graba un registro en el archivo. */ EMUFS_REG_ID emufs_tipo1_grabar_registro(EMUFS*, void*, EMUFS_REG_SIZE, int*); -/** Graba el bloque apuntado por \param ptr en el archivo */ -EMUFS_BLOCK_ID emufs_tipo1_grabar_bloque(EMUFS*, void*, EMUFS_BLOCK_ID, int*); - -int emufs_tipo1_buscar_registro(EMUFS*, EMUFS_REG_ID); - +/** Borra un registro de del archivo. */ int emufs_tipo1_borrar_registro(EMUFS*, EMUFS_REG_ID); -/** Método para modificar un registro */ +/** Método para modificar un registro. */ EMUFS_REG_ID emufs_tipo1_modificar_registro(EMUFS *emu, EMUFS_REG_ID, void*, EMUFS_REG_SIZE, int*); +/** Método para leer un registro con todo su bloque asociado. */ void* emufs_tipo1_leer_registro_raw(EMUFS *emu, EMUFS_REG_ID id, EMUFS_REG_SIZE *size, int *pos); -/* -int emufs_tipo1_buscar_lugar(EMUFS *emu, EMUFS_REG_SIZE tam_reg, - EMUFS_FREE *free_space); -*/ +/** Obtiene estádisticas del archivo */ +EMUFS_Estadisticas emufs_tipo1_leer_estadisticas(EMUFS*); + +/** Método para compactar el archivo reorganizándolo físicamente */ +void emufs_tipo1_compactar(EMUFS*); + +/** Lee un bloque y su contexto, en bruto (con cabeceras). */ +void emufs_tipo1_leer_bloque_raw(EMUFS *efs, EMUFS_BLOCK_ID id, char **actual, + char **anterior, char **siguiente, EMUFS_BLOCK_SIZE *size1, + EMUFS_BLOCK_SIZE *size2, EMUFS_BLOCK_SIZE *size3); #endif /* _EMUFS_TIPO1_H_ */