if ( emu->tam_bloque-sizeof(EMUFS_REG_ID) < emu->tam_reg ){
/*Si el registro ocupa mas de un bloque (original) resto = emu->tam_bloque-sizeof(EMUFS_REG_ID)*/
resto += sizeof(EMUFS_REG_ID);
- /*resto = emu->tam_reg - i*(emu->tam_bloque - sizeof(EMUFS_REG_ID)) + sizeof(EMUFS_REG_ID);*/
if ( cant_bloques-1 == i )
resto = emu->tam_reg - i*(emu->tam_bloque - sizeof(EMUFS_REG_ID))+sizeof(EMUFS_REG_ID);
- /*printf("fs-resto = %d\n", fs-resto);*/
if ( emufs_fsc_agregar(emu, num_bloque+i, fs-resto) !=0 ){
fclose(file);
if (bloque) free(bloque);
break;/*ya borre, corto aca*/
}
iter += tam_reg+sizeof(EMUFS_REG_ID);
- aux += iter;
+ aux += tam_reg+sizeof(EMUFS_REG_ID);
}
-
/*reacomodo el bloque */
- memcpy(bloque+iter-tam_reg-sizeof(EMUFS_REG_ID), aux+iter, emu->tam_bloque-iter-sizeof(int));
+ memcpy(aux, aux+tam_reg+sizeof(EMUFS_REG_ID), emu->tam_bloque-iter-sizeof(int));
/*le vuelvo a copiar la cantidad de registros*/
cant_reg--;
memcpy(bloque+emu->tam_bloque-sizeof(int), &cant_reg, sizeof(int));
/*grabo el bloque en el archivo*/
- if ( emufs_tipo3_grabar_bloque(emu, bloque, query.num_bloque) == EMUFS_NOT_FOUND ){
+ if ( emufs_tipo3_grabar_bloque(emu, bloque, query.num_bloque) == -1){
PERR("NO SE PUDO GRABAR EL BLOQUE");
+ free(bloque);
return -1;
}
free(bloque);
return 0;
}
+
+void *emufs_tipo3_leer_registro_plus(EMUFS *emu, CLAVE clave, EMUFS_REG_SIZE *size, int *err)
+{
+ CLAVE clave_ajena;
+ char *reg;
+ char *bloque, *aux;
+ INDEX_DAT query;
+ int result, cant_reg, i;
+ EMUFS_REG_SIZE tam_reg;
+
+ tam_reg = emu->tam_reg;
+ /*cargo el query*/
+ query.clave = clave;
+ query.num_bloque = 0;
+ /*hago la consulta*/
+
+ result = emufs_b_plus_get_bloque(emu->indices, &query, 0);
+
+ if (result == -1){
+ PERR("NO EXISTE EL BLOQUE");
+ return NULL;
+ }
+ if (result == 1){
+ PERR("SE PRODUJO UN ERROR EN EL ARBOL");
+ return NULL;
+ }
+ /*leo el bloque*/
+ bloque = emufs_tipo3_leer_bloque(emu, query.num_bloque, err);
+ /*busco el registro en el bloque*/
+ /*copio la cantidad de registros*/
+ memcpy(&cant_reg, bloque+emu->tam_bloque-sizeof(int), sizeof(int));
+ aux = bloque;
+ for (i=0; i<cant_reg; i++){
+ /*leo la clave*/
+ clave_ajena = emufs_indice_generar_clave(emu->indices, aux+sizeof(EMUFS_REG_ID));
+ if ( emufs_indice_es_igual(emu->indices, clave, clave_ajena) ){
+ reg = (char*)malloc(tam_reg);
+ if (reg == NULL){
+ PERR("NO SE PUDO CARGAR EL REGISTRO");
+ *err = -1;
+ free(bloque);
+ return -1;
+ }
+ /*copio el registro*/
+ memcpy(reg, aux+sizeof(EMUFS_REG_ID), tam_reg);
+ *size = tam_reg;
+ break; /*ya lo encontre, corto el for*/
+ }
+ aux += tam_reg+sizeof(EMUFS_REG_ID); /*paso al proximo*/
+ }
+ free(bloque);
+ return reg;
+}