Commit bc959b7b authored by Magnus Hagander's avatar Magnus Hagander

Parse pg_proc.h with entries without OIDs.

parent 7c5e5439
...@@ -145,7 +145,7 @@ sub GenerateFiles { ...@@ -145,7 +145,7 @@ sub GenerateFiles {
print H "/* fmgroids.h generated for Visual C++ */\n#ifndef FMGROIDS_H\n#define FMGROIDS_H\n\n"; print H "/* fmgroids.h generated for Visual C++ */\n#ifndef FMGROIDS_H\n#define FMGROIDS_H\n\n";
open(T,">src\\backend\\utils\\fmgrtab.c") || confess "Could not open fmgrtab.c"; open(T,">src\\backend\\utils\\fmgrtab.c") || confess "Could not open fmgrtab.c";
print T "/* fmgrtab.c generated for Visual C++ */\n#include \"postgres.h\"\n#include \"utils/fmgrtab.h\"\n\n"; print T "/* fmgrtab.c generated for Visual C++ */\n#include \"postgres.h\"\n#include \"utils/fmgrtab.h\"\n\n";
foreach my $s (sort {$a->{oid} <=> $b->{oid}} @fmgr) { foreach my $s (sort {intval($a->{oid}) <=> intval($b->{oid})} @fmgr) {
next if $seenit{$s->{prosrc}}; next if $seenit{$s->{prosrc}};
$seenit{$s->{prosrc}} = 1; $seenit{$s->{prosrc}} = 1;
print H "#define F_" . uc $s->{prosrc} . " $s->{oid}\n"; print H "#define F_" . uc $s->{prosrc} . " $s->{oid}\n";
...@@ -157,8 +157,9 @@ sub GenerateFiles { ...@@ -157,8 +157,9 @@ sub GenerateFiles {
my %bmap; my %bmap;
$bmap{'t'} = 'true'; $bmap{'t'} = 'true';
$bmap{'f'} = 'false'; $bmap{'f'} = 'false';
foreach my $s (sort {$a->{oid} <=> $b->{oid}} @fmgr) { foreach my $s (sort {intval($a->{oid}) <=> intval($b->{oid})} @fmgr) {
print T " { $s->{oid}, \"$s->{prosrc}\", $s->{nargs}, $bmap{$s->{strict}}, $bmap{$s->{retset}}, $s->{prosrc} },\n"; my $o = intval($s->{oid});
print T " { $o, \"$s->{prosrc}\", $s->{nargs}, $bmap{$s->{strict}}, $bmap{$s->{retset}}, $s->{prosrc} },\n";
} }
...@@ -231,6 +232,14 @@ EOF ...@@ -231,6 +232,14 @@ EOF
} }
} }
sub intval {
my $v = shift;
if ($v =~ /^\d+$/) {
return $v;
}
return 0;
}
sub AddProject { sub AddProject {
my ($self, $name, $type, $folder, $initialdir) = @_; my ($self, $name, $type, $folder, $initialdir) = @_;
......
...@@ -11,7 +11,7 @@ ...@@ -11,7 +11,7 @@
# #
# #
# IDENTIFICATION # IDENTIFICATION
# $PostgreSQL: pgsql/src/tools/msvc/genbki.pl,v 1.3 2007/02/06 09:16:08 petere Exp $ # $PostgreSQL: pgsql/src/tools/msvc/genbki.pl,v 1.4 2007/02/19 14:05:42 mha Exp $
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
...@@ -79,6 +79,9 @@ foreach my $line (split /\n/, $indata) { ...@@ -79,6 +79,9 @@ foreach my $line (split /\n/, $indata) {
my @fields = split /\s+/,$data; my @fields = split /\s+/,$data;
if ($#fields >=4 && $fields[0] eq "insert" && $fields[1] eq "OID" && $fields[2] eq "=") { if ($#fields >=4 && $fields[0] eq "insert" && $fields[1] eq "OID" && $fields[2] eq "=") {
$oid = $fields[3]; $oid = $fields[3];
}
else {
$oid = 0;
} }
$data =~ s/\s{2,}/ /g; $data =~ s/\s{2,}/ /g;
$bki .= $data . "\n"; $bki .= $data . "\n";
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment