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: dom may 30 07:48:10 ART 2004
22 * Autores: Leandro Lucarella <llucare@fi.uba.ar>
23 *----------------------------------------------------------------------------
31 * Algoritmo de ordenamiento externo.
33 * Interfaz del algoritmo de ordenamiento externo.
37 #ifndef _EXTSORT_EXTSORT_H_
38 #define _EXTSORT_EXTSORT_H_
43 /** Ordena un archivo utilizando un método de ordenamiento externo.
45 * \param filename Nombre del archivo a ordenar.
46 * \param buf_size Tamaño del buffer en bytes.
47 * \param reg_size Tamaño de un registro en bytes.
48 * \param cmp Función de ordenamiento a utilizar (ver base.h).
49 * \return 0 si hubo un error.
50 * \warning Si se usa el archivo original para almacenar los resultados, si
51 * llegara a haber un problema en el ordenamiento se puede perder el
54 int extsort(const char* filename, size_t buf_size, size_t reg_size,
57 /** Ordena un archivo utilizando un método de ordenamiento externo en otro.
59 * \param filename Nombre del archivo a ordenar.
60 * \param new_filename Nombre del archivo donde dejar el resultado, si es NULL,
61 * se utiliza el archivo original.
62 * \param buf_size Tamaño del buffer en bytes.
63 * \param reg_size Tamaño de un registro en bytes.
64 * \param cmp Función de ordenamiento a utilizar (ver base.h).
65 * \return 0 si hubo un error.
66 * \warning Si se usa el archivo original para almacenar los resultados, si
67 * llegara a haber un problema en el ordenamiento se puede perder el
70 int extsort_safe(const char* filename, const char* new_filename,
71 size_t buf_size, size_t reg_size, CMP_FUNC cmp);
73 #endif /* _EXTSORT_EXTSORT_H_ */