]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/tipo1.h
Se agrega una razon más para elegir algoritmo de external sort.
[z.facultad/75.06/emufs.git] / emufs / tipo1.h
index 9ebb2dacd58ec55e0ba05bd33b5121f94ad85a28..4e4deb32be910ad45485bdd01921f11c97be9593 100644 (file)
@@ -39,7 +39,7 @@
 #define _EMUFS_TIPO1_H_
 
 #include "emufs.h"
 #define _EMUFS_TIPO1_H_
 
 #include "emufs.h"
-#include "b_plus.h"
+#include "indice_bplus.h"
 
 /** Inicializa un EMUFS para poder ser utilizado como un archivo tipo1.
  *
 
 /** Inicializa un EMUFS para poder ser utilizado como un archivo tipo1.
  *
@@ -48,6 +48,8 @@
  */
 int emufs_tipo1_inicializar(EMUFS* efs);
 
  */
 int emufs_tipo1_inicializar(EMUFS* efs);
 
+int emufs_tipo4_inicializar(EMUFS* efs);
+
 /** Lee el registro \c reg_id y devolviendo su contenido. */
 void* emufs_tipo1_leer_registro(EMUFS*, CLAVE, EMUFS_REG_SIZE*, int*);
 
 /** Lee el registro \c reg_id y devolviendo su contenido. */
 void* emufs_tipo1_leer_registro(EMUFS*, CLAVE, EMUFS_REG_SIZE*, int*);
 
@@ -55,10 +57,10 @@ void* emufs_tipo1_leer_registro(EMUFS*, CLAVE, EMUFS_REG_SIZE*, int*);
 EMUFS_REG_ID emufs_tipo1_grabar_registro(EMUFS*, void*, EMUFS_REG_SIZE, int*);
 
 /** Borra un registro de del archivo. */
 EMUFS_REG_ID emufs_tipo1_grabar_registro(EMUFS*, void*, EMUFS_REG_SIZE, int*);
 
 /** Borra un registro de del archivo. */
-int emufs_tipo1_borrar_registro(EMUFS*, CLAVE);
+int emufs_tipo1_borrar_registro(EMUFS*, CLAVE, INDICE_DATO);
 
 /** Método para modificar un registro. */
 
 /** Método para modificar un registro. */
-EMUFS_REG_ID emufs_tipo1_modificar_registro(EMUFS *emu, CLAVE k, void*, EMUFS_REG_SIZE, int*);
+EMUFS_REG_ID emufs_tipo1_modificar_registro(EMUFS *emu, CLAVE k, void*, EMUFS_REG_SIZE, int*, INDICE_DATO);
 
 /** 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);
 
 /** 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);
@@ -73,6 +75,16 @@ void emufs_tipo1_compactar(EMUFS*);
 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);
 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);
+               
+/** Inserta un registro en el archivo, ordenado por clave principal*/
+EMUFS_REG_ID emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, int *err);
+
+/** Elimina un registro de clave CLAVE del archivo con ayuda del arbol B+*/
+int emufs_tipo1_eliminar_ordenado(EMUFS *emu, CLAVE clave, INDICE_DATO dato);
+
+void *emufs_tipo1_leer_registro_plus(EMUFS *emu, CLAVE clave, EMUFS_REG_SIZE *size, int *err);
+
+EMUFS_REG_ID emufs_tipo1_modificar_registro_plus(EMUFS *emu, CLAVE k, void*, EMUFS_REG_SIZE, int*, INDICE_DATO);
 
 
-int emufs_tipo1_insertar_ordenado(EMUFS *emu, void *ptr, EMUFS_REG_SIZE size, int *err);
+B_PLUS_KEYBUCKET *emufs_tipo1_obtener_claves_raw(EMUFS *emu, int num_bloque);
 #endif /* _EMUFS_TIPO1_H_ */
 #endif /* _EMUFS_TIPO1_H_ */