NAME
CPAN::LinksToDocs::No404s::Remember - same as CPAN::LinksToDocs::No404s with persistent storage of working links in SQLite database
SYNOPSIS
use strict;
use warnings;
use CPAN::LinksToDocs::No404s::Remember;
my $linker = CPAN::LinksToDocs::No404s::Remember->new;
for ( @{ $linker->link_for('map,grep,RE,OOP') } ) {
print "$_\n";
}
DESCRIPTION
The module provides means to get links to documentation on http://search.cpan.org by giving it "tags". There are a few tags which group several links together (e.g. RE
, REF
or OOP
tags). The base code of this module is what is used under the hood of http://tnx.nl/404 website. Thanks to Juerd Waalboer you can now use it too :)
The module is similiar to CPAN::LinksToDocs::No404s module, except this one will store working links for non-predefined tags in a SQLite database as to speed up any subsequent requests for the same tag.
CONSTRUCTOR
new
my $linker = CPAN::LinksToDocs::No404s::Remember->new;
my $linker2 = CPAN::LinksToDocs::No404s::Remember->new(
tags => {
some => 'http://there.somewhere',
map => 'http://some_custom.link.to.map.function',
BOTH => 'some,map', # will return 'some' and 'map' together
},
db_file => 'cpan_links_to_docs.db',
message_404 => 'NO DOCS!',
timeout => 20,
# or
ua => LWP::UserAgent->new( timeout => 20, agent => 'foos!' ),
);
Returns a freshly baked CPAN::LinksToDocs::No404s::Remember
object. Takes several optional arguments which are as follows;
tags
->new(
tags => {
some => 'http://there.somewhere',
map => 'http://some_custom.link.to.map.function',
BOTH => 'some,map', # will return 'some' and 'map' together
},
);
Optional. The tags
argument takes a hashref as a value. The keys of this hashref will be "tags" which you can use in the link_for
method. The values is what you'll get in return arrayref. Note: if the value contains a comma it will be split on and the elements of that split will be considered as tags, thus you can use predefined tags to group several links together. Defaults to: nothing, only predefined tags mentioned in TAGS
section.
db_file
->new( db_file => 'cpan_links_to_docs.db' );
Optional. Specifies the name of the file where the module should store the working links. This will be an SQLite database so you could possibly edit it with other tools. Defaults to: cpan_links_to_docs.db
message_404
->new( message_404 => 'NO DOCS!' );
Optional. If the "tag" was not found in predefined tags (see link_for
method and TAGS
section) the "link" for the tag will contain whatever you specify as message_404
argument to the constructor. Defaults to: Not found
timeout
->new( timeout => 10 );
Optional. Specifies the timeout
argument of LWP::UserAgent's constructor, which is used for checking 404s. Defaults to: 30
seconds.
ua
->new( ua => LWP::UserAgent->new( agent => 'Foos!' ) );
Optional. If the timeout
argument is not enough for your needs of mutilating the LWP::UserAgent object used for checking, feel free to specify the ua
argument which takes an LWP::UserAgent object as a value. Note: the timeout
argument to the constructor will not do anything if you specify the ua
argument as well. Defaults to: plain boring default LWP::UserAgent object with timeout
argument set to whatever CPAN::LinksToDocs::No404s::Remember
' timeout
argument is set to as well as agent
argument is set to mimic Firefox.
METHODS
link_for
my $links_ref = $linker->link_for('map,grep,some,BOTH');
Returns a (possibly empty) arrayref of links to documentation. Takes one mandatory scalar argument which is one or more "tags" separated by commas. See TAGS section below for possible tags. If the tag was not found in predefined tags the returning link will be http://search.cpan.org/perldoc?TAG_YOU_GAVE_THAT_WAS_NOT_FOUND
this way you can link to custom made modules available on CPAN. However, the module will connect to http://search.cpan.org/ and make sure that module exists. If the module doesn't exist the "link" for this tag will be your message_404
(see constructor). If a network error occured while checking the "link" will match qr/^Network error:/
and will contain the description of the error.
tags
my $tags_ref = $linker->tags;
$tags_ref->{foos} = 'http://bars/';
$linker->tags( $tags_ref );
Returns a hashref of currently set tags. Takes one optional argument which must be a hashref of tags. The format is the same as the tags
argument to the constructor.
response
my $last_response_obj = $linker->response;
Takes no arguments, returns the HTTP::Response object which was obtained while checking a non-predefined "tag".
message_404
my $old_message = $linker->message_404;
$linker->message_404('YOU GOT 404!');
Returns a currently set message_404
message (see constructor's message_404
argument's description). Takes one optional argument. If you call it with an argument, the argument you provide will be a new message_404
message.
dbh
my $dbh = $linker->dbh;
Takes no arguments. Returns DBI's database handle used for stuffing working links into the database.
ua
my $old_LWP_UA_obj = $linker->ua;
$linker->ua( LWP::UserAgent->new( timeout => 10, agent => 'foos' );
Returns a currently used LWP::UserAgent object used for checking 404s. Takes one optional argument which must be an LWP::UserAgent object, and the object you specify will be used in any subsequent checks of non-predefined "tags".
TAGS
The module has a LOT of predefined tags... and I am shamelessly going to semi-quote Juerd's site:
You can leave out the redundant perl
part. Except for perltie
, because tie
is also a function.
The following groups and special "tags" are known:
FAQ
, MOD
, OO
, OOP
, RE
, REF
, UNI
, bp
, cws
, include
, kp
, perlpodtut
, perltut
, podtut
, sfb
, tut
, tutorial
.
S\d\d
, A\d\d
and E\d\d
for Perl 6 language design documents.
Below are the known tags for CPAN::LinksToDocs::No404s::Remember module:
my @perldoc = qw(
perl perl5004delta perl5005delta perl5100delta perl561delta perl56delta
perl570delta perl571delta perl572delta perl573delta perl581delta
perl582delta perl583delta perl584delta perl585delta perl586delta
perl587delta perl588delta perl58delta perl590delta perl591delta
perl592delta perl593delta perl594delta perl595delta perl5db.pl perlXStut
perlamiga perlapi perlapio perlartistic perlbook perlboot perlbot perlbug
perlcall perlce perlcheat perlclib perlcn perlcommunity perlcompile
perldata perldbmfilter perldebguts perldebtut perldebug perldelta perldgux
perldiag perldoc perldos perldsc perlebcdic perlembed perlfaq perlfaq1
perlfaq2 perlfaq3 perlfaq4 perlfaq5 perlfaq6 perlfaq7 perlfaq8 perlfaq9
perlfilter perlfork perlform perlfunc perlglob.bat perlglossary perlgpl
perlguts perlhack perlhist perlintern perlintro perliol perlipc perlivp
perljp perlko perllexwarn perllocale perllol perlmod perlmodinstall
perlmodlib perlmodstyle perlnetware perlnewmod perlnumber perlobj perlop
perlopentut perlos2 perlothrtut perlpacktut perlplan9 perlpod perlpodspec
perlport perlpragma perlre perlreapi perlrebackslash perlrecharclass
perlref perlreftut perlreguts perlrequick perlreref perlretut perlrun
perlsec perlstyle perlsub perlsyn perlthrtut perltie perltoc perltodo
perltooc perltoot perltrap perltw perlunicode perlunifaq perluniintro
perlunitut perlutil perluts perlvar perlvms perlwin32 perlxs
);
my @perlfunc = qw(
abs accept alarm atan2 bind binmode bless break caller chdir chmod chomp
chop chown chr chroot close closedir connect continue cos crypt dbmclose
dbmopen defined delete die do dump each endgrent endhostent endnetent
endprotoent endpwent endservent eof eval exec exists exit exp fcntl fileno
flags flock fork format formline getc getgrent getgrgid getgrnam
gethostbyaddr gethostbyname gethostent getlogin getnetbyaddr getnetbyname
getnetent getpeername getpgrp getppid getpriority getprotobyname
getprotobynumber getprotoent getpwent getpwnam getpwuid getservbyname
getservbyport getservent getsockname getsockopt glob gmtime goto grep hex
import index int ioctl join keys kill last lc lcfirst length link listen
local localtime lock log lstat m map mkdir msgctl msgget msgrcv msgsnd my
next no oct open opendir ord order our pack package pipe pop pos precision
print printf prototype push qq qr q qw qx quotemeta rand read readdir
readline readlink readpipe recv redo ref rename require reset return
reverse rewinddir rindex rmdir s say scalar seek seekdir select semctl
semget semop send setgrent sethostent setnetent setpgrp setpriority
setprotoent setpwent setservent setsockopt shift shmctl shmget shmread
shmwrite shutdown sin size sleep socket socketpair sort splice split
sprintf sqrt srand stat state study sub substr symlink syscall sysopen
sysread sysseek system syswrite tell telldir tie tied time times tr
truncate uc ucfirst umask undef unlink unpack unshift untie use utime
values vec vector wait waitpid wantarray warn write -X y
);
my @stdmods = qw(
AnyDBM_File Archive::Extract Archive::Tar Archive::Tar::File
Attribute::Handlers attributes attrs AutoLoader AutoSplit autouse B base
B::Concise B::Debug B::Deparse Benchmark bigint bignum bigrat blib B::Lint
B::Showlex B::Terse B::Xref bytes Carp Carp::Heavy CGI CGI::Apache
CGI::Carp CGI::Cookie CGI::Fast CGI::Pretty CGI::Push CGI::Switch CGI::Util
charnames Class::ISA Class::Struct Compress::Raw::Zlib Compress::Zlib
Config constant CORE CPAN CPAN::API::HOWTO CPAN::FirstTime CPAN::Kwalify
CPAN::Nox CPANPLUS CPANPLUS::Dist::Base CPANPLUS::Dist::Sample
CPANPLUS::Shell::Classic CPANPLUS::Shell::Default::Plugins::HOWTO
CPAN::Version Cwd Data::Dumper DB DB_File DBM_Filter DBM_Filter::compress
DBM_Filter::encode DBM_Filter::int32 DBM_Filter::null DBM_Filter::utf8
Devel::DProf Devel::InnerPackage Devel::Peek Devel::SelfStubber diagnostics
Digest Digest::base Digest::file Digest::MD5 Digest::SHA DirHandle
Dumpvalue DynaLoader Encode Encode::Alias Encode::Byte Encode::CJKConstants
Encode::CN Encode::CN::HZ Encode::Config Encode::EBCDIC Encode::Encoder
Encode::Encoding Encode::GSM0338 Encode::Guess Encode::JP Encode::JP::H2Z
Encode::JP::JIS7 Encode::KR Encode::KR::2022_KR Encode::MIME::Header
Encode::MIME::Name Encode::PerlIO Encode::Supported Encode::Symbol
Encode::TW Encode::Unicode Encode::Unicode::UTF7 encoding
encoding::warnings English Env Errno Exporter Exporter::Heavy
ExtUtils::CBuilder ExtUtils::CBuilder::Platform::Windows ExtUtils::Command
ExtUtils::Command::MM ExtUtils::Constant ExtUtils::Constant::Base
ExtUtils::Constant::Utils ExtUtils::Constant::XS ExtUtils::Embed
ExtUtils::Install ExtUtils::Installed ExtUtils::Liblist ExtUtils::MakeMaker
ExtUtils::MakeMaker::bytes ExtUtils::MakeMaker::Config
ExtUtils::MakeMaker::FAQ ExtUtils::MakeMaker::Tutorial
ExtUtils::MakeMaker::vmsish ExtUtils::Manifest ExtUtils::Mkbootstrap
ExtUtils::Mksymlists ExtUtils::MM ExtUtils::MM_AIX ExtUtils::MM_Any
ExtUtils::MM_BeOS ExtUtils::MM_Cygwin ExtUtils::MM_DOS ExtUtils::MM_MacOS
ExtUtils::MM_NW5 ExtUtils::MM_OS2 ExtUtils::MM_QNX ExtUtils::MM_Unix
ExtUtils::MM_UWIN ExtUtils::MM_VMS ExtUtils::MM_VOS ExtUtils::MM_Win32
ExtUtils::MM_Win95 ExtUtils::MY ExtUtils::Packlist ExtUtils::ParseXS
ExtUtils::testlib Fatal Fcntl feature fields File::Basename FileCache
File::CheckTree File::Compare File::Copy File::DosGlob File::Fetch
File::Find File::Glob File::GlobMapper FileHandle File::Path File::Spec
File::Spec::Cygwin File::Spec::Epoc File::Spec::Functions File::Spec::Mac
File::Spec::OS2 File::Spec::Unix File::Spec::VMS File::Spec::Win32
File::stat File::Temp filetest Filter::Simple Filter::Util::Call FindBin
GDBM_File Getopt::Long Getopt::Std Hash::Util Hash::Util::FieldHash
I18N::Collate I18N::Langinfo I18N::LangTags I18N::LangTags::Detect
I18N::LangTags::List if integer IO IO::Compress::Base IO::Compress::Deflate
IO::Compress::Gzip IO::Compress::RawDeflate IO::Compress::Zip IO::Dir
IO::File IO::Handle IO::Pipe IO::Poll IO::Seekable IO::Select IO::Socket
IO::Socket::INET IO::Socket::UNIX IO::Uncompress::AnyInflate
IO::Uncompress::AnyUncompress IO::Uncompress::Base IO::Uncompress::Gunzip
IO::Uncompress::Inflate IO::Uncompress::RawInflate IO::Uncompress::Unzip
IO::Zlib IPC::Cmd IPC::Open2 IPC::Open3 IPC::SysV IPC::SysV::Msg
IPC::SysV::Semaphore less lib List::Util locale Locale::Constants
Locale::Country Locale::Currency Locale::Language Locale::Maketext
Locale::Maketext::Simple Locale::Maketext::TPJ13 Locale::Script
Log::Message Log::Message::Config Log::Message::Handlers Log::Message::Item
Math::BigFloat Math::BigInt Math::BigInt::Calc Math::BigInt::CalcEmu
Math::BigInt::FastCalc Math::BigRat Math::Complex Math::Trig Memoize
Memoize::AnyDBM_File Memoize::Expire Memoize::ExpireFile
Memoize::ExpireTest Memoize::NDBM_File Memoize::SDBM_File Memoize::Storable
MIME::Base64 MIME::QuotedPrint Module::Build Module::Build::API
Module::Build::Authoring Module::Build::Base Module::Build::Compat
Module::Build::ConfigData Module::Build::Cookbook Module::Build::ModuleInfo
Module::Build::Notes Module::Build::Platform::aix
Module::Build::Platform::Amiga Module::Build::Platform::cygwin
Module::Build::Platform::darwin Module::Build::Platform::Default
Module::Build::Platform::EBCDIC Module::Build::Platform::MacOS
Module::Build::Platform::MPEiX Module::Build::Platform::os2
Module::Build::Platform::RiscOS Module::Build::Platform::Unix
Module::Build::Platform::VMS Module::Build::Platform::VOS
Module::Build::Platform::Windows Module::Build::PPMMaker
Module::Build::YAML Module::CoreList Module::Load Module::Load::Conditional
Module::Loaded Module::Pluggable Module::Pluggable::Object mro NDBM_File
Net::Cmd Net::Config Net::Domain Net::FTP Net::hostent Net::libnetFAQ
Net::netent Net::Netrc Net::NNTP Net::Ping Net::POP3 Net::protoent
Net::servent Net::SMTP Net::Time NEXT O ODBM_File Opcode open ops overload
Package::Constants Params::Check PerlIO PerlIO::encoding PerlIO::scalar
PerlIO::via PerlIO::via::QuotedPrint Pod::Checker Pod::Escapes Pod::Find
Pod::Functions Pod::Html Pod::InputObjects Pod::LaTeX Pod::Man
Pod::ParseLink Pod::Parser Pod::ParseUtils Pod::Perldoc::ToChecker
Pod::Perldoc::ToMan Pod::Perldoc::ToNroff Pod::Perldoc::ToPod
Pod::Perldoc::ToRtf Pod::Perldoc::ToText Pod::Perldoc::ToTk
Pod::Perldoc::ToXml Pod::Plainer Pod::PlainText Pod::Select Pod::Simple
Pod::Simple::Checker Pod::Simple::Debug Pod::Simple::DumpAsText
Pod::Simple::DumpAsXML Pod::Simple::HTML Pod::Simple::HTMLBatch
Pod::Simple::LinkSection Pod::Simple::Methody Pod::Simple::PullParser
Pod::Simple::PullParserEndToken Pod::Simple::PullParserStartToken
Pod::Simple::PullParserTextToken Pod::Simple::PullParserToken
Pod::Simple::RTF Pod::Simple::Search Pod::Simple::SimpleTree
Pod::Simple::Subclassing Pod::Simple::Text Pod::Simple::TextContent
Pod::Simple::XMLOutStream Pod::Text Pod::Text::Color Pod::Text::Overstrike
Pod::Text::Termcap Pod::Usage POSIX re Safe Scalar::Util SDBM_File
Search::Dict SelectSaver SelfLoader Shell sigtrap Socket sort Storable
strict subs Switch Symbol Sys::Hostname Sys::Syslog
Sys::Syslog::win32::Win32 Term::ANSIColor Term::Cap Term::Complete
Term::ReadLine Term::UI Test Test::Builder Test::Builder::Module
Test::Builder::Tester Test::Builder::Tester::Color Test::Harness
Test::Harness::Assert Test::Harness::Iterator Test::Harness::Point
Test::Harness::Results Test::Harness::Straps Test::Harness::TAP
Test::Harness::Util Test::More Test::Simple Test::Tutorial Text::Abbrev
Text::Balanced Text::ParseWords Text::Soundex Text::Tabs Text::Wrap Thread
Thread::Queue threads Thread::Semaphore threads::shared Tie::Array
Tie::File Tie::Handle Tie::Hash Tie::Hash::NamedCapture Tie::Memoize
Tie::RefHash Tie::Scalar Tie::SubstrHash Time::gmtime Time::HiRes
Time::Local Time::localtime Time::Piece Time::Piece::Seconds Time::tm
Unicode::Collate Unicode::Normalize Unicode::UCD UNIVERSAL User::grent
User::pwent utf8 vars version vmsish warnings warnings::register Win32
Win32API::File Win32CORE XS::APItest XSLoader XS::Typemap
);
my %tags = (
UNI => 'perlunitut,perlunifaq,Encode,perluniintro,perlunicode,utf8',
RE => 'perlrequick,perlretut,perlre,perlreref',
REF => 'perlreftut,perllol,perldsc,perlref',
OO => 'perlboot,perltoot,perltooc,perlbot',
OOP => 'perlboot,perltoot,perltooc,perlbot',
FAQ => (join ',', "perlfaq1" .. "perlfaq9"),
MOD => 'perlmod,perlmodlib,perlmodstyle,perlmodinstall,perlnewmod',
kp => 'http://pastebot.nd.edu/perlhelp',
bp => 'http://learn.perl.org/library/beginning_perl/',
cws => 'http://perl.plover.com/FAQs/Namespaces.html',
sfb => 'http://perl.plover.com/FAQs/Buffering.html',
include => 'http://perlmonks.org/?node_id=393426',
podtut => 'http://juerd.nl/site.plp/perlpodtut',
perlpodtut => 'http://juerd.nl/site.plp/perlpodtut',
perltut => 'http://www.steve.gb.com/perl/tutorial.html',
tut => 'http://www.steve.gb.com/perl/tutorial.html',
tutorial => 'http://www.steve.gb.com/perl/tutorial.html',
);
SEE ALSO
http://tnx.nl/404, CPAN::LinksToDocs, CPAN::LinksToDocs::No404s::Remember, POE::Component::IRC::Plugin::CPAN::LinksToDocs, POE::Component::CPAN::LinksToDocs::No404s::Remember POE::Component::CPAN::LinksToDocs::No404s::Remember, POE::Component::IRC::Plugin::CPAN::LinksToDocs::No404s::Remember, POE::Component::IRC::Plugin::CPAN::LinksToDocs::No404s::Remember
AUTHOR
Thanks to Juerd Waalboer, the author of http://tnx.nl/404 for providing base code.
Zoffix Znet, <zoffix at cpan.org>
(http://zoffix.com, http://haslayout.net)
BUGS
Please report any bugs or feature requests to bug-cpan-linkstodocs-no404s-remember at rt.cpan.org
, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=CPAN-LinksToDocs-No404s-Remember. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
SUPPORT
You can find documentation for this module with the perldoc command.
perldoc CPAN::LinksToDocs::No404s::Remember
You can also look for information at:
RT: CPAN's request tracker
http://rt.cpan.org/NoAuth/Bugs.html?Dist=CPAN-LinksToDocs-No404s-Remember
AnnoCPAN: Annotated CPAN documentation
CPAN Ratings
http://cpanratings.perl.org/d/CPAN-LinksToDocs-No404s-Remember
Search CPAN
http://search.cpan.org/dist/CPAN-LinksToDocs-No404s-Remember
COPYRIGHT & LICENSE
Copyright 2008 Zoffix Znet, all rights reserved.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.