+ EMUFS_REG_ID reg_id;
+ EMUFS_FREE fs;
+ EMUFS_BLOCK_ID block_id;
+ char name_f[255];
+ char* block;
+
+ strcpy(name_f,efs->nombre);
+ strcat(name_f,".dat");
+
+ /* me devuelve el ID del bloque donde quepa un registro y el espacio libre en "fs"*/
+ block_id = emufs_fsc_buscar_lugar(efs, reg_size, &fs);
+ /* si no hay bloques con suficiente espacio creo un bloque nuevo */
+ if (block_id == EMUFS_NOT_FOUND) {
+ /* crear un nuevo bloque en memoria */
+ block = (char*) malloc(efs->tam_bloque);
+ if (block == NULL) {
+ /* TODO Manejo de errores */
+ PERR("No hay memoria");
+ *err = 2; /* EMUFS_ERROR_OUT_OF_MEMORY */
+ return EMUFS_NOT_FOUND;
+ }
+ /* graba el registro al principio del bloque */
+ reg_id = emufs_tipo1_get_id(efs);
+ /* graba registro en bloque */
+ emufs_tipo1_escribir_reg_en_memoria(block, reg_id, reg_size, reg);
+ /* graba el bloque en el archivo */
+ block_id = emufs_tipo1_grabar_bloque(efs, block, block_id, err);
+ if (*err) {
+ PERR("error al grabar bloque");
+ free(block);
+ return EMUFS_NOT_FOUND;
+ }
+ free(block);
+ /* grabo el nuevo registro en el archivo de espacios libres */
+ *err = emufs_fsc_agregar(efs, block_id, efs->tam_bloque - reg_size
+ - sizeof(EMUFS_REG_ID) - sizeof(EMUFS_REG_SIZE));
+ if (*err) {
+ PERR("No se pudo agregar fsc");
+ return EMUFS_NOT_FOUND;
+ }
+
+ /* Encontró espacio en un bloque existente, graba registro ahí */
+ } else {
+ /* cargo el bloque en block_id */
+ if (!(block = (char*) emufs_tipo1_leer_bloque(efs, block_id, err))) {
+ /* TODO Manejo de errores */
+ PERR("no se pudo leer el bloque");
+ return EMUFS_NOT_FOUND;
+ }
+ /* inserta el registro en el bloque */
+ /* tengo que buscar un ID válido para el nuevo registro */
+ reg_id = emufs_tipo1_get_id(efs);
+ /* graba registro en bloque */
+ emufs_tipo1_escribir_reg_en_memoria(block + efs->tam_bloque - fs,
+ reg_id, reg_size, reg);
+ /* graba el bloque en el archivo */
+ block_id = emufs_tipo1_grabar_bloque(efs, block, block_id, err);
+ if (*err) {
+ PERR("error al grabar bloque");
+ free(block);
+ return EMUFS_NOT_FOUND;
+ }
+ free(block);
+ /* actualizo el archivo de espacios libres */
+ *err = emufs_fsc_actualizar(efs, block_id, fs - reg_size
+ - sizeof(EMUFS_REG_ID) - sizeof(EMUFS_REG_SIZE));
+ if (*err) {
+ PERR("No se pudo actualizar fsc");
+ return EMUFS_NOT_FOUND;
+ }
+ }
+
+ /* actualizo el indice de bloques y registros */
+ *err = emufs_idx_agregar(efs, block_id, reg_id);
+ if (*err){
+ PERR("No se pudo agregar idx");
+ return EMUFS_NOT_FOUND;
+ }
+
+ return reg_id;
+}
+
+/*Graba un bloque en el archivo*/
+EMUFS_BLOCK_ID emufs_tipo1_grabar_bloque(EMUFS *efs, void *block,
+ EMUFS_BLOCK_ID block_id, int* err)
+{
+ FILE* file;
+ char name_f[255];
+
+ strcpy(name_f,efs->nombre);
+ strcat(name_f,".dat");
+
+ if ((file = fopen(name_f, "r+b")) == NULL) {
+ /* TODO Manejo de errores */
+ PERR("Error al abrir archivo");
+ *err = 4; /* EMUFS_ERROR_CANT_OPEN_FILE */
+ return EMUFS_NOT_FOUND;
+ }
+ /* Si es NOT_FOUND tengo que agregar un bloque al final del archivo */
+ if (block_id == EMUFS_NOT_FOUND) {
+ /* me paro al final del archivo */
+ if (fseek(file, 0l, SEEK_END)) {
+ /* TODO Manejo de errores */
+ PERR("No se pudo hacer fseek()");
+ fclose(file);
+ *err = 8; /* EMUFS_ERROR_SEEK_FILE */
+ return EMUFS_NOT_FOUND;
+ }
+ /* Obtengo ID del bloque nuevo */
+ block_id = (ftell(file) - emufs_tipo1_header_size()) / efs->tam_bloque;
+ /* Si es un ID válido, salto hasta ese bloque. */
+ } else {
+ /* Salta el header del archivo */
+ if ((*err = emufs_tipo1_header_jump(file))) {
+ PERR("no se pudo saltar la cabecera del archivo");
+ fclose(file);
+ return EMUFS_NOT_FOUND;
+ }
+ /* Salta bloques */
+ if ((*err = emufs_tipo1_block_jump(efs, file, block_id))) {
+ PERR("no se pudo saltar la cabecera del bloque");
+ fclose(file);
+ return EMUFS_NOT_FOUND;
+ }
+ }
+ /* Grabo el bloque */
+ if (fwrite(block, efs->tam_bloque, 1, file) != 1) {
+ PERR("No se pudo escribir el archivo");
+ fclose(file);
+ *err = 6; /* EMUFS_ERROR_WRITE_FILE */
+ return EMUFS_NOT_FOUND;
+ }
+
+ fclose(file);
+ return block_id;