%PDF- <> %âãÏÓ endobj 2 0 obj <> endobj 3 0 obj <>/ExtGState<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI] >>/Annots[ 28 0 R 29 0 R] /MediaBox[ 0 0 595.5 842.25] /Contents 4 0 R/Group<>/Tabs/S>> endobj ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<>endobj 2 0 obj<> endobj 2 0 obj<>endobj 2 0 obj<>es 3 0 R>> endobj 2 0 obj<> ox[ 0.000000 0.000000 609.600000 935.600000]/Fi endobj 3 0 obj<> endobj 7 1 obj<>/ProcSet[/PDF/Text/ImageB/ImageC/ImageI]>>/Subtype/Form>> stream
package Generators; require Exporter; use strict; use File::Basename; no strict 'refs'; use vars qw($VERSION @AVAILABLE); our $VERSION = '1.00'; our(@ISA, @EXPORT, @EXPORT_OK, @AVAILABLE); @ISA = qw(Exporter); BEGIN { local(*D); my $me = $INC{"Generators.pm"}; die "Couldn't find myself in \@INC, which is required to load the generators!" if ("$me" eq ""); $me = dirname($me); if (opendir(D,"$me/Generators")) { foreach my $gen (readdir(D)) { next if ($gen =~ /^\.\.?$/); require "${me}/Generators/$gen"; $gen =~ s,\.pm,,; push(@AVAILABLE, $gen); } closedir(D); my $gens = join(', ', @AVAILABLE); } push @EXPORT_OK, qw(available); } sub available { return @AVAILABLE; } sub generate { my ($gen, $git_dir, $out_dir, $rel_dir, %build_structure) = @_; return eval("Generators::${gen}::generate(\$git_dir, \$out_dir, \$rel_dir, \%build_structure)") if grep(/^$gen$/, @AVAILABLE); die "Generator \"${gen}\" is not available!\nAvailable generators are: @AVAILABLE\n"; } 1;