X-Git-Url: https://git.llucax.com/z.facultad/75.06/emufs.git/blobdiff_plain/840e216ee1d0b23864f75f44ba549899669d9595..997a97b5e42afccbc75f2e2dde61f1e74856cb86:/emufs/emufs.h diff --git a/emufs/emufs.h b/emufs/emufs.h index c2dab18..f9f7b85 100644 --- a/emufs/emufs.h +++ b/emufs/emufs.h @@ -44,12 +44,7 @@ #include #include -#ifdef DEBUG - /** Imprime un mensaje de debug por pantalla. */ - #define PERR(msg) fprintf(stderr, "%s:%d> %s.\n",__FILE__, __LINE__, msg); -#else - #define PERR(msg) ; -#endif /* DEBUG */ +#include "indices.h" /** Tipo de archivo. */ typedef enum { @@ -82,16 +77,17 @@ typedef unsigned long EMUFS_OFFSET; */ #define EMUFS_NOT_FOUND -1ul -/** Estadisticas de archivo */ +/** Estadisticas de archivo. */ typedef struct _emufs_est_t { - unsigned long tam_archivo; /**< Cantidad de Registros en el archivo */ - unsigned long tam_archivo_bytes;/**< Size del archivo en bytes */ - unsigned long info_control;/**< Cantidad de bytes en info de control */ + unsigned long tam_archivo;/**< Tamaño en bytes del archivo .dat */ + unsigned long tam_archivos_aux;/**< Tamaño en bytes de los archivos auxiliares sumados */ + unsigned long tam_info_control_dat;/**< Cantidad de bytes en info de control del .dat */ unsigned long media_fs;/**< Media del espacio libre en el archivo de datos */ unsigned long total_fs;/**< Cantidad total de espacio libre en el archivo de datos */ unsigned long max_fs;/**< Cantidad de maxima libre (gap o fs en bloque) en el archivo de datos */ unsigned long min_fs;/**< Cantidad de minima libre (gap o fs en bloque) en el archivo de datos */ unsigned long cant_bloques; /**< Cantidad de bloques en el archivo de datos */ + unsigned long cant_registros; /**< Cantidad de Registros en el archivo */ } EMUFS_Estadisticas; /** Tipo Abstracto para menajo de archivos. @@ -112,20 +108,23 @@ typedef struct _emufs_est_t { * la necesidad de que el usuario tenga que hacer una selección previa del tipo * para llamar al método correspondiente a cada tipo de archivo. */ -typedef struct _emu_fs_t { +struct _emu_fs_t { EMUFS_Tipo tipo; EMUFS_BLOCK_SIZE tam_bloque; /**< Tamaño de bloque. 0 Si no tiene bloques */ EMUFS_REG_SIZE tam_reg; /**< Tamaño de registro. 0 Si son registros variables */ void* (*leer_bloque)(struct _emu_fs_t*, EMUFS_BLOCK_ID, int*); /**< Método para leer un bloque */ - void* (*leer_registro)(struct _emu_fs_t*, EMUFS_REG_ID, EMUFS_REG_SIZE*, int*); /**< Método para leer un registro */ + 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 */ + void* (*leer_registro)(struct _emu_fs_t*, CLAVE, EMUFS_REG_SIZE*, int*); /**< Método para leer un registro */ 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 */ EMUFS_REG_ID (*grabar_registro)(struct _emu_fs_t*, void*, EMUFS_REG_SIZE, int*); /**< Método para grabar un registro */ - EMUFS_REG_ID (*modificar_registro)(struct _emu_fs_t*, EMUFS_REG_ID, void*, EMUFS_REG_SIZE, int*); /**< Método para modificar un registro */ - int (*borrar_registro)(struct _emu_fs_t*, EMUFS_REG_ID); /**< Método para borrar un registro */ - EMUFS_Estadisticas (*leer_estadisticas)(struct _emu_fs_t *); - void (*compactar)(struct _emu_fs_t *); + EMUFS_REG_ID (*modificar_registro)(struct _emu_fs_t*, CLAVE k, void*, EMUFS_REG_SIZE, int*, INDICE_DATO); /**< Método para modificar un registro */ + int (*borrar_registro)(struct _emu_fs_t*, CLAVE, INDICE_DATO); /**< Método para borrar un registro */ + EMUFS_Estadisticas (*leer_estadisticas)(struct _emu_fs_t *); /**< Método para obtener estádisticas sobre el archivo */ + void (*compactar)(struct _emu_fs_t *); /**< Método para compactar el archivo reorganizándolo físicamente */ char *nombre; /**< Nombre del archivo */ -} EMUFS; + + INDICE *indices; +}; /** Crea un archivo auxiliar. */ int emufs_crear_archivo_auxiliar(const char*, const char*); @@ -168,6 +167,19 @@ EMUFS *emufs_abrir(const char *filename); /** Libera un archivo virtual */ int emufs_destruir(EMUFS *e); +/** mustra archivos auxiliares, para debug. */ int ver_archivo_FS(EMUFS *emu); +/** muestra estadisticas, para debug. */ +int debug_ver_estadisticas(EMUFS *emu); + +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); + +INDICE_DATO *emufs_buscar_registros(EMUFS *emu, char *indice, char *data, int *cant); + +INDICE *emufs_buscar_indice_por_nombre(EMUFS *emu, const char *nombre); + +EMUFS_BLOCK_ID emufs_create_new_block(EMUFS *emu); + +EMUFS_BLOCK_ID emufs_get_new_block_number(EMUFS *emu); #endif /* _EMUFS_H_ */