]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/fsc.h
Empiezo a implementar el B*, por ahora en un archivo aparte para
[z.facultad/75.06/emufs.git] / emufs / fsc.h
index 6e10be16a553380a47903a2b8a9385eff07f148f..08cf1e6bc70ae1b112756ac4aae5174d37266a13 100644 (file)
@@ -43,8 +43,8 @@
 #define EMUFS_FSC_EXT ".fsc"
 
 typedef struct emufs_fsc_t {
-       unsigned long int marker;
-       unsigned long int freespace;
+       EMUFS_BLOCK_ID marker;
+       EMUFS_FREE freespace;
 } EMUFS_FSC;
 
 /** Crea un archivo de Gaps o Espacio Libre en Bloque */
@@ -65,11 +65,25 @@ int emufs_fsc_actualizar_gap(EMUFS *emu, EMUFS_OFFSET off, EMUFS_FREE fs);
 /** Actualiza un registro de espacio libre de acorde al FType */
 int emufs_fsc_actualizar(EMUFS *emu, EMUFS_BLOCK_ID block, EMUFS_FREE fs);
 
-/** Me devuelve el ID del bloque u Offset del Gap donde quepa un registro, 
-  * y guarda en \param n_freespace el espacio libre actualizado 
-  */
+/** Busca un bloque o gap en donde quepa un registro.
+ *
+ * Si encuentra el lugar buscado, devuelve en \c freespace el espacio libre en
+ * ese bloque o gap.
+ */
 EMUFS_BLOCK_ID emufs_fsc_buscar_lugar(EMUFS *emu, EMUFS_FREE reg_size, EMUFS_FREE *n_freespace);
 
+/** Busca una una serie de bloques consecutivos con espacio libre.
+ *
+ * De encontrarlo devuelve el identificador del primer bloque de la serie y el
+ * espacio libre en él.
+ *
+ * \note Considera el fin de archivo como espacio libre. Es decir, si buscamos 3
+ *       bloques libres y encuentra uno al final del archivo, lo devuelve porque
+ *       asume que podemos seguir agregando bloques al final.
+ */
+EMUFS_BLOCK_ID emufs_fsc_buscar_n_lugares(EMUFS*, size_t, EMUFS_FREE,
+               EMUFS_FREE*, int*);
+
 /** Devuelve el espacio libre de un Bloque o Gap dado */
 EMUFS_FREE emufs_fsc_get_fs(EMUFS *emu, EMUFS_BLOCK_ID block);
 
@@ -83,8 +97,15 @@ EMUFS_FREE emufs_fsc_get_media_fs(EMUFS *emu);
 int emufs_fsc_get_max_min_fs(EMUFS *emu, EMUFS_FREE *min, EMUFS_FREE *max);
 
 /** Trunca el archivo hasta el bloque \param block*/
-int emufs_fsc_truncate(EMUFS *emu, EMUFS_BLOCK_ID block);
+int emufs_fsc_truncate(EMUFS*, EMUFS_BLOCK_ID);
 
 /** Devuelve la cantidad de bloques vacios en el archivo*/
-int emufs_fsc_get_cant_bloques_vacios(EMUFS *emu);
+EMUFS_BLOCK_ID emufs_fsc_get_cant_bloques_vacios(EMUFS*);
+
+/** Devuelve la cantidad de bloques (o gaps) que tiene un archivo. */
+EMUFS_BLOCK_ID emufs_fsc_get_num_blocks(EMUFS*);
+
+/** Obtiene el tamaño del archivo de espacios libres. */
+long emufs_fsc_get_file_size(EMUFS*, int*);
+
 #endif /* _EMUFS_FSC_H */