1 /* vim: set noexpandtab tabstop=4 shiftwidth=4:
2 *----------------------------------------------------------------------------
4 *----------------------------------------------------------------------------
5 * This file is part of emufs.
7 * emufs is free software; you can redistribute it and/or modify it under the
8 * terms of the GNU General Public License as published by the Free Software
9 * Foundation; either version 2 of the License, or (at your option) any later
12 * emufs is distributed in the hope that it will be useful, but WITHOUT ANY
13 * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
17 * You should have received a copy of the GNU General Public License along
18 * with emufs; if not, write to the Free Software Foundation, Inc., 59 Temple
19 * Place, Suite 330, Boston, MA 02111-1307 USA
20 *----------------------------------------------------------------------------
21 * Creado: vie abr 9 16:47:54 ART 2004
22 * Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 *----------------------------------------------------------------------------
31 * Archivo con bloque de longitud parametrizada, registro de longitud variable.
33 * Interfaz del archivo con bloques de longitud parametrizada y registros de
38 #ifndef _EMUFS_TIPO1_H_
39 #define _EMUFS_TIPO1_H_
42 #include "indice_bplus.h"
44 /** Inicializa un EMUFS para poder ser utilizado como un archivo tipo1.
46 * \param efs Estructura a inicializar.
47 * \return Código de error o EMUFS_OK si no hubo error.
49 int emufs_tipo1_inicializar(EMUFS* efs);
51 int emufs_tipo4_inicializar(EMUFS* efs);
53 /** Lee el registro \c reg_id y devolviendo su contenido. */
54 void* emufs_tipo1_leer_registro(EMUFS*, CLAVE, EMUFS_REG_SIZE*, int*);
56 /** Graba un registro en el archivo. */
57 EMUFS_REG_ID emufs_tipo1_grabar_registro(EMUFS*, void*, EMUFS_REG_SIZE, int*);
59 /** Borra un registro de del archivo. */
60 int emufs_tipo1_borrar_registro(EMUFS*, CLAVE, INDICE_DATO);
62 /** Método para modificar un registro. */
63 EMUFS_REG_ID emufs_tipo1_modificar_registro(EMUFS *emu, CLAVE k, void*, EMUFS_REG_SIZE, int*, INDICE_DATO);
65 /** Método para leer un registro con todo su bloque asociado. */
66 void* emufs_tipo1_leer_registro_raw(EMUFS *emu, EMUFS_REG_ID id, EMUFS_REG_SIZE *size, int *pos);
68 /** Obtiene estádisticas del archivo */
69 EMUFS_Estadisticas emufs_tipo1_leer_estadisticas(EMUFS*);
71 /** Método para compactar el archivo reorganizándolo físicamente */
72 void emufs_tipo1_compactar(EMUFS*);
74 /** Lee un bloque y su contexto, en bruto (con cabeceras). */
75 void emufs_tipo1_leer_bloque_raw(EMUFS *efs, EMUFS_BLOCK_ID id, char **actual,
76 char **anterior, char **siguiente, EMUFS_BLOCK_SIZE *size1,
77 EMUFS_BLOCK_SIZE *size2, EMUFS_BLOCK_SIZE *size3);
79 /** Inserta un registro en el archivo, ordenado por clave principal*/
80 EMUFS_REG_ID emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, int *err);
82 /** Elimina un registro de clave CLAVE del archivo con ayuda del arbol B+*/
83 int emufs_tipo1_eliminar_ordenado(EMUFS *emu, CLAVE clave, INDICE_DATO dato);
85 void *emufs_tipo1_leer_registro_plus(EMUFS *emu, CLAVE clave, EMUFS_REG_SIZE *size, int *err);
87 EMUFS_REG_ID emufs_tipo1_modificar_registro_plus(EMUFS *emu, CLAVE k, void*, EMUFS_REG_SIZE, int*, INDICE_DATO);
88 #endif /* _EMUFS_TIPO1_H_ */