ADD: changed to perl only bibtex parser + multi page support
This commit is contained in:
parent
fccff5c467
commit
20b694ec76
@ -3,10 +3,10 @@ package HiD::Generator::BibtexPage;
|
|||||||
use Moose;
|
use Moose;
|
||||||
with 'HiD::Generator';
|
with 'HiD::Generator';
|
||||||
use HiD::Page;
|
use HiD::Page;
|
||||||
use Text::BibTeX;
|
use BibTeX::Parser;
|
||||||
use Text::BibTeX::Bib;
|
use IO::File;
|
||||||
|
|
||||||
our $VERSION = "0.3";
|
our $VERSION = "0.4";
|
||||||
|
|
||||||
|
|
||||||
# a map of bibtex publication item names to real/speaking names
|
# a map of bibtex publication item names to real/speaking names
|
||||||
@ -23,7 +23,7 @@ my $type_map = {
|
|||||||
|
|
||||||
=method generate
|
=method generate
|
||||||
|
|
||||||
reads the configured bibtex file and generates an html version
|
reads the configured bibtex files and generates an html version
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
@ -31,79 +31,44 @@ sub generate {
|
|||||||
my( $self , $site ) = @_;
|
my( $self , $site ) = @_;
|
||||||
return unless $site->config->{bibtex_page}{generate};
|
return unless $site->config->{bibtex_page}{generate};
|
||||||
|
|
||||||
my $input_file = $site->config->{bibtex_page}{layout}
|
die("no bibtex pages defined") unless $site->config->{bibtex_page}{pages};
|
||||||
|
|
||||||
|
for my $p (keys %{$site->config->{bibtex_page}{pages}})
|
||||||
|
{
|
||||||
|
|
||||||
|
my $input_file = $site->config->{bibtex_page}{pages}{$p}{layout}
|
||||||
or die "Must define bibtex_page.layout in config if bibtex_page.generate is enabled";
|
or die "Must define bibtex_page.layout in config if bibtex_page.generate is enabled";
|
||||||
|
|
||||||
my $bibtex_file = $site->config->{bibtex_page}{bibtex}
|
my $bibtex_file = $site->config->{bibtex_page}{pages}{$p}{bibtex}
|
||||||
or die "Must define bibtex_page.bibtex in config if bibtex_page.generate is enabled";
|
or die "Must define bibtex_page.bibtex in config if bibtex_page.generate is enabled";
|
||||||
|
|
||||||
if (! -e $site->config->{bibtex_page}{bibtex}) {
|
if (! -e $site->config->{bibtex_page}{pages}{$p}{bibtex}) {
|
||||||
die "bibtex_page.bibtex:".$site->config->{bibtex_page}{bibtex}." file must exist\n";
|
die "bibtex_page.bibtex:".$site->config->{bibtex_page}{bibtex}." file must exist\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
my $url = $site->config->{bibtex_page}{url} // 'publications/';
|
my $url = $site->config->{bibtex_page}{pages}{$p}{url} // 'publications/';
|
||||||
|
|
||||||
my $destination = $site->config->{bibtex_page}{destination} // $site->destination;
|
my $destination = $site->config->{bibtex_page}{pages}{$p}{destination} // $site->destination;
|
||||||
|
|
||||||
$self->_create_destination_directory_if_needed( $destination );
|
$self->_create_destination_directory_if_needed( $destination );
|
||||||
|
|
||||||
# here we need to parse the bibtex file and generate the list
|
# here we need to parse the bibtex file and generate the list
|
||||||
my @publications;
|
my @publications;
|
||||||
my $bibfile = new Text::BibTeX::File($site->config->{bibtex_page}{bibtex});
|
my $fh = IO::File->new($site->config->{bibtex_page}{pages}{$p}{bibtex});
|
||||||
$bibfile->set_structure ('Bib',sortby => 'year');
|
my $bibfile = BibTeX::Parser->new($fh);
|
||||||
while (my $entry = new Text::BibTeX::Entry $bibfile) {
|
|
||||||
next unless $entry->parse_ok;
|
|
||||||
my %pub;
|
|
||||||
$pub{type}=$type_map->{$entry->type};
|
|
||||||
|
|
||||||
my @names = $entry->names ('author');
|
my @entries;
|
||||||
my @last;
|
while (my $entry = $bibfile->next ) {
|
||||||
for my $n (@names){
|
if ($entry->parse_ok) {
|
||||||
push(@last, $n->part('last'));
|
push(@entries, $entry);
|
||||||
}
|
}
|
||||||
$pub{author}=\@last;
|
|
||||||
if ($entry->type eq "mastersthesis" || $entry->type eq "phdthesis") {
|
|
||||||
$pub{title}=$entry->get('title') . ", " . $entry->get('school') . ", " . $entry->get('address');
|
|
||||||
} elsif($entry->type eq "inproceedings") {
|
|
||||||
$pub{title}=$entry->get('title') . ", " .$entry->get('booktitle') . ", ". $entry->get('address');
|
|
||||||
} elsif($entry->type eq "misc") {
|
|
||||||
$pub{title}=$entry->get('title');
|
|
||||||
if (defined($entry->get('howpublished')) && length($entry->get('howpublished'))>0) {
|
|
||||||
$pub{title}.="," . $entry->get('howpublished');
|
|
||||||
}
|
|
||||||
if (defined($entry->get('address')) && length($entry->get('address'))>0) {
|
|
||||||
$pub{title}.="," . $entry->get('address');
|
|
||||||
}
|
|
||||||
} elsif($entry->type eq "inbook") {
|
|
||||||
$pub{title} = "Chap: " . $entry->get('chapter') . ", Book: " . $entry->get('title');
|
|
||||||
$pub{title} .= ", Editor: " . $entry->get('editor') unless !defined($entry->get('editor'));
|
|
||||||
$pub{title} .= ", " . $entry->get('publisher') unless !defined($entry->get('publisher'));
|
|
||||||
} elsif($entry->type eq "incollection") {
|
|
||||||
$pub{title} = $entry->get('title') .", " . $entry->get('booktitle');
|
|
||||||
$pub{title} .= " Vol. " . $entry->get('volume') unless !defined($entry->get('volume'));
|
|
||||||
$pub{title} .= ", Editor: " . $entry->get('editor') unless !defined($entry->get('editor'));
|
|
||||||
$pub{title} .= ", " . $entry->get('publisher') unless !defined($entry->get('publisher'));
|
|
||||||
} elsif($entry->type eq "article") {
|
|
||||||
$pub{title} = $entry->get('title') .", " . $entry->get('journal');
|
|
||||||
$pub{title} .= " Issue " . $entry->get('number') unless !defined($entry->get('number'));
|
|
||||||
$pub{title} .= " Vol. " . $entry->get('volume') unless !defined($entry->get('volume'));
|
|
||||||
$pub{title} .= ", " . $entry->get('publisher') unless !defined($entry->get('publisher'));
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$pub{title}=$entry->get('title');
|
|
||||||
}
|
|
||||||
$pub{year}=$entry->get('year');
|
|
||||||
$pub{month}=$entry->get('month');
|
|
||||||
$pub{day}=$entry->get('day');
|
|
||||||
$pub{url}=$entry->get('url');
|
|
||||||
$pub{source}=$entry->print_s;
|
|
||||||
$pub{id}=$entry->key;
|
|
||||||
|
|
||||||
push(@publications, \%pub);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
# sort publications by year
|
# sort publications by year
|
||||||
@publications=sort { $b->{year} <=> $a->{year} } @publications;
|
@publications=sort { $b->{year} <=> $a->{year} } @entries;
|
||||||
|
|
||||||
# create the new page
|
# create the new page
|
||||||
my $page = HiD::Page->new({
|
my $page = HiD::Page->new({
|
||||||
@ -118,7 +83,8 @@ sub generate {
|
|||||||
$site->add_input( "Publication" => 'page' );
|
$site->add_input( "Publication" => 'page' );
|
||||||
$site->add_object( $page );
|
$site->add_object( $page );
|
||||||
|
|
||||||
$site->INFO( "* Injected Bibtex page");
|
$site->INFO( "* Injected Bibtex page $p");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
__PACKAGE__->meta->make_immutable;
|
__PACKAGE__->meta->make_immutable;
|
||||||
|
Loading…
Reference in New Issue
Block a user