]> git.llucax.com Git - z.facultad/75.06/emufs.git/blob - emufs/idx.c
Faltan reemplazar un par de llamadas e implementar un par de funciones mas, pero...
[z.facultad/75.06/emufs.git] / emufs / idx.c
1 /* vim: set noexpandtab tabstop=4 shiftwidth=4:
2  *----------------------------------------------------------------------------
3  *                                  emufs
4  *----------------------------------------------------------------------------
5  * This file is part of emufs.
6  *
7  * emufs is free software; you can redistribute it and/or modify it under the
8  * terms of the GNU General Public License as published by the Free Software
9  * Foundation; either version 2 of the License, or (at your option) any later
10  * version.
11  *
12  * emufs is distributed in the hope that it will be useful, but WITHOUT ANY
13  * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
14  * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
15  * details.
16  *
17  * You should have received a copy of the GNU General Public License along
18  * with emufs; if not, write to the Free Software Foundation, Inc., 59 Temple
19  * Place, Suite 330, Boston, MA  02111-1307  USA
20  *----------------------------------------------------------------------------
21  * Creado:  jue abr  8 18:10:35 ART 2004
22  * Autores: Nicolás Dimov <sagardua@uolsinectis.com.ar>
23  *----------------------------------------------------------------------------
24  *
25  * $Id$
26  *
27  */
28
29 /** \file
30  *
31  * Manejo de archivos de índice de registros.
32  * 
33  * Implementación del manejo de archivos de índice de registros.
34  *
35  */
36
37 #include "idx.h"
38 #include "tipo3.h"
39
40 int emufs_idx_buscar_mayor_id(EMUFS *emu)
41 {
42         int id, max = -1;
43         FILE *f_idx;    
44         BLOCK_REG_T reg;
45         char name_f_idx[255];
46
47         strcpy(name_f_idx,emu->nombre);
48         strcat(name_f_idx,".idx");
49
50         if ( (f_idx = fopen(name_f_idx,"r")) == NULL) return -1; /*ERROR*/
51         id = -1;
52         while ( !feof(f_idx) ){
53                 /* Me aseguro de leer la cantidad de bytes correcta */
54                 if (fread(&reg,sizeof(BLOCK_REG_T),1,f_idx) != 1) continue;
55                 if ( reg.id_reg >= max ) 
56                         max = reg.id_reg;
57         }
58         id = max+1;
59         fclose(f_idx);
60
61         return id;      
62 }
63
64 /*busca el registro ID en el archivo "block_reg.dat" y devuelve el nro de bloque en el que se encuentra*/
65 int emufs_idx_buscar_registro(EMUFS *emu, int ID)
66 {
67         FILE* f_idx;
68         BLOCK_REG_T reg;
69         char name_f_idx[255];
70         strcpy(name_f_idx,emu->nombre);
71         strcat(name_f_idx,".idx");
72         
73         if ( (f_idx = fopen(name_f_idx,"r")) == NULL) return -1; /*ERROR*/
74         while ( !feof(f_idx) ){
75                 if (fread(&reg,sizeof(BLOCK_REG_T),1,f_idx) != 1) continue;
76                 if ( reg.id_reg == ID ){
77                         fclose(f_idx);
78                         return reg.block;
79                 }
80         }
81         
82         fclose(f_idx);
83         return -1; /*no existe el registro*/
84 }
85
86 /* agrega un registro al final del archivo */
87 emufs_idx_agregar(EMUFS *emu, int num_bloque, int ID_aux)
88 {
89         FILE *f_idx;
90         BLOCK_REG_T reg;
91         char name_f_idx[255];
92         
93         strcpy(name_f_idx,emu->nombre);
94         strcat(name_f_idx,".idx");
95
96         if ( (f_idx = fopen(name_f_idx,"ab+"))==NULL ) return -1;
97                 
98         reg.block = num_bloque;
99         reg.id_reg = ID_aux;
100         fwrite(&reg,sizeof(BLOCK_REG_T),1,f_idx); 
101         fclose(f_idx);
102         return 0;
103 }