package XML::RSS::Headline::PerlJobs; use strict; use warnings; use base qw(XML::RSS::Headline); =head1 NAME XML::RSS::Headline::PerlJobs - XML::RSS::Headline Example Subclass =head1 VERSION 2.2 =cut our $VERSION = 2.2; =head1 SYNOPSIS You can also subclass XML::RSS::Headline to provide a 'multiline' RSS headline based on additional information inside the RSS Feed. Here is an example for the Perl Jobs (jobs.perl.org) RSS feed by simply passing in the C class name. use XML::RSS::Feed; use XML::RSS::Headline::PerlJobs; use LWP::Simple qw(get); my $feed = XML::RSS::Feed->new( name => "perljobs", url => "http://jobs.perl.org/rss/standard.rss", hlobj => "XML::RSS::Headline::PerlJobs", ); while (1) { $feed->parse(get($feed->url)); print $_->headline . "\n" for $feed->late_breaking_news; sleep($feed->delay); } Here is the output from rssbot on irc.perl.org in channel #news (which uses these modules) + Part Time Perl Brian Koontz - United States, TX, Dallas Part time, Independent contractor (project-based) http://jobs.perl.org/job/950 =head1 MUTAITED METHOD =head2 $headline->item( $item ) Init the object for a parsed RSS item returned by L. =cut sub item { my ($self,$item) = @_; $self->SUPER::item($item); # set url and description my $key = 'http://jobs.perl.org/rss/'; my $name = $item->{$key}{company_name} || ""; my $location = $item->{$key}{location} || "Unknown Location"; my $hours = $item->{$key}{hours} || "Unknown Hours"; my $terms = $item->{$key}{employment_terms} || "Unknown Terms"; my $name_location = $name ? $name . " - " . $location : $location; $self->headline("$item->{title}\n$name_location\n$hours, $terms"); } =head1 AUTHOR Jeff Bisbee, C<< >> =head1 BUGS Please report any bugs or feature requests to C, or through the web interface at L. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes. =head1 SUPPORT You can find documentation for this module with the perldoc command. perldoc XML::RSS::Headline::PerlJobs You can also look for information at: =over 4 =item * AnnoCPAN: Annotated CPAN documentation L =item * CPAN Ratings L =item * RT: CPAN's request tracker L =item * Search CPAN L =back =head1 ACKNOWLEDGEMENTS Special thanks to Rocco Caputo, Martijn van Beers, Sean Burke, Prakash Kailasa and Randal Schwartz for their help, guidance, patience, and bug reports. Guys thanks for actually taking time to use the code and give good, honest feedback. =head1 COPYRIGHT & LICENSE Copyright 2006 Jeff Bisbee, all rights reserved. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =head1 SEE ALSO L, L, L, L, L =cut 1;