* \param err Indicador de error en la operacion.
* \return \b void* Buffer con el registro leido.
*/
-void *emufs_tipo2_leer_registro(EMUFS* efs, EMUFS_REG_ID id_reg, EMUFS_REG_SIZE* reg_size, int *err);
+void *emufs_tipo2_leer_registro(EMUFS* efs, CLAVE clave, EMUFS_REG_SIZE* reg_size, int *err);
/** Realiza la escritura de un registro en archivos del tipo 2 en base a su \em ID, devolviendo ademas el \em Size del
* registro leido.
* \param id_reg Id del registro que se quiere eliminar.
* \return \b int Indicador de exito de la operacion.
*/
-int emufs_tipo2_borrar_registro(EMUFS *efs, EMUFS_REG_ID id_reg);
+int emufs_tipo2_borrar_registro(EMUFS *efs, CLAVE k);
/** Devuelve el \em Size de un registro dado, en base a su \em ID.
*
*/
EMUFS_Estadisticas emufs_tipo2_leer_estadisticas(EMUFS *efs);
-/** Método para recompactar un archivo tipo 2
+/** Método para compactar un archivo tipo 2
*
* \param efs Estructura que realiza el handling de archivos de cualquier tipo.
- * \return \b int Indicador de exito de la opracion.
*/
-int emufs_tipo2_recompactar(EMUFS *efs);
+void emufs_tipo2_compactar(EMUFS *efs);
+
+/** Método para mover datos de un source a un dest, de a chunks
+ *
+ * \param datfile Stream en el cual se esta haciendo el movimiento.
+ * \param source Source desde donde mover los datos.
+ * \param destination Destino hacia donde mover los datos.
+ * \param mustmove_bytes Cantidad de bytes a mover.
+ */
void emufs_tipo2_movedata(FILE * datfile,EMUFS_OFFSET *source, EMUFS_OFFSET *destination, EMUFS_BLOCK_SIZE mustmove_bytes);
+/** Método para sincronizar / actualiza un indice luego de una recompactacion
+ *
+ * \param efs Estructura que realiza el handling de archivos de cualquier tipo.
+ * \return \b int Indicador de exito de la opracion.
+ */
+int emufs_tipo2_updateidx(EMUFS *efs);
+
+/** Método para leer un registro con todo su bloque asociado. */
+void* emufs_tipo2_leer_registro_raw(EMUFS *emu, EMUFS_REG_ID id, EMUFS_REG_SIZE *size, int *pos);
+
#endif /* _EMUFS_TIPO2_H_ */