## XML::Generator::RSS10::lgcl ## An extension to Dave Rolsky's XML::Generator::RSS10 to handle categories in the UK Local Government Category List ## To be used in conjunction with XML::Generator::RSS10::egms ## Written by Andrew Green, Article Seven, http://www.article7.co.uk/ ## Sponsored by Woking Borough Council, http://www.woking.gov.uk/ ## Last updated: Wednesday, 8 September 2004 package XML::Generator::RSS10::lgcl; $VERSION = '0.01'; use strict; use Carp; use base 'XML::Generator::RSS10::Module'; 1; #### sub NamespaceURI { 'http://www.esd.org.uk/standards/lgcl/1.03/lgcl-schema#' } #### sub category { my ($self,$rss,$category_value) = @_; my $camelcategory = $self->_camelcase($category_value); $rss->_start_element('lgcl',$camelcategory); $rss->_newline_if_pretty; $rss->_element_with_data('rdf','value',$category_value); $rss->_newline_if_pretty; $rss->_end_element('lgcl',$camelcategory); $rss->_newline_if_pretty; } #### sub _camelcase { my ($self,$cat) = @_; $cat =~ s/\s*(\w+)\s*/\u\L$1/g; return $cat; } #### __END__ =head1 NAME XML::Generator::RSS10::lgcl - Support for the UK Local Government Category List (lgcl) specfication =head1 SYNOPSIS use XML::Generator::RSS10; my $rss = XML::Generator::RSS10->new( Handler => $sax_handler, modules => [ qw(dc egms gcl lgcl) ] ); $rss->item( title => '2004 Council By-Election Results', link => 'http://www.example.gov.uk/news/elections.html', description => 'Results for the 2004 Council by-elections', dc => { date => '2004-05-01', creator => 'J. Random Reporter, Example Borough Council, j.r.reporter@example.gov.uk', }, egms => { SubjectCategory => [ ['GCL','Local government'], ['LGCL','Elections'], ['LGCL','News announcements'] ] } ); $rss->channel( title => 'Example Borough Council News', link => 'http://www.example.gov.uk/news/', description => 'News releases from Example Borough Council', dc => { date => '2004-05-01', creator => 'J. Random Administrator, Example Borough Council, j.r.administrator@example.gov.uk', publisher => 'Example Borough Council', rights => 'Copyright (c) Example Borough Council', language => 'en', coverage => 'Example, County, UK' }, egms => { SubjectCategory => [ ['GCL','Local government'], ['LGCL','News announcements'] ] } ); =head1 DESCRIPTION This module extends Dave Rolsky's L to support categories taken from the UK Local Government Category List (lgcl), a controlled vocabulary for use in the UK e-Government Metadata Standard (egms). The module is intended for use only with L. Please see the documentation accompanying that module for further information. =head1 CAVEAT This module has no awareness of what categories are actually in the LGCL. Moreover, it calculates the appropriate reference to the LGCL RDF schema by taking the category you supply and putting it in CamelCase. I'm not aware of any categories for which this would result in an incorrect reference, but exceptions would constitute a bug. =head1 BUGS Please let me know of any you find. You can use the CPAN bug tracker for this by emailing L. =head1 SEE ALSO L, L. =head1 AUTHOR Andrew Green, C<< >>. Sponsored by Woking Borough Council, L. =head1 LICENSE This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. =cut