]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/idx.h
Se vuelve a agregar el comentario que volo por error al sacar el TODO :)
[z.facultad/75.06/emufs.git] / emufs / idx.h
index 7999f064f55c8fd1a5254277cffa6d8ab2a37fd9..cd2c3e3ec8a008a2cbe0e65dce4701ac24458d0d 100644 (file)
 #define EMUFS_IDX_EXT ".idx"
 
 typedef struct emufs_idx_t {
 #define EMUFS_IDX_EXT ".idx"
 
 typedef struct emufs_idx_t {
-       int block;
-       long int id_reg;
+       EMUFS_REG_ID id_reg;
+       EMUFS_BLOCK_ID location;
 } EMUFS_IDX;
 
 FILE* emufs_idx_abrir(EMUFS*, const char*);
 
 int emufs_idx_crear(EMUFS*);
 
 } EMUFS_IDX;
 
 FILE* emufs_idx_abrir(EMUFS*, const char*);
 
 int emufs_idx_crear(EMUFS*);
 
-EMUFS_REG_ID emufs_idx_buscar_mayor_id(EMUFS *);
+EMUFS_REG_ID emufs_idx_buscar_mayor_id_libre(EMUFS*, int*);
 
 
-EMUFS_BLOCK_ID emufs_idx_buscar_registro(EMUFS *, EMUFS_REG_ID);
+EMUFS_BLOCK_ID emufs_idx_buscar_registro(EMUFS*, EMUFS_REG_ID);
 
 
-int emufs_idx_agregar(EMUFS *, EMUFS_BLOCK_ID, EMUFS_REG_ID);
+int emufs_idx_agregar(EMUFS*, EMUFS_BLOCK_ID, EMUFS_REG_ID);
 
 
-int emufs_idx_borrar(EMUFS *emu, EMUFS_REG_ID);
+int emufs_idx_borrar(EMUFS*, EMUFS_REG_ID);
+
+/** Retorna un array con los Ids validos del archivo IDX
+ *
+ *  EL ARRAY DEBE SER LIBERADO!
+ *  \param emu EMUFS
+ *  \param cant Puntero donde guardar la cantidad de items
+ */
+EMUFS_REG_ID *emufs_idx_get(EMUFS *emu, EMUFS_REG_ID *cant);
+
+EMUFS_REG_ID emufs_idx_get_new_id(EMUFS*, int*);
+
+int emufs_idx_existe_id(EMUFS *emu, int ID);
+
+int emufs_idx_actualizar(EMUFS *emu, int ID, EMUFS_BLOCK_ID bloque);
+
+/** Obtiene el tamaño del archivo de índice. */
+long emufs_idx_get_file_size(EMUFS*, int*);
 
 #endif /* _EMUFS_IDX_H */
 
 #endif /* _EMUFS_IDX_H */