PERR("GRABO ORDENADO");
grabar_ordenado_en_bloque(emu, ptr, size, bloque, query.num_bloque, fs, err);
/*en teoria el nuevo registro no debe cambiar el ancla, por lo cual no actualizo el arbol*/
+ free(bloque);
return 0;
/*aca va lo que saque*/
} else { /* el registro no entra en el bloque, hay que crear uno nuevo y desparramar */
+ PERR(" COMO NO ENTRA DEBO DIVIDIR LOS REGISTROS EN 2 BLOQUES");
new_bloque = (char*)malloc(emu->tam_bloque);
move_size=0;
for(i=0; i<cant_reg/2; i++){ /*copio mitad aca y mitad en el nuevo*/
aux += sizeof(EMUFS_TIPO1_REG_HEADER)+tam_reg;
move_size += sizeof(EMUFS_TIPO1_REG_HEADER)+tam_reg;
}
+ PERR("ME MOVI LA MITAD DE LOS REGISTROS");
/*copio el resto del bloque al nuevo bloque*/
memcpy(new_bloque, aux, emu->tam_bloque-move_size);
/*borro lo que sobra en el bloque original, guardando el footer*/
memset(aux, 0, emu->tam_bloque - move_size - sizeof(int));
/*actualizo la cant de registros (footer)*/
memcpy(bloque+emu->tam_bloque-sizeof(int), &i, sizeof(int));
+ PERR("PASE");
/*grabo el bloque original*/
emufs_tipo1_grabar_bloque_fsc(emu, bloque, num_bloque, EMUFS_NOT_FOUND, err);
+ PERR("GRABE EL BLOQUE 1 de 2");
/*actualizo el footer del nuevo bloque*/
dif = cant_reg - i; /*por las dudas*/
memcpy(new_bloque+emu->tam_bloque, &dif, sizeof(int));
/*cargo el header*/
header.id = emufs_idx_get_new_id(emu, err);
header.size = size;
- cant_reg++; /*voy a poner un reg mas*/
new_bloque = (char*)malloc(emu->tam_bloque);
aux = new_bloque;
for (i=0; i<cant_reg+1; i++){
}
/*grabo el bloque en el archivo*/
new_bloque = aux; /*apunto al principio del bloque*/
+ cant_reg++; /*voy a poner un reg mas*/
memcpy(new_bloque+emu->tam_bloque-sizeof(int), &cant_reg, sizeof(int));
emufs_tipo1_grabar_bloque_fsc(emu, new_bloque, num_bloque, EMUFS_NOT_FOUND, err);
clave = emufs_indice_generar_clave(emu->indices, new_bloque+sizeof(EMUFS_TIPO1_REG_HEADER));