]> git.llucax.com Git - z.facultad/75.06/emufs.git/blob - emufs/idx.c
99790704fb42de6cb57b88665a51f65237212f89
[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
39 int emufs_idx_buscar_mayor_id(EMUFS *emu)
40 {
41         int id, max = -1;
42         FILE *f_idx;    
43         EMUFS_IDX reg;
44         char name_f_idx[255]; /* TODO usar malloc para no limitar el tamaño de nombre de archivo */
45
46         strcpy(name_f_idx,emu->nombre);
47         strcat(name_f_idx, EMUFS_IDX_EXT);
48
49         if ( (f_idx = fopen(name_f_idx,"r")) == NULL) return -1; /*ERROR*/
50         id = -1;
51         while ( !feof(f_idx) ){
52                 /* Me aseguro de leer la cantidad de bytes correcta */
53                 if (fread(&reg,sizeof(EMUFS_IDX),1,f_idx) != 1) continue;
54                 if ( reg.id_reg >= max ) 
55                         max = reg.id_reg;
56         }
57         id = max+1;
58         fclose(f_idx);
59
60         return id;      
61 }
62
63 /*busca el registro ID en el archivo "block_reg.dat" y devuelve el nro de bloque en el que se encuentra*/
64 int emufs_idx_buscar_registro(EMUFS *emu, int ID)
65 {
66         FILE* f_idx;
67         EMUFS_IDX reg;
68         char name_f_idx[255];
69         strcpy(name_f_idx,emu->nombre);
70         strcat(name_f_idx, EMUFS_IDX_EXT);
71         
72         if ( (f_idx = fopen(name_f_idx,"r")) == NULL) return -1; /*ERROR*/
73         while ( !feof(f_idx) ){
74                 if (fread(&reg,sizeof(EMUFS_IDX),1,f_idx) != 1) continue;
75                 if ( reg.id_reg == ID ){
76                         fclose(f_idx);
77                         return reg.block;
78                 }
79         }
80         
81         fclose(f_idx);
82         return -1; /*no existe el registro*/
83 }
84
85 /* agrega un registro al final del archivo */
86 int emufs_idx_agregar(EMUFS *emu, int num_bloque, int ID_aux)
87 {
88         FILE *f_idx;
89         EMUFS_IDX reg;
90         char name_f_idx[255];
91         
92         strcpy(name_f_idx,emu->nombre);
93         strcat(name_f_idx, EMUFS_IDX_EXT);
94
95         if ( (f_idx = fopen(name_f_idx,"ab+"))==NULL ) return -1;
96                 
97         reg.block = num_bloque;
98         reg.id_reg = ID_aux;
99         fwrite(&reg,sizeof(EMUFS_IDX),1,f_idx); 
100         fclose(f_idx);
101         return 0;
102 }