1 /* vim: set noexpandtab tabstop=4 shiftwidth=4 wrap:
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: mié mar 31 17:26:46 ART 2004
22 * Autores: Nicolás Dimov <sagardua@uolsinectis.com.ar>
23 * Ricardo Markiewicz <rmarkie@fi.uba.ar>
24 * Leandro Lucarella <llucare@fi.uba.ar>
25 *----------------------------------------------------------------------------
33 * Estructura general de un archivo <em>abstracto</em> de emufs.
35 * Interfaz de la estructura abstracta que representa cualquiera de los tipos
36 * de archivo implementados.
49 /** Tipo de archivo. */
51 T1, /**< Archivo de bloque parametrizado y registro variable. */
52 T2, /**< Archivo sin bloques y registros variables. */
53 T3 /**< Archivo de bloque parametrizado y registro fijo. */
56 /** Tipo de identificador de registro. */
57 typedef unsigned long EMUFS_REG_ID;
59 /** Tipo de tamaño de registro. */
60 typedef unsigned long EMUFS_REG_SIZE;
62 /** Tipo de identificador de bloque. */
63 typedef unsigned long EMUFS_BLOCK_ID;
65 /** Tipo de tamaño de bloque. */
66 typedef unsigned long EMUFS_BLOCK_SIZE;
68 /** Tipo de espacio libre. */
69 typedef unsigned long EMUFS_FREE;
71 /** Tipo de offset. */
72 typedef unsigned long EMUFS_OFFSET;
74 /** Constante para indicar el valor especial de un ID inválido.
76 * El uso típico es para indicar que no se encontró el ID en una búsqueda.
78 #define EMUFS_NOT_FOUND -1ul
80 /** Estadisticas de archivo. */
81 typedef struct _emufs_est_t {
82 unsigned long tam_archivo;/**< Tamaño en bytes del archivo .dat */
83 unsigned long tam_archivos_aux;/**< Tamaño en bytes de los archivos auxiliares sumados */
84 unsigned long tam_info_control_dat;/**< Cantidad de bytes en info de control del .dat */
85 unsigned long media_fs;/**< Media del espacio libre en el archivo de datos */
86 unsigned long total_fs;/**< Cantidad total de espacio libre en el archivo de datos */
87 unsigned long max_fs;/**< Cantidad de maxima libre (gap o fs en bloque) en el archivo de datos */
88 unsigned long min_fs;/**< Cantidad de minima libre (gap o fs en bloque) en el archivo de datos */
89 unsigned long cant_bloques; /**< Cantidad de bloques en el archivo de datos */
90 unsigned long cant_registros; /**< Cantidad de Registros en el archivo */
93 /** Tipo Abstracto para menajo de archivos.
95 * Esta estructura es utilizada para acceder a cualquier tipo de archivo.
97 * Cuando se requiere abrir o crear un nuevo archivo, esta estrucura contendrá los
98 * punteros a los métodos de dicho archivo, por lo que desde el código que utilice
99 * esta estructura no deberá ser modificado por cada tipo de archivo.
103 * EMUFS *fs = emufs_abrir("archivo");
104 * fs->leer_registro(id, ptr, size);
107 * Este ejemplo funcionará sin importar de que tipo de archivo se trate, sin
108 * la necesidad de que el usuario tenga que hacer una selección previa del tipo
109 * para llamar al método correspondiente a cada tipo de archivo.
113 EMUFS_BLOCK_SIZE tam_bloque; /**< Tamaño de bloque. 0 Si no tiene bloques */
114 EMUFS_REG_SIZE tam_reg; /**< Tamaño de registro. 0 Si son registros variables */
115 void* (*leer_bloque)(struct _emu_fs_t*, EMUFS_BLOCK_ID, int*); /**< Método para leer un bloque */
116 void (*leer_bloque_raw)(struct _emu_fs_t*, EMUFS_BLOCK_ID, char **, char **, char **, EMUFS_BLOCK_SIZE *, EMUFS_BLOCK_SIZE *, EMUFS_BLOCK_SIZE *); /**< Método para leer un bloque, el anterior y el siguiente */
117 void* (*leer_registro)(struct _emu_fs_t*, CLAVE, EMUFS_REG_SIZE*, int*); /**< Método para leer un registro */
118 void* (*leer_registro_raw)(struct _emu_fs_t*, EMUFS_REG_ID, EMUFS_REG_SIZE*, int *); /**< Método para leer un registro con todo su bloque asociado */
119 EMUFS_REG_ID (*grabar_registro)(struct _emu_fs_t*, void*, EMUFS_REG_SIZE, int*); /**< Método para grabar un registro */
120 EMUFS_REG_ID (*modificar_registro)(struct _emu_fs_t*, CLAVE k, void*, EMUFS_REG_SIZE, int*, INDICE_DATO); /**< Método para modificar un registro */
121 int (*borrar_registro)(struct _emu_fs_t*, CLAVE, INDICE_DATO); /**< Método para borrar un registro */
122 EMUFS_Estadisticas (*leer_estadisticas)(struct _emu_fs_t *); /**< Método para obtener estádisticas sobre el archivo */
123 void (*compactar)(struct _emu_fs_t *); /**< Método para compactar el archivo reorganizándolo físicamente */
124 char *nombre; /**< Nombre del archivo */
129 /** Crea un archivo auxiliar. */
130 int emufs_crear_archivo_auxiliar(const char*, const char*);
132 /** Crea un nuevo archivo EMUFS.
134 * Un archivo EMUFS está compuesto por 4 archivos a nivel del SO.
135 * Un archivo principal con extensión .dat y 3 archivos auxiliares para
138 * El parámetro filename que recive esta función en el nombre virtual que se
139 * utilizará, ya que las extensiones serán puestas automáticamente for EMUFS.
143 * EMUFS *fp emufs_crear("archivo", T3, 100, 100);
146 * En el ejemplo anterior se tiene que nuestro filesystem virtual se llamará
149 * Los últimos 2 parámetros serán ignorados si el tipo de archivo no utiliza
152 * \param filename Nombre del archivo virtual.
153 * \param tipo Tipo de archivo.
154 * \param tam_bloque Tamaño del bloque.
155 * \param tam_reg Tamaño del registro.
157 EMUFS *emufs_crear(const char *filename, EMUFS_Tipo tipo,EMUFS_BLOCK_SIZE tam_bloque, EMUFS_REG_SIZE tam_reg);
159 /** Abre un archivo EMUFS.
161 * Abre un archivo, determinando de que tipo se trata.
163 * \param filename Nombre del archivo virtual.
165 EMUFS *emufs_abrir(const char *filename);
167 /** Libera un archivo virtual */
168 int emufs_destruir(EMUFS *e);
170 /** mustra archivos auxiliares, para debug. */
171 int ver_archivo_FS(EMUFS *emu);
173 /** muestra estadisticas, para debug. */
174 int debug_ver_estadisticas(EMUFS *emu);
176 int emufs_agregar_indice(EMUFS *emu, char *nombre, INDICE_FUNCION funcion, INDICE_TIPO tipo, INDICE_TIPO_DATO tipo_dato, unsigned int offset, unsigned int tam_bloque);
178 INDICE_DATO *emufs_buscar_registros(EMUFS *emu, char *indice, char *data, int *cant);
180 INDICE *emufs_buscar_indice_por_nombre(EMUFS *emu, const char *nombre);
182 EMUFS_BLOCK_ID emufs_create_new_block(EMUFS *emu);
184 EMUFS_BLOCK_ID emufs_get_new_block_number(EMUFS *emu);
185 #endif /* _EMUFS_H_ */