X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/32feb1e82b00d6c1ad3f5aa6884d003a665ea975..baf79a90e2addd39a342fcb910bbfdb6ee6623cf:/emufs/tipo1.h diff --git a/emufs/tipo1.h b/emufs/tipo1.h index 00e63d5..946d36e 100644 --- a/emufs/tipo1.h +++ b/emufs/tipo1.h @@ -40,27 +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*); +/** Borra un registro de del archivo. */ +int emufs_tipo1_borrar_registro(EMUFS*, EMUFS_REG_ID); + +/** 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_registro(EMUFS*, EMUFS_REG_ID); +/** Obtiene estádisticas del archivo */ +EMUFS_Estadisticas emufs_tipo1_leer_estadisticas(EMUFS*); -int emufs_tipo1_borrar_registro(EMUFS*, EMUFS_REG_ID, EMUFS_REG_SIZE); +/** Método para compactar el archivo reorganizándolo físicamente */ +void emufs_tipo1_compactar(EMUFS*); -/* -int emufs_tipo1_buscar_lugar(EMUFS *emu, EMUFS_REG_SIZE tam_reg, - EMUFS_FREE *free_space); -*/ +/** 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_ */