- /*cargo el bloque en "bloque"*/
- if (!(bloque = emufs_tipo3_leer_bloque(emu, num_bloque, err))) {
- /* TODO Manejo de errores */
- PERR("no se pudo leer el bloque");
- return -1;
- }
- /*El error puede haberse producido porque la funcion leer_bloque devolvio -1, el cual es un bloque invalido*/
- /*insertar el registro en el bloque*/
- /*tengo que buscar un ID valido para el nuevo registro*/
- ID_aux = emufs_idx_get_new_id(emu, err);
- /*grabo el id en el bloque*/
- memcpy(bloque+emu->tam_bloque-fs,&ID_aux,sizeof(EMUFS_REG_ID));
- /*grabo el registro en el bloque*/
- memcpy(bloque+emu->tam_bloque-fs+sizeof(EMUFS_REG_ID),ptr,emu->tam_reg);
- if ( emufs_tipo3_grabar_bloque(emu, bloque, num_bloque) != 0) {
- PERR("error al grabar bloque");
- return -1; /* se produjo un error */
- }
- /*actualizo el archivo de espacios libres*/
- if ( emufs_fsc_actualizar(emu, num_bloque, fs - emu->tam_reg - sizeof(EMUFS_REG_ID)) != 0 ){
- free(bloque);
- return -1;
- }
- /*actualizo el archivo de bloques y registros*/
- if ( emufs_idx_agregar(emu, ID_aux, num_bloque) != 0 ){
- free(bloque);
- return -1;
+ for (i=0; i<cant_bloques; i++){
+ /*cargo el bloque en "bloque"*/
+ if (!(bloque = emufs_tipo3_leer_bloque(emu, num_bloque+i, err))) {
+ /* TODO Manejo de errores */
+ PERR("no se pudo leer el bloque");
+ return -1;
+ }
+ /*El error puede haberse producido porque la funcion leer_bloque devolvio -1, el cual es un bloque invalido*/
+ /*insertar el registro en el bloque*/
+ /*tengo que buscar un ID valido para el nuevo registro*/
+ ID_aux = emufs_idx_get_new_id(emu, err);
+ /*grabo el id en el bloque*/
+ /*veo el espacio libre que queda*/
+ fs = emufs_fsc_get_fs(emu, num_bloque+i);
+ printf("el espacio libre del bloque %d es: %d\n", num_bloque+i, fs);
+ if (emu->tam_bloque-sizeof(EMUFS_REG_ID) < emu->tam_reg)
+ memcpy(bloque+sizeof(EMUFS_REG_ID),&ID_aux,sizeof(EMUFS_REG_ID));
+ else
+ memcpy(bloque+emu->tam_bloque-fs,&ID_aux,sizeof(EMUFS_REG_ID));
+ /*grabo el registro en el bloque*/
+ if ( cant_bloques == 1 ){
+ memcpy(bloque+emu->tam_bloque-fs+sizeof(EMUFS_REG_ID),ptr,emu->tam_reg);
+ } else {
+ if ( cant_bloques-1 == i )
+ resto = emu->tam_reg - i*(emu->tam_bloque - sizeof(EMUFS_REG_ID));
+ memcpy(bloque+sizeof(EMUFS_REG_ID),((char*)ptr)+i*(emu->tam_bloque-sizeof(EMUFS_REG_ID)),resto);
+ }
+
+ /*grabo el bloque en el archivo*/
+ if ( emufs_tipo3_grabar_bloque(emu, bloque, num_bloque+i) != 0) {
+ PERR("error al grabar bloque");
+ return -1; /* se produjo un error */
+ }
+
+ /*actualizo el archivo de espacios libres*/
+ if ( emu->tam_bloque-sizeof(EMUFS_REG_ID) > emu->tam_reg ){
+ resto = emu->tam_reg;
+ if ( emufs_fsc_agregar(emu, num_bloque, fs - resto - sizeof(EMUFS_REG_ID) ) != 0 ) {
+ fclose(file);
+ if (bloque != NULL) free(bloque);
+ return -1;
+ }
+ /*agrego al idx*/
+ if ( emufs_idx_agregar(emu, ID_aux, num_bloque) != 0 ){
+ if (bloque != NULL) free(bloque);
+ return -1;
+ }
+ } else {
+ if ( cant_bloques-1 == i )
+ resto = emu->tam_reg - i*(emu->tam_bloque - sizeof(EMUFS_REG_ID));
+ fs = emufs_fsc_get_fs(emu,num_bloque+i);
+ if ( emufs_fsc_agregar(emu, num_bloque+i, fs-resto) !=0 ){
+ fclose(file);
+ if (bloque != NULL) free(bloque);
+ return -1;
+ }
+ /*actualizo el archivo de bloques y registros*/
+ if (i == 0) {
+ /* Tengo que agregar el primer bloque en IDX */
+ if( emufs_idx_agregar(emu, ID_aux, num_bloque) != 0 ){
+ if (bloque != NULL) free(bloque);
+ return -1;
+ }
+ }
+ }