Date: Sat, 9 Dec 2006 20:20:38 +0800 (CST) From: Gea-Suan Lin <gslin@gslin.org> To: FreeBSD-gnats-submit@freebsd.org Cc: perl@FreeBSD.org Subject: [PATCH] devel/p5-Coro: update to 3.1.1 Message-ID: <20061209122038.754778D@netnews.NCTU.edu.tw>
next in thread | raw e-mail | index | archive | help
>Submitter-Id: current-users >Originator: Gea-Suan Lin >Organization: >Confidential: no >Synopsis: [PATCH] devel/p5-Coro: update to 3.1.1 >Severity: non-critical >Priority: low >Category: ports >Class: update >Release: FreeBSD 6.1-RELEASE-p8 i386 >Environment: System: FreeBSD netnews.NCTU.edu.tw 6.1-RELEASE-p8 FreeBSD 6.1-RELEASE-p8 #0: Fri Sep 29 03:41:50 CST 2006 >Description: - Update to 3.1.1 Port maintainer (perl@FreeBSD.org) is cc'd. Generated with FreeBSD Port Tools 0.77 >How-To-Repeat: >Fix: --- p5-Coro-3.1.1,1.patch begins here --- diff -ruN --exclude=CVS /usr/ports/devel/p5-Coro/Makefile /home/staff/gslin/work/ports/p5-Coro/Makefile --- /usr/ports/devel/p5-Coro/Makefile Mon Feb 6 16:11:21 2006 +++ /home/staff/gslin/work/ports/p5-Coro/Makefile Sat Dec 9 20:19:51 2006 @@ -6,34 +6,29 @@ # PORTNAME= Coro -PORTVERSION= 1.9 +PORTVERSION= 3.1.1 PORTEPOCH= 1 CATEGORIES= devel MASTER_SITES= ${MASTER_SITE_PERL_CPAN} MASTER_SITE_SUBDIR= Coro PKGNAMEPREFIX= p5- +DISTNAME= ${PORTNAME}-3.11 MAINTAINER= perl@FreeBSD.org COMMENT= Coro - coroutine process abstraction for perl -BUILD_DEPENDS= p5-Event>=0.89:${PORTSDIR}/devel/p5-Event \ - ${SITE_PERL}/${PERL_ARCH}/Scalar/Util.pm:${PORTSDIR}/lang/p5-Scalar-List-Utils -RUN_DEPENDS= ${BUILD_DEPENDS} +RUN_DEPENDS= p5-Event>=0.89:${PORTSDIR}/devel/p5-Event \ + ${SITE_PERL}/AnyEvent.pm:${PORTSDIR}/devel/p5-AnyEvent \ + ${SITE_PERL}/${PERL_ARCH}/IO/AIO.pm:${PORTSDIR}/devel/p5-IO-AIO +BUILD_DEPENDS= ${RUN_DEPENDS} PERL_CONFIGURE= yes -.if !defined(NOPORTDOCS) -PORTDOCS= Changes -EXAMPLES= eg/attributes eg/bench eg/cont eg/dns eg/event eg/lwp eg/myhttpd eg/prodcons1 eg/prodcons2 eg/prodcons3 eg/readline - -post-install: - @${MKDIR} ${DOCSDIR} - @${INSTALL_DATA} ${PORTDOCS:S|^|${WRKSRC}/|} ${DOCSDIR} - @${ECHO_MSG} "===> Documentation installed in ${DOCSDIR}." - @${MKDIR} ${EXAMPLESDIR} - @${INSTALL_DATA} ${EXAMPLES:S|^|${WRKSRC}/|} ${EXAMPLESDIR} - @${ECHO_MSG} "===> Examples installed in ${EXAMPLESDIR}." -.endif +MAN3= Coro.3 Coro::AIO.3 Coro::Channel.3 Coro::Handle.3 \ + Coro::LWP.3 Coro::MakeMaker.3 Coro::RWLock.3 Coro::Select.3 \ + Coro::Semaphore.3 Coro::SemaphoreSet.3 Coro::Signal.3 \ + Coro::Socket.3 Coro::Specific.3 Coro::State.3 Coro::Timer.3 \ + Coro::Util.3 .include <bsd.port.pre.mk> @@ -41,22 +36,12 @@ IGNORE= requires perl 5.6.0 or later. Install lang/perl5.8 and try again .endif -MAN3= Coro.3 \ - Coro::AIO.3 \ - Coro::Channel.3 \ - Coro::Cont.3 \ - Coro::Event.3 \ - Coro::Handle.3 \ - Coro::MakeMaker.3 \ - Coro::RWLock.3 \ - Coro::Select.3 \ - Coro::Semaphore.3 \ - Coro::SemaphoreSet.3 \ - Coro::Signal.3 \ - Coro::Socket.3 \ - Coro::Specific.3 \ - Coro::State.3 \ - Coro::Timer.3 \ - Coro::Util.3 +post-install: + ${MKDIR} ${EXAMPLESDIR} + ${INSTALL_SCRIPT} ${WRKSRC}/eg/* ${EXAMPLESDIR} +.if !defined(NOPORTDOCS) + ${MKDIR} ${DOCSDIR} + ${INSTALL_DATA} ${WRKSRC}/doc/cede-vs-schedule ${DOCSDIR} +.endif .include <bsd.port.post.mk> diff -ruN --exclude=CVS /usr/ports/devel/p5-Coro/distinfo /home/staff/gslin/work/ports/p5-Coro/distinfo --- /usr/ports/devel/p5-Coro/distinfo Mon Feb 6 16:11:21 2006 +++ /home/staff/gslin/work/ports/p5-Coro/distinfo Sat Dec 9 19:45:50 2006 @@ -1,3 +1,3 @@ -MD5 (Coro-1.9.tar.gz) = 63efa9fb31ded80f2c7d1fb900163824 -SHA256 (Coro-1.9.tar.gz) = c94d584e07e0433909157277194112807077ed97446943995ecc2634595b8d7f -SIZE (Coro-1.9.tar.gz) = 55882 +MD5 (Coro-3.11.tar.gz) = b5e2accd75fbb4aaa83e7216e92e6a3d +SHA256 (Coro-3.11.tar.gz) = 1ad4f9aa856b7b8d9add923d1cb5baf14064d4754d999090f6d402c7e5b7cd9d +SIZE (Coro-3.11.tar.gz) = 62084 diff -ruN --exclude=CVS /usr/ports/devel/p5-Coro/files/patch-Coro-Makefile.PL /home/staff/gslin/work/ports/p5-Coro/files/patch-Coro-Makefile.PL --- /usr/ports/devel/p5-Coro/files/patch-Coro-Makefile.PL Wed Jan 11 21:17:31 2006 +++ /home/staff/gslin/work/ports/p5-Coro/files/patch-Coro-Makefile.PL Sat Dec 9 19:51:35 2006 @@ -1,120 +1,40 @@ ---- Coro/Makefile.PL.orig Wed Jan 11 13:20:06 2006 -+++ Coro/Makefile.PL Wed Jan 11 13:22:18 2006 -@@ -31,77 +31,8 @@ if ($^O =~ /win32/i or $^O =~ /cygwin/ o - $iface = "s"; - } - --print <<EOF; -- --*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** -- --C context sharing: This option makes it possible to share the C stack and --context between many coroutines, resulting in large memory savings and --slight speed gains, at the cost of potential (but mostly theoretical) --segfaults. On my Linux/x86 machine this decreased the size of a new --coroutine from 9k to 5k, but the savings are much more apparent on --machines without mmap or good memory management. -- --The algorithm relies on the non-fact that the same machine stack pointer --indicates the same function call nesting level, which usually works good --enough (no known cases of it failing are known) but might fail in theory. -- --The default (enabled) has been in use on productions servers for some --time now, without any problem reports, so you are encouraged to use the --default. -- --EOF -- --if (prompt ("Do you want to enable C context sharing (y/n)", "y") !~ /^\s*n/i) { -- print "\nC context sharing enabled.\n\n"; -+$iface = "u"; - $DEFINE .= " -DCORO_LAZY_STACK"; --} -- --if ($iface) { -- print <<EOF; -- --*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** -- --Coro can use a number of methods to implement coroutines at the C --level. The default chosen is based on your current confguration and is --correct in most cases, but you still can chose between these alternatives: -- --u The unix 'ucontext.h' functions are relatively new and not implemented -- or well-tested in older unices. They allow very fast coroutine creation -- and reasonably fast switching, and, most importantly, are very stable. -- --s If the ucontext functions are not working or you don't want -- to use them for other reasons you can try a workaround using -- setjmp/longjmp/sigaltstack (also standard unix functions). Coroutine -- creation is rather slow, but switching is very fast as well (often much -- faster than with the ucontext functions). Unfortunately, glibc-2.1 and -- below don't even feature a working sigaltstack. -- --l GNU/Linux. Very old GNU/Linux systems (glibc-2.1 and below) need -- this hack. Since it is very linux-specific it is also quite fast and -- recommended even for newer versions; when it works, that is (currently -- x86 and a few others only. If it compiles, it's usually ok). -- --i IRIX. For some reason, SGI really does not like to follow the single -- unix specification (does that surprise you?), so this workaround might -- be needed (it's fast), although [s] and [u] should also work now. -- --w Microsoft Windows. Try this on Microsoft Windows, although, as there is -- no standard on how to do this under windows, this might work only on -- cygwin or specific versions of msvc. Your problem. -- --For most systems, the default chosen should be OK. If you experience --problems then you should experiment with this setting and/or turn off --optimizations (make OPTIMIZE=-O0). -- --EOF -- --retry: -- +--- Coro/Makefile.PL.orig Sat Dec 9 19:48:35 2006 ++++ Coro/Makefile.PL Sat Dec 9 19:51:08 2006 +@@ -72,9 +72,7 @@ + + retry: + - my $r = prompt "Use which implementation,\n" . - "<s>etjmp/longjump, <u>context, <i>rix, <l>inux or <w>indows?", - $iface; -- $iface = lc $1 if $r =~ /(\S)/; ++ my $r = 'u'; + $iface = lc $1 if $r =~ /(\S)/; if ($iface eq "u") { - $DEFINE .= " -DCORO_UCONTEXT"; -@@ -122,37 +53,9 @@ retry: - print "\nUsing windows-specific implementation\n\n"; - } else { - print "\nUnknown implementation \"$iface\"\n"; -- goto retry; - } --} else { -- print "\nUsing microsoft compatible coroutines\n\n"; --} -- --print <<EOF; -- --*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** -- --Per-context stack size factor: Depending on your settings, Coro tries to --share the C stack as much as possible, but sometimes it needs to allocate --a new one. This setting controls the maximum size that gets allocated, --and should not be set too high, as memory and address space still is --wasted even if it's not fully used. The value entered will be multiplied --by sizeof(long), which is usually 4 on 32-bit systems, and 8 on 64-bit --systems. -- --A setting of 16384 (the default) therefore corresponds to a 64k..128k --stack, which usually is ample space (you might even want to try 8192 or --lower if your program creates many coroutines). -- --Some perls (mostly threaded ones and perl compiled under linux 2.6) and --some programs (inefficient regexes can use a lot of stack space) may --need much, much more: If Coro segfaults with weird backtraces (e.g. in a --function prologue) or in t/10_bugs.t, you might want to increase this to --65536 or more. -- --EOF +@@ -132,7 +130,7 @@ + + EOF -my $stacksize = prompt ("C stack size factor", "16384"); +my $stacksize = 65536; $DEFINE .= " -DSTACKSIZE=$stacksize"; print "using a stacksize of $stacksize * sizeof(long)\n"; +@@ -159,7 +157,7 @@ + + EOF + +-my $stackguard = prompt ("Number of guard pages (0 disables)", "4"); ++my $stackguard = 4; + $DEFINE .= " -DSTACKGUARD=$stackguard"; + + print <<EOF; +@@ -177,7 +175,7 @@ + + EOF + +-my $valgrind = prompt ("Enable valgrind support (y/n)", "n"); ++my $valgrind = 'n'; + $DEFINE .= " -DUSE_VALGRIND=1" if $valgrind =~ /[yY]/; + + print <<EOF; diff -ruN --exclude=CVS /usr/ports/devel/p5-Coro/pkg-plist /home/staff/gslin/work/ports/p5-Coro/pkg-plist --- /usr/ports/devel/p5-Coro/pkg-plist Wed Jan 11 21:17:31 2006 +++ /home/staff/gslin/work/ports/p5-Coro/pkg-plist Sat Dec 9 20:20:11 2006 @@ -1,40 +1,37 @@ -@comment $FreeBSD: ports/devel/p5-Coro/pkg-plist,v 1.5 2006/01/11 13:17:31 tobez Exp $ -%%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/Event/Event.so -%%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/Event/Event.bs -%%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/State/State.so -%%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/State/State.bs -%%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/.packlist +@comment $FreeBSD$ +%%EXAMPLESDIR%%/attributes +%%EXAMPLESDIR%%/bench +%%EXAMPLESDIR%%/dns +%%EXAMPLESDIR%%/event +%%EXAMPLESDIR%%/lwp +%%EXAMPLESDIR%%/myhttpd +%%EXAMPLESDIR%%/prodcons1 +%%EXAMPLESDIR%%/prodcons2 +%%EXAMPLESDIR%%/prodcons3 +%%EXAMPLESDIR%%/readline +%%PORTDOCS%%%%DOCSDIR%%/cede-vs-schedule %%SITE_PERL%%/%%PERL_ARCH%%/Coro.pm %%SITE_PERL%%/%%PERL_ARCH%%/Coro/AIO.pm -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Cont.pm -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/State.pm %%SITE_PERL%%/%%PERL_ARCH%%/Coro/Channel.pm -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Semaphore.pm -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/SemaphoreSet.pm -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/RWLock.pm %%SITE_PERL%%/%%PERL_ARCH%%/Coro/CoroAPI.h -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Specific.pm -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Timer.pm +%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Handle.pm +%%SITE_PERL%%/%%PERL_ARCH%%/Coro/LWP.pm %%SITE_PERL%%/%%PERL_ARCH%%/Coro/MakeMaker.pm +%%SITE_PERL%%/%%PERL_ARCH%%/Coro/RWLock.pm %%SITE_PERL%%/%%PERL_ARCH%%/Coro/Select.pm +%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Semaphore.pm +%%SITE_PERL%%/%%PERL_ARCH%%/Coro/SemaphoreSet.pm %%SITE_PERL%%/%%PERL_ARCH%%/Coro/Signal.pm -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Handle.pm -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Util.pm -%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Event.pm %%SITE_PERL%%/%%PERL_ARCH%%/Coro/Socket.pm -%%PORTDOCS%%%%EXAMPLESDIR%%/attributes -%%PORTDOCS%%%%EXAMPLESDIR%%/bench -%%PORTDOCS%%%%EXAMPLESDIR%%/cont -%%PORTDOCS%%%%EXAMPLESDIR%%/dns -%%PORTDOCS%%%%EXAMPLESDIR%%/event -%%PORTDOCS%%%%EXAMPLESDIR%%/lwp -%%PORTDOCS%%%%EXAMPLESDIR%%/myhttpd -%%PORTDOCS%%%%EXAMPLESDIR%%/prodcons1 -%%PORTDOCS%%%%EXAMPLESDIR%%/prodcons2 -%%PORTDOCS%%%%EXAMPLESDIR%%/prodcons3 -%%PORTDOCS%%%%EXAMPLESDIR%%/readline -%%PORTDOCS%%@dirrm %%EXAMPLESDIR%% -@dirrm %%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/Event -@dirrm %%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/State -@dirrm %%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro -@dirrm %%SITE_PERL%%/%%PERL_ARCH%%/Coro +%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Specific.pm +%%SITE_PERL%%/%%PERL_ARCH%%/Coro/State.pm +%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Timer.pm +%%SITE_PERL%%/%%PERL_ARCH%%/Coro/Util.pm +%%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/.packlist +%%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/State/State.bs +%%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/State/State.so +@dirrmtry %%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro/State +@dirrmtry %%SITE_PERL%%/%%PERL_ARCH%%/auto/Coro +@dirrmtry %%SITE_PERL%%/%%PERL_ARCH%%/Coro +@dirrmtry %%EXAMPLESDIR%% +%%PORTDOCS%%@dirrm %%DOCSDIR%% --- p5-Coro-3.1.1,1.patch ends here ---
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20061209122038.754778D>