'Carp::Clan' => 0,
'IO::Dir' => 0,
'IO::Scalar' => 2.110,
- 'Parse::RecDescent' => 1.962002,
+ 'Parse::RecDescent' => 1.964001,
'Pod::Usage' => 0,
'DBI' => 0,
'File::ShareDir' => 1.0,
WriteAll();
sub _recompile_grammars {
- # placeholder, will be used to recompile P::RD parsers before shipping
- # will also allow to lose dependency on P::RD
+ require File::Spec;
+
+ my $compiled_parser_dir = File::Spec->catdir(qw/
+ share PrecompiledParsers Parse RecDescent DDL SQLT
+ /);
+
+ # Currently consider only single-name parsers containing a grammar marker
+ # This is somewhat fragile, but better than loading all kinds of parsers
+ # to some of which we may not even have the deps
+ my $parser_libdir = 'lib/SQL/Translator/Parser';
+ for my $parser_fn (glob "$parser_libdir/*.pm") {
+ die "$parser_fn does not look like a readable file\n"
+ unless ( -f $parser_fn and -r $parser_fn );
+
+ my ($type) = $parser_fn =~ /^\Q$parser_libdir\E\/(.+)\.pm$/i
+ or die "$parser_fn not named in expected format\n";
+
+ my $parser_source = do { local (@ARGV, $/) = $parser_fn; <> };
+ next unless $parser_source =~ /\$GRAMMAR.+?END_OF_GRAMMAR/s;
+
+
+ my $precomp_parser_fn = File::Spec->catfile($compiled_parser_dir, "$type.pm");
+
+ next if (
+ -f $precomp_parser_fn
+ and
+ (stat($parser_fn))[9] <= (stat($precomp_parser_fn))[9]
+ );
+
+
+ print "Precompiling parser for $type\n";
+
+ require $parser_fn;
+ require Parse::RecDescent;
+
+ Parse::RecDescent->Precompile(
+ do {
+ no strict 'refs';
+ ${"SQL::Translator::Parser::${type}::GRAMMAR"}
+ || die "No \$GRAMMAR global found in SQL::Translator::Parser::$type ($parser_fn)\n"
+ },
+ "Parse::RecDescent::DDL::SQLT::$type"
+ );
+
+ rename( "$type.pm", $precomp_parser_fn )
+ or die "Unable to move $type.pm to $compiled_parser_dir: $!\n";
+ }
+
}
sub _recreate_rt_source {