| OPML(3pm) | User Contributed Perl Documentation | OPML(3pm) | 
XML::OPML - creates and updates OPML (Outline Processor Markup Language) files
# Create an OPML file
 use XML::OPML;
 my $opml = new XML::OPML(version => "1.1");
 $opml->head(
             title => 'mySubscription',
             dateCreated => 'Mon, 16 Feb 2004 11:35:00 GMT',
             dateModified => 'Sat, 05 Mar 2004 09:02:00 GMT',
             ownerName => 'michael szul',
             ownerEmail => 'opml-dev@blogenstein.com',
             expansionState => '',
             vertScrollState => '',
             windowTop => '',
             windowLeft => '',
             windowBottom => '',
             windowRight => '',
           );
 $opml->add_outline(
                 text => 'Warren Ellis Speaks Clever',
                 description => 'Warren Ellis\' Personal Weblog',
                 title => 'Warren Ellis Speaks Clever',
                 type => 'rss',
                 version => 'RSS',
                 htmlUrl => 'http://www.diepunyhumans.com ',
                 xmlUrl => 'http://www.diepunyhumans.com/index.rdf ',
               );
 $opml->add_outline(
                 text => 'raelity bytes',
                 descriptions => 'The raelity bytes weblog.',
                 title => 'raelity bytes',
                 type => 'rss',
                 version => 'RSS',
                 htmlUrl => 'http://www.raelity.org ',
                 xmlUrl => 'http://www.raelity.org/index.rss10 ',
               );
# Create embedded outlines
 $opml->add_outline(
                     opmlvalue => 'embed',
                     outline_one => {
                                      text => 'The first embedded outline',
                                      description => 'The description for the first embedded outline',
                                    },
                     outline_two => {
                                      text => 'The second embedded outline',
                                      description => 'The description for the second embedded outline',
                                    },
                     outline_three => {
                                        opmlvalue => 'embed',
                                        em_outline_one => {
                                                            text => 'I'm too lazy to come up with real examples',
                                                          },
                                        em_outline_two => {
                                                            text => 'so you get generic text',
                                                          },
                                      },
                   );
# Create an embedded outline with attributes in the encasing <outline> tag
 $opml->add_outline(
                     opmlvalue => 'embed',
                     description => 'now we can have attributes in this tag',
                     title => 'attributes',
                     outline_with_atts => {
                                            text => 'Eat Your Wheaties',
                                            description => 'Cereal is the breakfast of champion programmers',
                                          },
                   );
# Save it as a string.
$opml->as_string();
# Save it to a file.
 $opml->save('mySubscriptions.opml');
# Update your OPML file.
use XML::OPML; my $opml = new XML::OPML;
# Parse the file.
 $opml->parse('mySubscriptions.opml');
# Or optionally from a variable.
my $content = $opml->as_string(); $opml->parse($content);
# Update it appending to the end of the outline
 $opml->add_outline(
                    text => 'Neil Gaiman\'s Journal',
                    description =>'Neil Gaiman\'s Journal',
                    title => 'Neil Gaiman\'s Journal',
                    type => 'rss',
                    version => 'RSS',
                    htmlUrl => 'http://www.neilgaiman.com/journal/journal.asp ',
                    xmlUrl => 'http://www.neilgaiman.com/journal/blogger_rss.xml ',
                  );
# Update it inserting the outline into a specific group (note the group parameter)
 $opml->insert_outline(
                       group => 'occult',
                       text => 'madghoul.com',
                       description => 'the dark night of the soul',
                       title => 'madghoul.com',
                       type => 'rss',
                       version => 'RSS',
                       htmlUrl => 'http://www.madghoul.com ',
                       xmlUrl => 'http://www.madghoul.com/cgi-bin/fearsome/fallout/index.rss10 ',
                      );
This experimental module is designed to allow for easy creation and manipulation of OPML files. OPML files are most commonly used for the sharing of blogrolls or subscriptions - an outlined list of what other blogs an Internet blogger reads. RSS Feed Readers such as AmphetaDesk ( http://www.disobey.com/amphetadesk ) use *.opml files to store your subscription information for easy access.
This is purely experimental at this point and has a few limitations. This module may now support attributes in the <outline> element of an embedded hierarchy, but these are limited to the following attributes: date_added, date_downloaded, description, email, filename, htmlurl, keywords, text, title, type, version, and xmlurl. Additionally, the following alternate spellings are also supported: dateAdded, dateDownloaded, htmlUrl, and xmlUrl.
Rather than reinvent the wheel, this module was modified from the XML::RSS module, so functionality works in a similar way.
Source code is available at the development site at http://opml.blogenstein.com . Any contributions or improvements are greatly appreciated. You may also want to visit http://www.madghoul.com to see a whole lot of perl coding at work.
michael szul <opml-dev@blogenstein.com>
copyright (c) 2004 michael szul <opml-dev@blogenstein.com>
XML::OPML is free software. It may be redistributed and/or modified under the same terms as Perl.
michael szul <opml-dev@blogenstein.com> matt cashner <sungo@eekeek.org> ricardo signes <rjbs@cpan.org> gergely nagy <algernon@bonehunter.rulez.org>
| 2022-12-04 | perl v5.36.0 |