ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/cvsroot/schmorpforge/genpage
(Generate patch)

Comparing cvsroot/schmorpforge/genpage (file contents):
Revision 1.65 by root, Tue Dec 8 19:50:54 2009 UTC vs.
Revision 1.72 by root, Fri Jul 30 14:47:50 2010 UTC

4 4
5mkdir "software.schmorp.de", 0755; 5mkdir "software.schmorp.de", 0755;
6mkdir "software.schmorp.de/pkg", 0755; 6mkdir "software.schmorp.de/pkg", 0755;
7mkdir "software.schmorp.de/img", 0755; 7mkdir "software.schmorp.de/img", 0755;
8system "rsync -av *.jpg software.schmorp.de/img/"; 8system "rsync -av *.jpg software.schmorp.de/img/";
9
10our %IRC = (
11 anyevent => ["irc.perl.org", "#anyevent", "http://mibbit.com/chat/#anyevent\@irc.perl.org"],
12# freenode => ["irc.freenode.org", "#schmorp", "http://webchat.freenode.net/?randomnick=1&channels=schmorp&prompt=1", ", users <tt>schmorp</tt> and <tt>elmex</tt>"],
13 freenode => ["irc.schmorp.de", "#schmorpforge", "http://chat.schmorp.de/?channels=schmorpforge", ", users <tt>schmorp</tt> and <tt>elmex</tt>"],
14 rxvt => ["irc.freenode.org", "#rxvt-unicode", "http://webchat.freenode.net/?randomnick=1&channels=rxvt-unicode&prompt=1", ""],
15 rxvtdev => ["irc.freenode.org", "#rxvt-unicode-dev", "http://webchat.freenode.net/?randomnick=1&channels=rxvt-unicode-dev&prompt=1", " <b>(no support, development only)</b>"],
16);
9 17
10sub hdr($$) { 18sub hdr($$) {
11 print <<EOF; 19 print <<EOF;
12<?xml version='1.0' encoding='utf-8'?> 20<?xml version='1.0' encoding='utf-8'?>
13<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd"> 21<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
133</body> 141</body>
134</html> 142</html>
135EOF 143EOF
136} 144}
137 145
138sub res_irc {
139# print "<tr><td><tt class='icon'>IRC</tt></td><td class='rr'>Server <tt><b><a href='http://widget.mibbit.com/?settings=ba7bec4f0f493fde9b226a13c375edbd&server=irc.schmorp.de&channel=%23schmorp&noServerNotices=true&autoConnect=true'>irc.schmorp.de</a></b></tt>, channel <tt>#schmorp</tt>, users <tt>schmorp</tt> and <tt>elmex</tt> <b>(say hi and <i>wait a few minutes</i>)</b></td></tr>\n";
140 print "<tr><td><tt class='icon'>IRC</tt></td><td class='rr'>Server <tt><b>irc.freenode.net</b></tt>, channel <tt>#schmorp</tt>, users <tt>schmorp</tt> and <tt>elmex</tt> <b>(say hi and <i>wait a few minutes</i>)</b></td></tr>\n";
141}
142
143$_ = <DATA>; 146$_ = <DATA>;
144for (;defined $_;) { 147for (;defined $_;) {
145 my ($name, @args) = split /\s+/; 148 my ($name, @args) = split /\s+/;
146 149
147 next unless $name; 150 next unless $name;
212 215
213</td></tr> 216</td></tr>
214EOF 217EOF
215 } 218 }
216 219
220 my @irc;
221
217 print "<tr><td><tt class='icon'>FILE</tt></td><td class='rr'><a href='http://dist.schmorp.de/$name/'>File Releases</a></td></tr>\n" 222 print "<tr><td><tt class='icon'>FILE</tt></td><td class='rr'><a href='http://dist.schmorp.de/$name/'>File Releases</a></td></tr>\n"
218 if grep /dist/, @args; 223 if grep /dist/, @args;
219 print "<tr><td><tt class='icon'>CPAN</tt></td><td class='rr'><a href='http://www.cpan.org/modules/by-authors/Marc_Lehmann/'>File Releases (CPAN)</a></td></tr>\n" 224 print "<tr><td><tt class='icon'>CPAN</tt></td><td class='rr'><a href='http://www.cpan.org/modules/by-authors/Marc_Lehmann/'>File Releases (CPAN)</a></td></tr>\n"
220 if grep /cpan$/, @args; 225 if grep /cpan$/, @args;
221 print "<tr><td><tt class='icon'>CPAN</tt></td><td class='rr'><a href='http://www.cpan.org/modules/by-authors/id/E/EL/ELMEX/'>File Releases (CPAN)</a></td></tr>\n" 226 print "<tr><td><tt class='icon'>CPAN</tt></td><td class='rr'><a href='http://www.cpan.org/modules/by-authors/id/E/EL/ELMEX/'>File Releases (CPAN)</a></td></tr>\n"
222 if grep /cpan-elmex/, @args; 227 if grep /cpan-elmex/, @args;
223 for (@args) { 228 for (@args) {
224 if (/list\((.*)\)/) { 229 if (/list\((.*?)\)/) {
225 print "<tr><td><tt class='icon'>LIST</tt></td><td class='rr'><a href='http://lists.schmorp.de/mailman/listinfo/" . ($1 || $name) . "'>Mailing List '" . ($1 || $name) . "'</a></td></tr>\n"; 230 print "<tr><td><tt class='icon'>LIST</tt></td><td class='rr'><a href='http://lists.schmorp.de/mailman/listinfo/" . ($1 || $name) . "'>Mailing List '" . ($1 || $name) . "'</a></td></tr>\n";
226 } 231 }
232 if (/irc\((.*?)\)/) {
233 push @irc, $1;
234 }
227 } 235 }
228 res_irc; 236 push @irc, "freenode" unless @irc;
237 for (@irc) {
238 my ($server, $channel, $url, $comment) = @{ $IRC{$_} or die };
239 print "<tr><td><tt class='icon'>IRC</tt></td><td class='rr'>Server <a href='$url'><tt><b>$server</b></tt>, channel <tt>$channel</tt></a>$comment <b>(say hi and <i>wait a few minutes or hours</i>)</b></td></tr>\n";
240 }
241
229 print "</table>"; 242 print "</table>";
230 243
231 if (my @files = grep $_, map /(cvs-co|cvs-pod|git-pod|git-co)\((\S+)\)/ && [$1, $2], @args) { 244 if (my @files = grep $_, map /(cvs-co|cvs-pod|git-pod|git-co)\((\S+)\)/ && [$1, $2], @args) {
232 print "<h2>Additional Documents</h2><table class='resources'>"; 245 print "<h2>Additional Documents</h2><table class='resources'>";
233 246
273<tr><td><tt class='icon'>CVS</tt></td><td class='rr'>All CVS modules can be browsed <a href="http://cvs.schmorp.de/">here</a></td></tr> 286<tr><td><tt class='icon'>CVS</tt></td><td class='rr'>All CVS modules can be browsed <a href="http://cvs.schmorp.de/">here</a></td></tr>
274<tr><td><tt class='icon'>GIT</tt></td><td class='rr'>All GIT repositories can be found <a href="http://git.ta-sa.org/">here</a></td></tr> 287<tr><td><tt class='icon'>GIT</tt></td><td class='rr'>All GIT repositories can be found <a href="http://git.ta-sa.org/">here</a></td></tr>
275<tr><td><tt class='icon'>FILE</tt></td><td class='rr'>All file releases can be found <a href="http://dist.schmorp.de/">here</a> or on CPAN (for Perl modules)</td></tr> 288<tr><td><tt class='icon'>FILE</tt></td><td class='rr'>All file releases can be found <a href="http://dist.schmorp.de/">here</a> or on CPAN (for Perl modules)</td></tr>
276<tr><td><tt class='icon'>LIST</tt></td><td class='rr'>All mailinglists can be found <a href="http://lists.schmorp.de/mailman/listinfo">here</a></td></tr> 289<tr><td><tt class='icon'>LIST</tt></td><td class='rr'>All mailinglists can be found <a href="http://lists.schmorp.de/mailman/listinfo">here</a></td></tr>
277<!--<tr><td><tt class='icon'>WIKI</tt></td><td class='rr'>The Wiki can be found <a href="http://wiki.schmorp.de/">here</a></td></tr>--> 290<!--<tr><td><tt class='icon'>WIKI</tt></td><td class='rr'>The Wiki can be found <a href="http://wiki.schmorp.de/">here</a></td></tr>-->
291
292<!--<tr><td><tt class='icon'>IRC</tt></td><td class='rr'>Server <a href='http://webchat.freenode.net/?randomnick=1&amp;channels=schmorp&amp;prompt=1'><tt><b>irc.freenode.net</b></tt>, channel <tt>#schmorp</tt></a>, users <tt>schmorp</tt> and <tt>elmex</tt> <b>(say hi and <i>wait a few minutes or hours</i>)</b><br/>Other project-specific IRC servers are listed on their respective project page.</td></tr>-->
293<tr><td><tt class='icon'>IRC</tt></td><td class='rr'>Server <a href='http://chat.schmorp.de/?channels=schmorpforge'><tt><b>irc.schmorp.de</b></tt>, channel <tt>#schmorpforge</tt></a>, users <tt>schmorp</tt> and <tt>elmex</tt> <b>(say hi and <i>wait a few minutes or hours</i>)</b><br/>Other project-specific IRC servers are listed on their respective project page.</td></tr>
278EOF 294EOF
279
280res_irc;
281 295
282print <<EOF; 296print <<EOF;
283</table> 297</table>
284 298
285<h2>Project List</h2> 299<h2>Project List</h2>
290 304
291print "</table>"; 305print "</table>";
292ftr; 306ftr;
293 307
294__DATA__ 308__DATA__
295rxvt-unicode dist list(rxvt-unicode) cvs-pod(doc/rxvt.1.pod,) cvs-pod(doc/rxvt.7.pod,FAQ) cvs-pod(src/urxvt.pm,Perl) cvs-co(Changes) 309rxvt-unicode dist list(rxvt-unicode) cvs-pod(doc/rxvt.1.pod,) cvs-pod(doc/rxvt.7.pod,FAQ) cvs-pod(src/urxvt.pm,Perl) cvs-co(Changes) irc(rxvt) irc(rxvtdev)
296 rxvt-unicode is a clone of the well known terminal emulator rxvt. 310 rxvt-unicode is a clone of the well known terminal emulator rxvt.
297 311
298 <p>If you have a problem, please have a look at the 312 <p>If you have a problem, please have a look at the
299 <a href="http://cvs.schmorp.de/rxvt-unicode/doc/rxvt.7.html">FAQ</a> 313 <a href="http://cvs.schmorp.de/rxvt-unicode/doc/rxvt.7.html">FAQ</a>
300 <em>first</em>.</p> 314 <em>first</em>.</p>
363 readline tab-completion to enter filenames. 377 readline tab-completion to enter filenames.
364 378
365 Again, its a dire hack and will not work with all programs. It does work 379 Again, its a dire hack and will not work with all programs. It does work
366 for gimp, firefox, gedit at least, though. 380 for gimp, firefox, gedit at least, though.
367 381
368Async-Interrupt cpan cvs-pod(Interrupt.pm,) cvs-co(Changes) list(anyevent) 382Async-Interrupt cpan cvs-pod(Interrupt.pm,) cvs-co(Changes) list(anyevent) irc(anyevent)
369 Allow C/XS libraries to interrupt perl asynchronously. 383 Allow C/XS libraries to interrupt perl asynchronously.
370 384
371 This is a module implementing a rarely-needed, very advanced technique 385 This is a module implementing a rarely-needed, very advanced technique
372 to interrupt a running perl interpreter from another thread, or similar, 386 to interrupt a running perl interpreter from another thread, or similar,
373 context, at very low overhead. 387 context, at very low overhead.
405 It could be used to write Knuddels clients, bots and even servers 419 It could be used to write Knuddels clients, bots and even servers
406 (although the latter doesn't make much sense, the protocol is rather 420 (although the latter doesn't make much sense, the protocol is rather
407 ugly. If you want to implement your own group communication server, use 421 ugly. If you want to implement your own group communication server, use
408 IRC instead). 422 IRC instead).
409 423
410AnyEvent-IRC cpan-elmex git-pod(lib/AnyEvent/IRC.pm,) git-co(Changes) git-co(samples/anyeventirccl) git-co(samples/anyeventirc) list(anyevent) 424AnyEvent-IRC cpan-elmex git-pod(lib/AnyEvent/IRC.pm,) git-co(Changes) git-co(samples/anyeventirccl) git-co(samples/anyeventirc) list(anyevent) irc(anyevent)
411 This module provides an alternative to the Net-IRC and Net-IRC2 425 This module provides an alternative to the Net-IRC and Net-IRC2
412 modules. Its design rationale is offering a 100% non-blocking 426 modules. Its design rationale is offering a 100% non-blocking
413 callback-based interface, RFC-compliant parsing and a lightweight 427 callback-based interface, RFC-compliant parsing and a lightweight
414 approach to modularity and reusability. 428 approach to modularity and reusability.
415 429
418 that are executed when a scope is being exited (or an object is destroyed). 432 that are executed when a scope is being exited (or an object is destroyed).
419 433
420 Much effort was invested into these guards behaving "sensibly" in the 434 Much effort was invested into these guards behaving "sensibly" in the
421 presence of thrown exceptions, errors and other adverse conditions, as 435 presence of thrown exceptions, errors and other adverse conditions, as
422 well as into good performance. 436 well as into good performance.
437
438common-sense cpan cvs-pod(sense.pm,) cvs-co(Changes)
439 This module implements some sane defaults for Perl programs, as defined
440 by two typical (or not so typical - use your common sense) specimens of
441 Perl coders.
423 442
424Net-IRC-Server cvs-pod(Net/IRC/Server.pm,) 443Net-IRC-Server cvs-pod(Net/IRC/Server.pm,)
425 This module provides a simple API for handling the IRC Protocol 444 This module provides a simple API for handling the IRC Protocol
426 aiming at implementing lightweight IRC-Servers. 445 aiming at implementing lightweight IRC-Servers.
427 446
446libcoro cvs-co(README) cvs-co(coro.h) 465libcoro cvs-co(README) cvs-co(coro.h)
447 This C-library implements coroutines (cooperative multitasking) in a 466 This C-library implements coroutines (cooperative multitasking) in a
448 portable fashion. 467 portable fashion.
449 468
450 As long as your system implements the <tt>ucontext</tt> (Unix) or the 469 As long as your system implements the <tt>ucontext</tt> (Unix) or the
451 older <tt>sigaltstack</tt> interfaces it should work out of the box, with 470 older <tt>sigaltstack</tt> interfaces it should work out of the box,
452 minimal configuration (it consists of only a single <tt>.h</tt> and a 471 with minimal configuration (it consists of only a single <tt>.h</tt> and
453 single <tt>.c</tt> file). It is known to run on a wide variety of unix 472 a single <tt>.c</tt> file). For the broken systems, it also supports
454 systems (SunOS, IRIX, GNU/Linux, HP-UX) and also on Windows, does not use 473 a slow pthreads-based system and (optional) assembly backends for
455 any assembly language and is architecture-independent. 474 higher speed on some systems. It is known to run on a wide variety of
475 unix systems (SunOS, IRIX, GNU/Linux, HP-UX, FreeBSD, NetBSD, OpenBSD)
476 and also on Windows, does not require any assembly language and is
477 architecture-independent.
456 478
457deliantra/server cvs-co(README) cvs-co(Changes) cvs-co(COPYING.Affero) 479deliantra/server cvs-co(README) cvs-co(Changes) cvs-co(COPYING.Affero)
458 The <a href="http://www.deliantra.net/">Deliantra</a> game server. 480 The <a href="http://www.deliantra.net/">Deliantra</a> game server.
459 481
460 Follow the link to <a href="http://www.deliantra.net/">Deliantra</a> for background info. 482 Follow the link to <a href="http://www.deliantra.net/">Deliantra</a> for background info.
537 See <a href="http://home.schmorp.de/marc/lmainit.html">its homepage</a> for more info. 559 See <a href="http://home.schmorp.de/marc/lmainit.html">its homepage</a> for more info.
538 560
539Algorithm-FEC cpan cvs-pod(FEC.pm,) cvs-co(README.fec) cvs-co(Changes) 561Algorithm-FEC cpan cvs-pod(FEC.pm,) cvs-co(README.fec) cvs-co(Changes)
540 Perl module implementing forward error correction using Vandermonde matrices 562 Perl module implementing forward error correction using Vandermonde matrices
541 563
542AnyEvent cpan cvs-pod(lib/AnyEvent.pm,) cvs-pod(lib/AnyEvent/Intro.pod,Introduction/Tutorial) cvs-pod(lib/AE.pm,AE) cvs-co(Changes) cvs-pod(lib/AnyEvent/Util.pm,AnyEvent::Util) cvs-pod(lib/AnyEvent/Handle.pm,AnyEvent::Handle) cvs-pod(lib/AnyEvent/Socket.pm,AnyEvent::Socket) cvs-pod(lib/AnyEvent/DNS.pm,AnyEvent::DNS) cvs-pod(lib/AnyEvent/Impl/EV.pm,AnyEvent::Impl::EV) cvs-pod(lib/AnyEvent/Impl/Event.pm,AnyEvent::Impl::Event) cvs-pod(lib/AnyEvent/Impl/Glib.pm,AnyEvent::Impl::Glib) cvs-pod(lib/AnyEvent/Impl/Tk.pm,AnyEvent::Impl::Tk) cvs-pod(lib/AnyEvent/Impl/Perl.pm,AnyEvent::Impl::Perl) cvs-pod(lib/AnyEvent/Impl/Qt.pm,AnyEvent::Impl::Qt) cvs-pod(lib/AnyEvent/Impl/EventLib.pm,AnyEvent::Impl::EventLib) cvs-pod(lib/AnyEvent/Impl/Irssi.pm,AnyEvent::Impl::Irssi) cvs-pod(lib/AnyEvent/Impl/IOAsync.pm,AnyEvent::Impl::IOAsync) cvs-pod(lib/AnyEvent/Impl/POE.pm,AnyEvent::Impl::POE) list(anyevent) 564AnyEvent cpan cvs-pod(lib/AnyEvent.pm,) cvs-pod(lib/AnyEvent/Intro.pod,Introduction/Tutorial) cvs-pod(lib/AE.pm,AE) cvs-co(Changes) cvs-pod(lib/AnyEvent/Util.pm,AnyEvent::Util) cvs-pod(lib/AnyEvent/Handle.pm,AnyEvent::Handle) cvs-pod(lib/AnyEvent/Socket.pm,AnyEvent::Socket) cvs-pod(lib/AnyEvent/DNS.pm,AnyEvent::DNS) cvs-pod(lib/AnyEvent/Impl/EV.pm,AnyEvent::Impl::EV) cvs-pod(lib/AnyEvent/Impl/Event.pm,AnyEvent::Impl::Event) cvs-pod(lib/AnyEvent/Impl/Glib.pm,AnyEvent::Impl::Glib) cvs-pod(lib/AnyEvent/Impl/Tk.pm,AnyEvent::Impl::Tk) cvs-pod(lib/AnyEvent/Impl/Perl.pm,AnyEvent::Impl::Perl) cvs-pod(lib/AnyEvent/Impl/Qt.pm,AnyEvent::Impl::Qt) cvs-pod(lib/AnyEvent/Impl/EventLib.pm,AnyEvent::Impl::EventLib) cvs-pod(lib/AnyEvent/Impl/Irssi.pm,AnyEvent::Impl::Irssi) cvs-pod(lib/AnyEvent/Impl/IOAsync.pm,AnyEvent::Impl::IOAsync) cvs-pod(lib/AnyEvent/Impl/POE.pm,AnyEvent::Impl::POE) list(anyevent) irc(anyevent)
543 This module offers a simple API for I/O, timer, signal, child process 565 This module offers a simple API for I/O, timer, signal, child process
544 and completion events, independent of a specific event loop. 566 and completion events, independent of a specific event loop.
545 567
546 <p>This module allows module authors to use those events internally 568 <p>This module allows module authors to use those events internally
547 without forcing users of the module to use a specific event loop, without 569 without forcing users of the module to use a specific event loop, without
566 <p>Lastly, AnyEvent::Handle offers a powerful framework for asynchronous and 588 <p>Lastly, AnyEvent::Handle offers a powerful framework for asynchronous and
567 buffered protocol handling. You can push multiple read event handlers 589 buffered protocol handling. You can push multiple read event handlers
568 to parse your protocol and start TLS/SSL negotiation transparently (and 590 to parse your protocol and start TLS/SSL negotiation transparently (and
569 fully non-blocking) at any time, in both server and client mode.</p> 591 fully non-blocking) at any time, in both server and client mode.</p>
570 592
571AnyEvent-FastPing cpan cvs-pod(FastPing.pm,) list(anyevent) 593AnyEvent-FastPing cpan cvs-pod(FastPing.pm,) list(anyevent) irc(anyevent)
572 This module implements a very fast and relatively flexible 594 This module implements a very fast and relatively flexible
573 ping (ping as in icmp echo request). 595 ping (ping as in icmp echo request).
574 596
575 This module allows you to quickly send ipv4 and ipv6 pings at a defined 597 This module allows you to quickly send ipv4 and ipv6 pings at a defined
576 rate to whole address ranges. It is fully event-driven (doesn't block 598 rate to whole address ranges. It is fully event-driven (doesn't block
579 more address ranges, to which pings will be distributed according to a 601 more address ranges, to which pings will be distributed according to a
580 least-load principle. 602 least-load principle.
581 603
582 A command line utility (<tt>fastping</tt>) is included. 604 A command line utility (<tt>fastping</tt>) is included.
583 605
584AnyEvent-HTTP cpan cvs-pod(HTTP.pm,) cvs-co(Changes) list(anyevent) 606AnyEvent-HTTP cpan cvs-pod(HTTP.pm,) cvs-co(Changes) list(anyevent) irc(anyevent)
585 A simple and plain event based http and https client. 607 A simple and plain event based http and https client.
586 608
587 This module implements a simple, stateless and non-blocking HTTP 609 This module implements a simple, stateless and non-blocking HTTP
588 client. It supports GET, POST and other request methods, cookies and more, 610 client. It supports GET, POST and other request methods, cookies and more,
589 all on a very low level. It can follow redirects supports proxies and 611 all on a very low level. It can follow redirects supports proxies and
597 The caller is responsible for authentication management, cookies (if 619 The caller is responsible for authentication management, cookies (if
598 the simplistic implementation in this module doesn't suffice), referer 620 the simplistic implementation in this module doesn't suffice), referer
599 and other high-level protocol details for which this module offers only 621 and other high-level protocol details for which this module offers only
600 limited support. 622 limited support.
601 623
602AnyEvent-MP cpan cvs-pod(MP.pm,) cvs-pod(MP/Intro.pod,Introduction/Tutorial) cvs-co(Changes) list(anyevent) 624AnyEvent-MP cpan cvs-pod(MP.pm,) cvs-pod(MP/Intro.pod,Introduction/Tutorial) cvs-co(Changes) list(anyevent) irc(anyevent)
603 This Perl module (-family) implements a simple message passing framework for Perl. 625 This Perl module (-family) implements a simple message passing framework for Perl.
604 626
605 Despite its simplicity, you can securely message other processes running 627 Despite its simplicity, you can securely message other processes running
606 on the same or other hosts. 628 on the same or other hosts.
607 629
608 For an introduction to this module family, see the Intro manual page. 630 For an introduction to this module family, see the Intro manual page.
609 631
610Coro-MP cpan cvs-pod(MP.pm,) cvs-co(Changes) list(anyevent) 632Coro-MP cpan cvs-pod(MP.pm,) cvs-co(Changes) list(anyevent) irc(anyevent)
611 This Perl module extends the AnyEvent::MP API with a thread-like/erlang-style API. 633 This Perl module extends the AnyEvent::MP API with a thread-like/erlang-style API.
612 634
613 This module implements a thread-like API to AnyEvent::MP that is closer 635 This module implements a thread-like API to AnyEvent::MP that is closer
614 to Erlang than the event-based AnyEvent::MP API. It integrates well into 636 to Erlang than the event-based AnyEvent::MP API. It integrates well into
615 AnyEvent::MP. 637 AnyEvent::MP.
616 638
617 See the AnyEvent::MP module and tutorial for info about the concepts used 639 See the AnyEvent::MP module and tutorial for info about the concepts used
618 in AnyEvent::MP. 640 in AnyEvent::MP.
619 641
620AnyEvent-DBI cpan cvs-pod(DBI.pm,) cvs-co(Changes) list(anyevent) 642AnyEvent-DBI cpan cvs-pod(DBI.pm,) cvs-co(Changes) list(anyevent) irc(anyevent)
621 A relatively simple wrapper around DBI to make asynchronous 643 A relatively simple wrapper around DBI to make asynchronous
622 SQL requests. 644 SQL requests.
623 645
624 This module implements asynchronous DBI access my forking or executing 646 This module implements asynchronous DBI access my forking or executing
625 separate "DBI-Server" processes and sending them requests. 647 separate "DBI-Server" processes and sending them requests.
626 648
627 It means that you can run DBI requests in parallel to other tasks. 649 It means that you can run DBI requests in parallel to other tasks.
628 650
629AnyEvent-HTTPD cpan-elmex git-pod(lib/AnyEvent/HTTPD.pm,) git-co(Changes) list(anyevent) 651AnyEvent-HTTPD cpan-elmex git-pod(lib/AnyEvent/HTTPD.pm,) git-co(Changes) list(anyevent) irc(anyevent)
630 A simple and plain event based http web application server Perl module. 652 A simple and plain event based http web application server Perl module.
631 653
632 This is a very basic HTTP server that allows the user/programmer to install 654 This is a very basic HTTP server that allows the user/programmer to install
633 hooks for URL paths to generate the output. It uses AnyEvent to be easily 655 hooks for URL paths to generate the output. It uses AnyEvent to be easily
634 embeddable into other applications. The main objective was to make it 656 embeddable into other applications. The main objective was to make it
635 easier to make simple HTTP frontends in Perl for Perl programs and Perl modules. 657 easier to make simple HTTP frontends in Perl for Perl programs and Perl modules.
636 658
637AnyEvent-Feed cpan-elmex git-pod(lib/AnyEvent/Feed.pm,) git-co(Changes) list(anyevent) 659AnyEvent-Feed cpan-elmex git-pod(lib/AnyEvent/Feed.pm,) git-co(Changes) list(anyevent) irc(anyevent)
638 A RSS/Atom Feed aggregator. 660 A RSS/Atom Feed aggregator.
639 661
640 This module uses AnyEvent::HTTP and XML::Feed to fetch and parse RSS and Atom 662 This module uses AnyEvent::HTTP and XML::Feed to fetch and parse RSS and Atom
641 feeds. It provides aggregation (detecting of new entries) to provide an easy 663 feeds. It provides aggregation (detecting of new entries) to provide an easy
642 interface for simple feed readers. 664 interface for simple feed readers.
643 665
644AnyEvent-Twitter cpan-elmex git-pod(lib/AnyEvent/Twitter.pm,) git-co(Changes) list(anyevent) 666AnyEvent-Twitter cpan-elmex git-pod(lib/AnyEvent/Twitter.pm,) git-co(Changes) list(anyevent) irc(anyevent)
645 Implementation of the Twitter API for AnyEvent. 667 Implementation of the Twitter API for AnyEvent.
646 668
647 Provides a simple non-blocking API to access information (aka tweets) provided 669 Provides a simple non-blocking API to access information (aka tweets) provided
648 by <a href="http://www.twitter.com">Twitter</a>. 670 by <a href="http://www.twitter.com">Twitter</a>.
649 671
650AnyEvent-IGS cpan-elmex git-pod(lib/AnyEvent/IGS.pm,) git-co(Changes) list(anyevent) 672AnyEvent-IGS cpan-elmex git-pod(lib/AnyEvent/IGS.pm,) git-co(Changes) list(anyevent) irc(anyevent)
651 A Perl module that interfaces to the International Go Server. 673 A Perl module that interfaces to the International Go Server.
652 674
653 This module is an Anyevent-based interface to the International Go Server 675 This module is an AnyEvent-based interface to the International Go Server
654 protocol. 676 protocol.
655 677
656AnyEvent-EditText cpan-elmex git-pod(lib/AnyEvent/EditText.pm,) git-co(Changes) list(anyevent) 678AnyEvent-EditText cpan-elmex git-pod(lib/AnyEvent/EditText.pm,) git-co(Changes) list(anyevent) irc(anyevent)
657 A Perl module which allows editing any text via an editor in a separate process. 679 A Perl module which allows editing any text via an editor in a separate process.
658 680
659 A utility Perl module that will start a terminal/editor for you and will 681 A utility Perl module that will start a terminal/editor for you and will
660 wait non-blocking for you to finish editing that file. Very useful to embed 682 wait non-blocking for you to finish editing that file. Very useful to embed
661 content edititing in event based programs that have a AnyEvent compatible 683 content edititing in event based programs that have a AnyEvent compatible
695 allows easy decoding of multipart mime, uuencode and a whole lot of 717 allows easy decoding of multipart mime, uuencode and a whole lot of
696 differently encoded messages. You basically throw files at it, and 718 differently encoded messages. You basically throw files at it, and
697 it extracts the files in them. This module is used by the popular <a 719 it extracts the files in them. This module is used by the popular <a
698 href="www.amavis.org">amavis virus scanner</a>. 720 href="www.amavis.org">amavis virus scanner</a>.
699 721
700Coro cpan cvs-co(Changes) cvs-pod(Coro.pm,) cvs-pod(Coro/AIO.pm,Coro::AIO) cvs-pod(Coro/AnyEvent.pm,Coro::AnyEvent) cvs-pod(Coro/BDB.pm,Coro::BDB) cvs-pod(Coro/Channel.pm,Coro::Channel) cvs-pod(Coro/Debug.pm,Coro::Debug) cvs-pod(Coro/EV.pm,Coro::EV) cvs-pod(Coro/Event.pm,Coro::Event) cvs-pod(Coro/Handle.pm,Coro::Handle) cvs-pod(Coro/LWP.pm,Coro::LWP) cvs-pod(Coro/MakeMaker.pm,Coro::MakeMaker) cvs-pod(Coro/RWLock.pm,Coro::RWLock) cvs-pod(Coro/Select.pm,Coro::Select) cvs-pod(Coro/Semaphore.pm,Coro::Semaphore) cvs-pod(Coro/SemaphoreSet.pm,Coro::SemaphoreSet) cvs-pod(Coro/Signal.pm,Coro::Signal) cvs-pod(Coro/Socket.pm,Coro::Socket) cvs-pod(Coro/Specific.pm,Coro::Specific) cvs-pod(Coro/State.pm,Coro::State) cvs-pod(Coro/Storable.pm,Coro::Storable) cvs-pod(Coro/Timer.pm,Coro::Timer) cvs-pod(Coro/Util.pm,Coro::Util) list(anyevent) 722Coro cpan cvs-co(Changes) cvs-pod(Coro.pm,) cvs-pod(Coro/AIO.pm,Coro::AIO) cvs-pod(Coro/AnyEvent.pm,Coro::AnyEvent) cvs-pod(Coro/BDB.pm,Coro::BDB) cvs-pod(Coro/Channel.pm,Coro::Channel) cvs-pod(Coro/Debug.pm,Coro::Debug) cvs-pod(Coro/EV.pm,Coro::EV) cvs-pod(Coro/Event.pm,Coro::Event) cvs-pod(Coro/Handle.pm,Coro::Handle) cvs-pod(Coro/LWP.pm,Coro::LWP) cvs-pod(Coro/MakeMaker.pm,Coro::MakeMaker) cvs-pod(Coro/RWLock.pm,Coro::RWLock) cvs-pod(Coro/Select.pm,Coro::Select) cvs-pod(Coro/Semaphore.pm,Coro::Semaphore) cvs-pod(Coro/SemaphoreSet.pm,Coro::SemaphoreSet) cvs-pod(Coro/Signal.pm,Coro::Signal) cvs-pod(Coro/Socket.pm,Coro::Socket) cvs-pod(Coro/Specific.pm,Coro::Specific) cvs-pod(Coro/State.pm,Coro::State) cvs-pod(Coro/Storable.pm,Coro::Storable) cvs-pod(Coro/Timer.pm,Coro::Timer) cvs-pod(Coro/Util.pm,Coro::Util) list(anyevent) irc(anyevent)
701 A large Perl module family that implements cooperative multitasking in 723 A large Perl module family that implements cooperative multitasking in
702 Perl. It supports filehandle and event abstraction and also implements 724 Perl. It supports filehandle and event abstraction and also implements
703 continuations as well as the necessary directives to implement a slightly 725 continuations as well as the necessary directives to implement a slightly
704 limited call/cc in Perl. 726 limited call/cc in Perl.
705 727
860 882
861 This Perl module represents a Go game. It can check for valid moves, 883 This Perl module represents a Go game. It can check for valid moves,
862 capture stones, stores move history and can represent a variety of 884 capture stones, stores move history and can represent a variety of
863 additional annotations (circles, labels, grayed-out stones etc.). 885 additional annotations (circles, labels, grayed-out stones etc.).
864 886
887Games-Sokoban cpan cvs-pod(Sokoban.pm,) cvs-co(Changes)
888 A perl module to load/transform/save sokoban levels in various formats.
889
890 Supports xsb (text), rle, sokevo and a small "binpack" format for input and
891 output and can normalise levels as well as calculate unique IDs.
892
865Gtk2-GoBoard cpan cvs-pod(GoBoard.pm,) cvs-co(Changes) 893Gtk2-GoBoard cpan cvs-pod(GoBoard.pm,) cvs-co(Changes)
866 A Perl module implementing a go board widget. 894 A Perl module implementing a go board widget.
867 895
868 This Perl module implements a beautiful go board (see <a 896 This Perl module implements a beautiful go board (see <a
869 href="http://data.plan9.de/kgsuemel.jpg">example</a>), implemented as a 897 href="http://data.plan9.de/kgsuemel.jpg">example</a>), implemented as a

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines