Date: Thu, 28 May 2009 17:35:11 +0200 (CEST) From: Thomas-Martin Seck <tmseck@web.de> To: FreeBSD-gnats-submit@FreeBSD.org Subject: ports/135027: [Maintainer] www/gatling: update to 0.10 Message-ID: <200905281535.n4SFZBLr069766@hardy.tmseck.homedns.org> Resent-Message-ID: <200905281540.n4SFe27j074619@freefall.freebsd.org>
next in thread | raw e-mail | index | archive | help
>Number: 135027 >Category: ports >Synopsis: [Maintainer] www/gatling: update to 0.10 >Confidential: no >Severity: non-critical >Priority: low >Responsible: freebsd-ports-bugs >State: open >Quarter: >Keywords: >Date-Required: >Class: maintainer-update >Submitter-Id: current-users >Arrival-Date: Thu May 28 15:40:02 UTC 2009 >Closed-Date: >Last-Modified: >Originator: Thomas-Martin Seck >Release: FreeBSD 7.1-STABLE i386 >Organization: a private site in Germany >Environment: FreeBSD ports collection as of May 28, 2009. >Description: - update to 0.10 - introduce an rc.d and a gatling_wrapper script - add a test for strndup(3) and provide 7.2's strndup(3) implementation in case strndup is missing from the base system to make the dl utility build on all supported FreeBSD versions - retire the GATLING_ICONV option - introduce a new GATLING_SMB option (default on) - since tlsgatling and zlib do no longer cause build breakage (on supported FreeBSD versions anyway), change the default of GATLING_TLS and GATLING_ZLIB to "on" - honor WITH_DEBUG Added files: files/extra-patch-disable_smb files/gatling.in files/gatling_wrapper files/patch-bench.c files/patch-dl.c files/patch-http.c files/patch-matchiprange.c files/patch-rellink.c files/patch-strndup.c Removed files: files/patch-gatling.c >How-To-Repeat: >Fix: Apply this patch: Index: Makefile =================================================================== --- Makefile (.../www/gatling) (revision 1587) +++ Makefile (.../local/gatling) (revision 1587) @@ -6,7 +6,7 @@ # PORTNAME= gatling -PORTVERSION= 0.9 +PORTVERSION= 0.10 CATEGORIES= www benchmarks ftp ipv6 MASTER_SITES= http://dl.fefe.de/ @@ -18,6 +18,7 @@ USE_BZIP2= yes USE_GMAKE= yes USE_OPENSSL= yes +USE_RC_SUBR= gatling CFLAGS+= -I${LOCALBASE}/include/libowfat -I${OPENSSLINC} LDFLAGS+= -L${LOCALBASE}/lib -L${OPENSSLLIB} @@ -28,16 +29,18 @@ bin= dl sbin= gatling MAN8= gatling.8 -PORTDOCS= CHANGES README README.cgi README.ftp README.htaccess \ +PORTDOCS= CHANGES README README.antidos README.cgi README.ftp \ + README.htaccess \ README.http README.performance README.prefetch README.proxy \ README.redirect -PORTEXAMPLES= run-gatling cgi acc hcat referrer +PORTEXAMPLES= run-gatling cgi acc getlinks hcat hitprofile matchiprange \ + referrer OPTIONS= GATLING_BENCHMARKS "Install some benchmark programs" on \ - GATLING_ICONV "Use charset conversion" off \ - GATLING_TLS "Install tlsgatling" off \ - GATLING_ZLIB "Compress outgoing data" off \ - GATLING_OPTIMIZED_CFLAGS "Use optimized CFLAGS" on + GATLING_SMB "Add (read only) SMB support" on \ + GATLING_TLS "Build and install tlsgatling" on \ + GATLING_ZLIB "Compress outgoing data" on \ + GATLING_OPTIMIZED_CFLAGS "Add additional optimizations" on .include <bsd.port.pre.mk> @@ -47,41 +50,53 @@ bin+= bindbench forkbench forksbench httpbench ioerr manymapbench \ mktestdata mmapbench pthreadbench examples+= prep run-bench +MAN1+= bench.1 MAKE_ENV+= BENCHMARKS=1 .endif -.if defined(WITH_GATLING_OPTIMIZED_CFLAGS) +.if defined(WITH_GATLING_OPTIMIZED_CFLAGS) && !defined(WITH_DEBUG) CFLAGS+= -O2 -fomit-frame-pointer .endif -.if defined(WITH_GATLING_ICONV) +.if defined(WITH_GATLING_SMB) USE_ICONV= yes CFLAGS+= -I${LOCALBASE}/include MAKE_ENV+= ICONV=1 +.else +EXTRA_PATCHES+= ${PATCHDIR}/extra-patch-disable_smb .endif .if defined(WITH_GATLING_TLS) MAKE_ENV+= TLSGATLING=1 sbin+= tlsgatling -portdocs+= README.tls +PORTDOCS+= README.tls .endif .if defined(WITH_GATLING_ZLIB) MAKE_ENV+= ZLIB=1 .endif -PLIST_FILES= ${bin:S,^,bin/,} ${sbin:S,^,sbin/,} +.if defined(WITH_DEBUG) +MAKE_ENV+= DEBUG=1 +STRIP= +.endif +PLIST_FILES= ${bin:S,^,bin/,} ${sbin:S,^,sbin/,} sbin/gatling_wrapper + pre-install: @cd ${WRKSRC} && ${CP} gatling.1 gatling.8 do-install: cd ${WRKSRC} && ${INSTALL_PROGRAM} ${bin} ${PREFIX}/bin cd ${WRKSRC} && ${INSTALL_PROGRAM} ${sbin} ${PREFIX}/sbin + ${INSTALL_SCRIPT} ${FILESDIR}/gatling_wrapper ${PREFIX}/sbin .if !defined(NOPORTEXAMPLES) ${MKDIR} ${EXAMPLESDIR} cd ${WRKSRC} && ${INSTALL_SCRIPT} ${PORTEXAMPLES} ${EXAMPLESDIR} .endif +.if !empty(MAN1) + cd ${WRKSRC} && ${INSTALL_MAN} ${MAN1} ${MAN1PREFIX}/man/man1 +.endif cd ${WRKSRC} && ${INSTALL_MAN} ${MAN8} ${MAN8PREFIX}/man/man8 .if !defined(NOPORTDOCS) ${MKDIR} ${DOCSDIR} Index: distinfo =================================================================== --- distinfo (.../www/gatling) (revision 1587) +++ distinfo (.../local/gatling) (revision 1587) @@ -1,3 +1,3 @@ -MD5 (gatling-0.9.tar.bz2) = bae9a695b7ced3ba0a4b359369273a66 -SHA256 (gatling-0.9.tar.bz2) = 6fa7c1278fd7d05422e073e4062cd931e10d2593fe73728fdcf0e2541db01bbe -SIZE (gatling-0.9.tar.bz2) = 73831 +MD5 (gatling-0.10.tar.bz2) = 04e8434156d91657c77a8a038c5b27cf +SHA256 (gatling-0.10.tar.bz2) = 1981ee8706a423e06e507c25202e83785595feabe68c148350818bc50380d416 +SIZE (gatling-0.10.tar.bz2) = 98422 Index: files/patch-gatling.c =================================================================== --- files/patch-gatling.c (.../www/gatling) (revision 1587) +++ files/patch-gatling.c (.../local/gatling) (revision 1587) @@ -1,10 +0,0 @@ ---- gatling.c.orig Mon Aug 27 16:08:00 2007 -+++ gatling.c Mon Aug 27 16:08:06 2007 -@@ -101,7 +101,6 @@ - #include <fcntl.h> - #include <string.h> - #include <ctype.h> --#include <crypt.h> - #include "havealloca.h" - #include "havesetresuid.h" - Index: files/patch-matchiprange.c =================================================================== --- files/patch-matchiprange.c (.../www/gatling) (revision 0) +++ files/patch-matchiprange.c (.../local/gatling) (revision 1587) @@ -0,0 +1,10 @@ +--- matchiprange.c.orig 2009-04-10 18:17:38.000000000 +0200 ++++ matchiprange.c 2009-04-10 18:17:58.000000000 +0200 +@@ -17,6 +17,7 @@ + #include <fmt.h> + #include <ctype.h> + #include <ip6.h> ++#include <string.h> + + char _buf[8192]; + Index: files/extra-patch-disable_smb =================================================================== --- files/extra-patch-disable_smb (.../www/gatling) (revision 0) +++ files/extra-patch-disable_smb (.../local/gatling) (revision 1587) @@ -0,0 +1,11 @@ +--- gatling_features.h.orig 2009-04-13 16:18:09.000000000 +0200 ++++ gatling_features.h 2009-04-13 16:19:18.000000000 +0200 +@@ -6,7 +6,7 @@ + // #define SUPPORT_BITTORRENT + + #define SUPPORT_SERVERSTATUS +-#define SUPPORT_SMB ++#undef SUPPORT_SMB + #define SUPPORT_FTP + #define SUPPORT_PROXY + /* #define DEBUG to enable more verbose debug messages for tracking fd Index: files/patch-GNUmakefile =================================================================== --- files/patch-GNUmakefile (.../www/gatling) (revision 1587) +++ files/patch-GNUmakefile (.../local/gatling) (revision 1587) @@ -1,7 +1,7 @@ ---- GNUmakefile.orig Wed Jan 31 18:05:38 2007 -+++ GNUmakefile Mon Aug 27 16:49:36 2007 -@@ -1,21 +1,26 @@ - #DEBUG=1 +--- GNUmakefile.orig 2009-04-09 19:00:23.000000000 +0200 ++++ GNUmakefile 2009-04-10 17:46:56.000000000 +0200 +@@ -1,24 +1,23 @@ +-#DEBUG=1 -ZLIB=1 -prefix=/opt/diet +prefix=${PREFIX} @@ -10,34 +10,33 @@ man1dir=$(MANDIR)/man1 -TARGETS=gatling httpbench bindbench dl ioerr bench tlsgatling \ --pthreadbench cgi getlinks rellink acc hcat +-pthreadbench cgi -TARGETS2=mktestdata mmapbench manymapbench forkbench forksbench -+TARGETS=cgi dl gatling getlinks rellink acc hcat referrer ++TARGETS=gatling dl \ ++cgi +TARGETS2= +ifdef BENCHMARKS -+TARGETS+=httpbench bindbench ioerr pthreadbench ++TARGETS+=httpbench bindbench ioerr bench pthreadbench +TARGETS2+=mktestdata mmapbench manymapbench forkbench forksbench +endif +ifdef TLSGATLING +TARGETS+=tlsgatling +endif + ALLTARGETS=$(TARGETS) acc hcat referrer hitprofile matchiprange getlinks \ + rellink $(TARGETS2) --all: $(TARGETS) $(TARGETS2) -+all: checklibs $(TARGETS) $(TARGETS2) + all: $(ALLTARGETS) -CROSS= -+#CROSS= - #CROSS=i686-mingw32- +-#CROSS=i686-mingw32- -CC=$(CROSS)gcc -CFLAGS=-pipe -Wall -LDFLAGS= -+#CC=$(CROSS)gcc -+#CFLAGS=-pipe -Wall -+#LDFLAGS= - +- path = $(subst :, ,$(PATH)) diet_path = $(foreach dir,$(path),$(wildcard $(dir)/diet)) -@@ -32,15 +37,11 @@ + ifeq ($(strip $(diet_path)),) +@@ -34,15 +33,11 @@ # to build without diet libc support, use $ make DIET= # see http://www.fefe.de/dietlibc/ for details about the diet libc @@ -55,7 +54,7 @@ endif LDLIBS=-lowfat -@@ -66,7 +67,7 @@ +@@ -68,7 +63,7 @@ CC:=$(DIET) $(CC) pthreadbench: pthreadbench.o @@ -64,16 +63,20 @@ forksbench: forkbench.o $(CC) -static -o $@ forkbench.o $(LDFLAGS) $(LDLIBS) -@@ -74,7 +75,7 @@ - gatling.o: version.h havesetresuid.h +@@ -86,9 +81,11 @@ + gatling: gatling.o $(OBJS) md5lib + $(CC) $(LDFLAGS) $@.o $(OBJS) -o $@ $(LDLIBS) `cat md5lib` - tlsgatling: gatling.c ssl.o mime.o -- -$(CC) -o $@ gatling.c ssl.o mime.o $(CFLAGS) -DSUPPORT_HTTPS $(LDFLAGS) -lssl -lcrypto $(LDLIBS) -+ $(CC) -o $@ gatling.c ssl.o mime.o $(CFLAGS) -DSUPPORT_HTTPS $(LDFLAGS) -lssl -lcrypto $(LDLIBS) - - gatling: gatling.o mime.o - $(CC) $(LDFLAGS) $@.o mime.o -o $@ $(LDLIBS) -@@ -107,9 +108,13 @@ ++dl: dl.c havestrndup havestrndup.h ++ $(CC) $(CFLAGS) dl.c `cat havestrndup` $(LDFLAGS) -lowfat -o $@ ++ + httpbench: httpbench.o + bindbench: bindbench.o +-dl: dl.o + ioerr: ioerr.o + bench: bench.o + getlinks: getlinks.o +@@ -121,9 +118,13 @@ rm -f trysocket libiconv: tryiconv.c @@ -81,7 +84,7 @@ - if $(CC) $(CFLAGS) -o tryiconv tryiconv.c -liconv >/dev/null 2>&1; then echo "-liconv"; \ - fi; fi > libiconv +ifdef ICONV -+ if $(CC) $(CFLAGS) -L$(LOCALBASE)/lib -o tryiconv tryiconv.c -liconv >/dev/null 2>&1; then echo "-L$(LOCALBASE)/lib -liconv"; else \ ++ if $(CC) $(CFLAGS) $(LDFLAGS) -o tryiconv tryiconv.c -liconv >/dev/null 2>&1; then echo "-L$(LDFLAGS) -liconv"; else \ + echo ""; \ + fi > libiconv +else @@ -90,25 +93,14 @@ rm -f tryiconv libcrypt: trycrypt.c -@@ -130,9 +135,11 @@ - ar q $@ dummy.o - -ranlib $@ +@@ -144,6 +145,10 @@ + if $(CC) $(CFLAGS) -o tryresuid $^ >/dev/null 2>&1; then echo "#define LIBC_HAS_SETRESUID"; fi > $@ + -rm -f tryresuid -+checklibs: libsocket libiconv libcrypt ++havestrndup havestrndup.h: trystrndup.c ++ if $(CC) $(CFLAGS) -o trystrndup $^ >/dev/null 2>&1; then echo "">havestrndup; echo "#define LIBC_HAS_STRNDUP">havestrndup.h; else echo "strndup.c">havestrndup; echo "">havestrndup.h; fi ++ rm -f trystrndup + - LDLIBS+=`cat libsocket libiconv libcrypt` + dummy.c: + touch $@ --$(TARGETS): libsocketkludge.a libsocket libiconv libcrypt -+$(TARGETS): libsocketkludge.a - - install: gatling dl getlinks - install -d $(DESTDIR)$(BINDIR) $(man1dir) -@@ -144,7 +151,7 @@ - rm -f $(DESTDIR)$(BINDIR)/gatling $(DESTDIR)$(BINDIR)/tlsgatling $(DESTDIR)$(man1dir)/gatling.1 $(DESTDIR)$(man1dir)/bench.1 - - clean: -- rm -f $(TARGETS) *.o version.h core *.core libsocket libsocketkludge.a dummy.c libiconv libcrypt havesetresuid.h -+ rm -f $(TARGETS) $(TARGETS2) *.o version.h core *.core libsocket libsocketkludge.a dummy.c libiconv libcrypt havesetresuid.h - - VERSION=gatling-$(shell head -n 1 CHANGES|sed 's/://') - CURNAME=$(notdir $(shell pwd)) Index: files/gatling_wrapper =================================================================== --- files/gatling_wrapper (.../www/gatling) (revision 0) +++ files/gatling_wrapper (.../local/gatling) (revision 1587) @@ -0,0 +1,91 @@ +#!/bin/sh -T +# +#- +# Copyright 2009 Thomas-Martin Seck. All rights reserved. +# +# Redistribution and use in source and binary forms, with or without +# modification, are permitted providing that the following conditions +# are met: +# 1. Redistributions of source code must retain the above copyright +# notice, this list of conditions and the following disclaimer. +# 2. Redistributions in binary form must reproduce the above copyright +# notice, this list of conditions and the following disclaimer in the +# documentation and/or other materials provided with the distribution. +# +# THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND +# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE +# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE +# ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE +# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL +# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS +# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) +# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT +# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY +# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF +# SUCH DAMAGE. +# +# $FreeBSD$ +# +# gatling_wrapper {gatling|tlsgatling} [options] +# +# A simple wrapper script for gatling (or any other program that does not +# daemonize itself and logs to stdout). +# +# This wrapper tries to emulate part of the functionality usually supplied +# by software like daemontools or runit. +# It can be used by a FreeBSD port rc.d script to start a program +# that does not daemonize itself and logs to stdout/stderr. It redirects stdout +# and stderr to logger(1) via a fifo. +# +# Note: We need a shell that can offer us asynchronous trap handling in order +# to be able to abort the infinite loop from outside. FreeBSD's /bin/sh offers +# the "-T" switch for this purpose. +# +# TODO: send fd 2 output to never-never land to get rid of "Terminated" when we +# kill this script but provide a way for errx() to communicate with the outside +# world via stderr. + +errx() { + echo "${me}: $@" >&2 + exit 1 +} + +cleanup() { + rm -rf ${tmpdir} + rm -f ${pidfile} +} + +PATH=/bin:/sbin:/usr/bin:/usr/sbin + +me=${0##*/} +logger=/usr/bin/logger +daemon_log_facility=daemon.notice +self_log_facility=daemon.notice +pidfile=/var/run/${me}.pid +daemon_name=gatling +daemon_program="$1" +shift + +test -x "${daemon_program}" || errx "cannot execute ${daemon_program}!" +test -x ${logger} || errx "cannot execute ${logger}!" +test -f ${pidfile} && errx "${pidfile} is already present -- is another instance of ${me} running?" +echo $$ >${pidfile} || errx "cannot write to ${pidfile}!" +tmpdir=`mktemp -d /tmp/${me}.XXXXXXXXXX` || errx "cannot generate tmpdir!" + +logfifo=${tmpdir}/fifo +mkfifo -m 0600 ${logfifo} || errx "cannot generate fifo!" + +while true; do + trap 'break' 1 2 3 6 9 15 + ${logger} -i -p ${daemon_log_facility} -t ${daemon_name} <${logfifo} & + log_pid=$! + "${daemon_program}" $@ >${logfifo} 2>&1 & + daemon_pid=$! + wait ${daemon_pid} + ${logger} -i -p ${self_log_facility} -t ${me} "${daemon_program} died -- restarting..." + sleep 2 +done + +kill -TERM ${daemon_pid} 2>/dev/null +wait +cleanup Index: files/gatling.in =================================================================== --- files/gatling.in (.../www/gatling) (revision 0) +++ files/gatling.in (.../local/gatling) (revision 1587) @@ -0,0 +1,67 @@ +#!/bin/sh +# +# $FreeBSD$ +# + +# PROVIDE: gatling +# REQUIRE: LOGIN +# KEYWORD: shutdown + +# Set "gatling_enable=yes" in either /etc/rc.conf, /etc/rc.conf.local or +# /etc/rc.conf.d/gatling to enable gatling. +# +# Set gatling_root if you want to serve files from other locations than +# the default (%%PREFIX%%/www/data). +# +# Set gatling_ftp_enable=yes to make gatling serve files via FTP, too. +# +# Set gatling_ssl_enable=yes to serve files via HTTPS/SSL (needs tlsgatling). +# +# Additionally, you can set gatling_effective_user and gatling_flags; please +# see gatling(8) for further information about possible gatling_flags. + +check_user() { + /usr/sbin/pw usershow -n ${gatling_effective_user} -q >/dev/null +} + +. %%RC_SUBR%% + +name=gatling +rcvar=`set_rcvar` + +load_rc_config ${name} + +gatling_enable=${gatling_enable-"NO"} +gatling_root=${gatling_root:-%%PREFIX%%/www/data} +# needed to bind privileged ports at startup: +gatling_user=root +gatling_effective_user=${gatling_effective_user:-www} +gatling_flags="-u ${gatling_effective_user} -c ${gatling_root} ${gatling_flags}" +case "${gatling_ftp_enable}" in + [Yy][Ee][Ss]) + gatling_flags="-f ${gatling_flags}" + ;; + *) + gatling_flags="-F ${gatling_flags}" + ;; +esac + +case "${gatling_ssl_enable}" in + [Yy][Ee][Ss]) + which_gatling="%%PREFIX%%/sbin/tlsgatling" + ;; + *) + which_gatling="%%PREFIX%%/sbin/gatling" + ;; +esac + +gatling_flags="${which_gatling} ${gatling_flags} &" +command="%%PREFIX%%/sbin/gatling_wrapper" +command_interpreter="/bin/sh -T" +pidfile=/var/run/gatling_wrapper.pid +required_dirs="${gatling_root}" +required_files="${which_gatling}" + +start_precmd=check_user +run_rc_command "$1" + Index: files/patch-bench.c =================================================================== --- files/patch-bench.c (.../www/gatling) (revision 0) +++ files/patch-bench.c (.../local/gatling) (revision 1587) @@ -0,0 +1,10 @@ +--- bench.c.orig 2009-04-10 18:15:06.000000000 +0200 ++++ bench.c 2009-04-10 18:15:19.000000000 +0200 +@@ -13,6 +13,7 @@ + #include <errno.h> + #include <buffer.h> + #include <fcntl.h> ++#include <string.h> + + void usage() { + die(0,"usage: bench [-n requests] [-c concurrency] [-t timeout] [-k] [-K count]\n" Index: files/patch-dl.c =================================================================== --- files/patch-dl.c (.../www/gatling) (revision 0) +++ files/patch-dl.c (.../local/gatling) (revision 1587) @@ -0,0 +1,13 @@ +--- dl.c.orig 2009-04-10 17:51:59.000000000 +0200 ++++ dl.c 2009-04-10 17:56:31.000000000 +0200 +@@ -37,6 +37,10 @@ + #include <assert.h> + #include <ctype.h> + #include <string.h> ++#include "havestrndup.h" ++#ifndef LIBC_HAS_STRNDUP ++char* strndup(const char*, size_t); ++#endif + + int dostats; + Index: files/patch-http.c =================================================================== --- files/patch-http.c (.../www/gatling) (revision 0) +++ files/patch-http.c (.../local/gatling) (revision 1587) @@ -0,0 +1,9 @@ +--- http.c.orig 2009-04-10 16:01:37.000000000 +0200 ++++ http.c 2009-04-10 16:01:57.000000000 +0200 +@@ -1,4 +1,6 @@ ++/* this define breaks the build on FreeBSD: + #define _XOPEN_SOURCE 500 ++*/ + + #include "gatling.h" + Index: files/patch-strndup.c =================================================================== --- files/patch-strndup.c (.../www/gatling) (revision 0) +++ files/patch-strndup.c (.../local/gatling) (revision 1587) @@ -0,0 +1,65 @@ +--- /dev/null 2009-04-10 17:44:00.000000000 +0200 ++++ trystrndup.c 2009-04-10 17:01:00.000000000 +0200 +@@ -0,0 +1,6 @@ ++#include <string.h> ++int main() { ++char* s; ++s=strndup("foo",3); ++return 0; ++} +--- /dev/null 2009-04-10 16:55:00.000000000 +0200 ++++ strndup.c 2009-01-08 10:50:20.000000000 +0100 +@@ -0,0 +1,53 @@ ++/* $NetBSD: strndup.c,v 1.3 2007/01/14 23:41:24 cbiere Exp $ */ ++ ++/* ++ * Copyright (c) 1988, 1993 ++ * The Regents of the University of California. All rights reserved. ++ * ++ * Redistribution and use in source and binary forms, with or without ++ * modification, are permitted provided that the following conditions ++ * are met: ++ * 1. Redistributions of source code must retain the above copyright ++ * notice, this list of conditions and the following disclaimer. ++ * 2. Redistributions in binary form must reproduce the above copyright ++ * notice, this list of conditions and the following disclaimer in the ++ * documentation and/or other materials provided with the distribution. ++ * 4. Neither the name of the University nor the names of its contributors ++ * may be used to endorse or promote products derived from this software ++ * without specific prior written permission. ++ * ++ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND ++ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE ++ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ++ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE ++ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL ++ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS ++ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) ++ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT ++ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY ++ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF ++ * SUCH DAMAGE. ++ */ ++ ++#include <sys/cdefs.h> ++__FBSDID("$FreeBSD: src/lib/libc/string/strndup.c,v 1.1.2.1 2009/01/08 09:50:20 kib Exp $"); ++ ++#include <stddef.h> ++#include <stdlib.h> ++#include <string.h> ++ ++char * ++strndup(const char *str, size_t n) ++{ ++ size_t len; ++ char *copy; ++ ++ for (len = 0; len < n && str[len]; len++) ++ continue; ++ ++ if ((copy = malloc(len + 1)) == NULL) ++ return (NULL); ++ memcpy(copy, str, len); ++ copy[len] = '\0'; ++ return (copy); ++} Index: files/patch-rellink.c =================================================================== --- files/patch-rellink.c (.../www/gatling) (revision 0) +++ files/patch-rellink.c (.../local/gatling) (revision 1587) @@ -0,0 +1,10 @@ +--- rellink.c.orig 2009-04-10 18:15:33.000000000 +0200 ++++ rellink.c 2009-04-10 18:15:46.000000000 +0200 +@@ -17,6 +17,7 @@ + #include <fcntl.h> + #include <sys/mman.h> + #include <utime.h> ++#include <string.h> + + static int canonicalize(stralloc* url,const char* baseurl) { + /* for the comments, assume baseurl is "http://www.fefe.de/x/y.html" */ >Release-Note: >Audit-Trail: >Unformatted:
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200905281535.n4SFZBLr069766>