1 1.18 simonb /* $NetBSD: fsort.h,v 1.18 2023/10/25 05:51:11 simonb Exp $ */ 2 1.12 jdolecek 3 1.12 jdolecek /*- 4 1.12 jdolecek * Copyright (c) 2000-2003 The NetBSD Foundation, Inc. 5 1.12 jdolecek * All rights reserved. 6 1.12 jdolecek * 7 1.12 jdolecek * This code is derived from software contributed to The NetBSD Foundation 8 1.12 jdolecek * by Ben Harris and Jaromir Dolecek. 9 1.12 jdolecek * 10 1.12 jdolecek * Redistribution and use in source and binary forms, with or without 11 1.12 jdolecek * modification, are permitted provided that the following conditions 12 1.12 jdolecek * are met: 13 1.12 jdolecek * 1. Redistributions of source code must retain the above copyright 14 1.12 jdolecek * notice, this list of conditions and the following disclaimer. 15 1.12 jdolecek * 2. Redistributions in binary form must reproduce the above copyright 16 1.12 jdolecek * notice, this list of conditions and the following disclaimer in the 17 1.12 jdolecek * documentation and/or other materials provided with the distribution. 18 1.12 jdolecek * 19 1.12 jdolecek * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS 20 1.12 jdolecek * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED 21 1.12 jdolecek * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR 22 1.12 jdolecek * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS 23 1.12 jdolecek * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 24 1.12 jdolecek * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 25 1.12 jdolecek * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 26 1.12 jdolecek * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 27 1.12 jdolecek * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 28 1.12 jdolecek * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 29 1.12 jdolecek * POSSIBILITY OF SUCH DAMAGE. 30 1.12 jdolecek */ 31 1.2 bjh21 32 1.1 bjh21 /*- 33 1.1 bjh21 * Copyright (c) 1993 34 1.1 bjh21 * The Regents of the University of California. All rights reserved. 35 1.1 bjh21 * 36 1.1 bjh21 * This code is derived from software contributed to Berkeley by 37 1.1 bjh21 * Peter McIlroy. 38 1.1 bjh21 * 39 1.1 bjh21 * Redistribution and use in source and binary forms, with or without 40 1.1 bjh21 * modification, are permitted provided that the following conditions 41 1.1 bjh21 * are met: 42 1.1 bjh21 * 1. Redistributions of source code must retain the above copyright 43 1.1 bjh21 * notice, this list of conditions and the following disclaimer. 44 1.1 bjh21 * 2. Redistributions in binary form must reproduce the above copyright 45 1.1 bjh21 * notice, this list of conditions and the following disclaimer in the 46 1.1 bjh21 * documentation and/or other materials provided with the distribution. 47 1.11 agc * 3. Neither the name of the University nor the names of its contributors 48 1.1 bjh21 * may be used to endorse or promote products derived from this software 49 1.1 bjh21 * without specific prior written permission. 50 1.1 bjh21 * 51 1.1 bjh21 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 52 1.1 bjh21 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 53 1.1 bjh21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 54 1.1 bjh21 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 55 1.1 bjh21 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 56 1.1 bjh21 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 57 1.1 bjh21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 58 1.1 bjh21 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 59 1.1 bjh21 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 60 1.1 bjh21 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 61 1.1 bjh21 * SUCH DAMAGE. 62 1.1 bjh21 * 63 1.1 bjh21 * @(#)fsort.h 8.1 (Berkeley) 6/6/93 64 1.1 bjh21 */ 65 1.1 bjh21 66 1.6 jdolecek #define BUFSIZE (1<<20) 67 1.9 jdolecek #define MAXNUM 131072 /* low guess at average record count */ 68 1.6 jdolecek #define BUFFEND (EOF-2) 69 1.6 jdolecek #define MAXFCT 1000 70 1.6 jdolecek #define DEFLLEN 65536 71 1.9 jdolecek 72 1.9 jdolecek /* 73 1.9 jdolecek * Default (initial) and maximum size of record buffer for fsort(). 74 1.9 jdolecek * Note that no more than MAXNUM records are stored in the buffer, 75 1.9 jdolecek * even if the buffer is not full yet. 76 1.9 jdolecek */ 77 1.18 simonb #define DEFBUFSIZE (1 << 20) /* 1 MB */ 78 1.18 simonb #define MAXBUFSIZE (8 << 20) /* 8 MB */ 79