#include "did.h"
#include "idx.h"
#include "fsc.h"
+#include "b_plus.h"
/** Devuelve un puntero con la memoria reservada que contiene al registro solicitado
* por el segundo parámetro \c ID, y almacena en \c reg_size el tamaño del
* \param reg_size tamaño del registro.
* \param err Codigo de error devuelto en caso de falla.
*/
-void* emufs_tipo3_leer_registro(EMUFS *emu, EMUFS_REG_ID ID, EMUFS_REG_SIZE* reg_size, int* err);
+void* emufs_tipo3_leer_registro(EMUFS *emu, CLAVE clave, EMUFS_REG_SIZE* reg_size, int* err);
/** Devuelve un puntero con la memoria reservada que contiene el bloque solicitado por
* el segundo parámetro \c num_bloque. Como la numeración de los bloques es virtual,
* \param ptr Cadena de datos que contiene el registro a grabar.
* \param err Codigo de error devuelto en caso de falla.
*/
-EMUFS_REG_ID emufs_tipo3_grabar_registro(EMUFS *emu, void *ptr, EMUFS_REG_SIZE, int *err);
+EMUFS_REG_ID emufs_tipo3_grabar_registro(EMUFS *emu, void *ptr, EMUFS_REG_SIZE reg_size, int *err);
/** Graba el bloque apuntado por \c ptr en el archivo
* \param emu Esructura para manejar los archivos.
* \param emu Esructura para manejar los archivos.
* \param id_reg Id del registro a borrar.
*/
-int emufs_tipo3_borrar_registro(EMUFS *emu, EMUFS_REG_ID id_reg);
+int emufs_tipo3_borrar_registro(EMUFS *emu, CLAVE k);
/** Método para modificar un registro
* \param emu Esructura para manejar los archivos.
* \param ptr Cadena de datos que contiene el nuevo registro.
* \param err Codigo de error devuelto en caso de falla.
*/
-EMUFS_REG_ID emufs_tipo3_modificar_registro(EMUFS *emu, EMUFS_REG_ID reg_id, void *ptr, EMUFS_REG_SIZE, int*err);
+EMUFS_REG_ID emufs_tipo3_modificar_registro(EMUFS *emu, CLAVE k, void *ptr, EMUFS_REG_SIZE, int*err);
/** Completa una estructura del tipo EMUFS_Estadisticas con las estadísticas del
* archivo de datos, espacio libre total, cantidad de registros, cantidad de bloques,
*/
void emufs_tipo3_leer_bloque_raw(EMUFS *emu, EMUFS_BLOCK_ID block_id, char **actual, char **anterior, char **siguiente, EMUFS_BLOCK_SIZE *size1, EMUFS_BLOCK_SIZE *size2, EMUFS_BLOCK_SIZE *size3);
+/** Inserta un registro ordenado segun el Arbol B+ lo indique
+ * \param emu Esructura para manejar los archivos.
+ * \param ptr Cadena de datos contenedora del registro.
+ * \param clave Clave de ordenamiento.
+ * \param offset Distancia en bytes hasta la clave.
+ * \param num_bloque Numero de bloque donde se insertara el registro.
+ */
+int emufs_tipo3_insertar_ordenado(EMUFS *emu, void *ptr, CLAVE clave, int offset, EMUFS_BLOCK_ID num_bloque, int *err);
+
#endif /* _EMUFS_TIPO3_H_ */