]> git.llucax.com Git - z.facultad/75.06/emufs.git/blobdiff - emufs/idx.c
Fixed mezcla de data types utilizando los nuevos tipos definidos por Luca - by Bugo
[z.facultad/75.06/emufs.git] / emufs / idx.c
index 56fa4fca3b0bb787b65c2d1eb3ecdb0f088d7f37..29e021db8664c7f9c0864caf4a68828560bbd502 100644 (file)
@@ -38,6 +38,7 @@
 #include "idx.h"
 #include <stdlib.h>
 #include <strings.h>
+#include <unistd.h>
 
 FILE* emufs_idx_abrir(EMUFS* efs, const char* mode)
 {
@@ -62,7 +63,7 @@ int emufs_idx_crear(EMUFS *efs)
        return emufs_crear_archivo_auxiliar(efs->nombre, EMUFS_IDX_EXT);
 }
 
-int emufs_idx_buscar_mayor_id(EMUFS *emu)
+EMUFS_REG_ID emufs_idx_buscar_mayor_id(EMUFS *emu)
 {
        int id, max = -1;
        FILE *f_idx;    
@@ -87,7 +88,7 @@ int emufs_idx_buscar_mayor_id(EMUFS *emu)
 }
 
 /*busca el registro ID en el archivo ".idx" y devuelve el nro de bloque en el que se encuentra*/
-int emufs_idx_buscar_registro(EMUFS *emu, int ID)
+EMUFS_BLOCK_ID emufs_idx_buscar_registro(EMUFS *emu, EMUFS_REG_ID ID)
 {
        FILE* f_idx;
        EMUFS_IDX reg;
@@ -110,7 +111,7 @@ int emufs_idx_buscar_registro(EMUFS *emu, int ID)
 }
 
 /* agrega un registro al final del archivo */
-int emufs_idx_agregar(EMUFS *emu, int num_bloque, int ID_aux)
+int emufs_idx_agregar(EMUFS *emu, EMUFS_BLOCK_ID num_bloque, EMUFS_REG_ID id)
 {
        FILE *f_idx;
        EMUFS_IDX reg;
@@ -122,13 +123,13 @@ int emufs_idx_agregar(EMUFS *emu, int num_bloque, int ID_aux)
        if ( (f_idx = fopen(name_f_idx,"a+"))==NULL ) return -1;
                
        reg.block = num_bloque;
-       reg.id_reg = ID_aux;
+       reg.id_reg = id;
        fwrite(&reg,sizeof(EMUFS_IDX),1,f_idx); 
        fclose(f_idx);
        return 0;
 }
 
-int emufs_idx_borrar(EMUFS *emu, int ID)
+int emufs_idx_borrar(EMUFS *emu, EMUFS_REG_ID ID)
 {
        FILE *f_idx;
        EMUFS_IDX reg, buffer;
@@ -153,11 +154,11 @@ int emufs_idx_borrar(EMUFS *emu, int ID)
        printf("ACTUAL = %ld\n", actual/sizeof(EMUFS_IDX));
        fseek(f_idx, 0, SEEK_END); /* me voy al final */
        final = ftell(f_idx); /* veo cuando ocupa el archivo */
-       printf("tamanio del archivo de bloques y registros = %d\n", final/sizeof(EMUFS_IDX));
+       printf("tamanio del archivo de bloques y registros = %ld\n", final/sizeof(EMUFS_IDX));
        fseek(f_idx, actual, SEEK_SET); /* vuelvo al lugar desde donde quiero justificar */
        
        cant = (final-actual)/sizeof(EMUFS_IDX);
-       printf("cant = %d\n", cant);
+       printf("cant = %ld\n", cant);
        for(i=0; i<cant-1; i++) {
                   /* Calculo donde empieza el proximo elemento a mover */
                   final = actual+sizeof(EMUFS_IDX); printf("final = %ld actual =  %ld\n", final/sizeof(EMUFS_IDX), actual/sizeof(EMUFS_IDX));
@@ -174,7 +175,7 @@ int emufs_idx_borrar(EMUFS *emu, int ID)
        }
        fseek (f_idx,0,SEEK_END);
        tam = ftell(f_idx);
-       printf("tamanio del archivo de bloques y registros = %d\n", tam/sizeof(EMUFS_IDX) - 1);
+       printf("tamanio del archivo de bloques y registros = %ld\n", tam/sizeof(EMUFS_IDX) - 1);
        fclose(f_idx);
        truncate(name_f_idx, tam - sizeof(EMUFS_IDX));
        return 0;