7 Given a URL of an Atom or RSS feed or a filename of an already downloaded
8 feed, this script will try to parse it and print out what it understands
17 die "Usage: $0 FILE|URL\n" if not $src;
20 if ($src =~ m{^https?://}) {
21 $source = URI->new($src);
24 die "'$source' does not look like a URL and it does not exist on the file-system either.\n";
28 my $feed = XML::Feed->parse( $source ) or die XML::Feed->errstr;
29 say 'Title: ' . ($feed->title // '');
30 say 'Tagline: ' . ($feed->tagline // '');
31 say 'Format: ' . ($feed->format // '');
32 say 'Author: ' . ($feed->author // '');
33 say 'Link: ' . ($feed->link // '');
34 say 'Base: ' . ($feed->base // '');
35 say 'Language: ' . ($feed->language // '');
36 say 'Copyright: ' . ($feed->copyright // '');
37 say 'Modified: ' . ($feed->modified // ''); # DateTime object
38 say 'Generator: ' . ($feed->generator // '');
40 for my $entry ($feed->entries) {
42 say ' Link: ' . ($entry->link // '');
43 say ' Author: ' . ($entry->author // '');
44 say ' Title: ' . ($entry->title // '');
45 say ' Caregory: ' . ($entry->category // '');
46 say ' Id: ' . ($entry->id // '');
47 say ' Issued: ' . ($entry->issued // ''); # DateTime object
48 say ' Modified: ' . ($entry->modified // ''); # DateTime object
49 say ' Lat: ' . ($entry->lat // '');
50 say ' Long: ' . ($entry->long // '');
51 say ' Format: ' . ($entry->format // '');
52 say ' Tags: ' . ($entry->tags // '');
53 say ' Enclosure: ' . ($entry->enclosure // '');
54 say ' Summary: ' . ($entry->summary->body // '');
55 say ' Content: ' . ($entry->content->body // '');