1 /* vim: set noexpandtab tabstop=4 shiftwidth=4:
2 *----------------------------------------------------------------------------
4 *----------------------------------------------------------------------------
5 * This file is part of emufs.
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
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
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 *----------------------------------------------------------------------------
31 * Manejo de archivos de índice de registros.
33 * Implementación del manejo de archivos de índice de registros.
40 int emufs_idx_buscar_mayor_id(EMUFS *emu)
47 strcpy(name_f_idx,emu->nombre);
48 strcat(name_f_idx,".idx");
50 if ( (f_idx = fopen(name_f_idx,"r")) == NULL) return -1; /*ERROR*/
52 while ( !feof(f_idx) ){
53 /* Me aseguro de leer la cantidad de bytes correcta */
54 if (fread(®,sizeof(BLOCK_REG_T),1,f_idx) != 1) continue;
55 if ( reg.id_reg >= max )
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)
70 strcpy(name_f_idx,emu->nombre);
71 strcat(name_f_idx,".idx");
73 if ( (f_idx = fopen(name_f_idx,"r")) == NULL) return -1; /*ERROR*/
74 while ( !feof(f_idx) ){
75 if (fread(®,sizeof(BLOCK_REG_T),1,f_idx) != 1) continue;
76 if ( reg.id_reg == ID ){
83 return -1; /*no existe el registro*/
86 /* agrega un registro al final del archivo */
87 emufs_idx_agregar(EMUFS *emu, int num_bloque, int ID_aux)
93 strcpy(name_f_idx,emu->nombre);
94 strcat(name_f_idx,".idx");
96 if ( (f_idx = fopen(name_f_idx,"ab+"))==NULL ) return -1;
98 reg.block = num_bloque;
100 fwrite(®,sizeof(BLOCK_REG_T),1,f_idx);