1 1.23 joerg /* $NetBSD: append.c,v 1.23 2009/11/06 18:34:22 joerg 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 64 1.2 bjh21 #include "sort.h" 65 1.2 bjh21 66 1.23 joerg __RCSID("$NetBSD: append.c,v 1.23 2009/11/06 18:34:22 joerg Exp $"); 67 1.1 bjh21 68 1.1 bjh21 #include <stdlib.h> 69 1.1 bjh21 70 1.1 bjh21 /* 71 1.22 dsl * copy sorted lines to output 72 1.22 dsl * Ignore duplicates (marked with -ve keylen) 73 1.1 bjh21 */ 74 1.1 bjh21 void 75 1.22 dsl append(RECHEADER **keylist, int nelem, FILE *fp, put_func_t put) 76 1.1 bjh21 { 77 1.22 dsl RECHEADER **cpos, **lastkey; 78 1.22 dsl RECHEADER *crec; 79 1.1 bjh21 80 1.20 dsl lastkey = keylist + nelem; 81 1.22 dsl if (REVERSE) { 82 1.22 dsl for (cpos = lastkey; cpos-- > keylist;) { 83 1.21 dsl crec = *cpos; 84 1.22 dsl if (crec->keylen >= 0) 85 1.22 dsl put(crec, fp); 86 1.1 bjh21 } 87 1.22 dsl } else { 88 1.22 dsl for (cpos = keylist; cpos < lastkey; cpos++) { 89 1.22 dsl crec = *cpos; 90 1.22 dsl if (crec->keylen >= 0) 91 1.22 dsl put(crec, fp); 92 1.1 bjh21 } 93 1.1 bjh21 } 94 1.1 bjh21 } 95