12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849 |
- #!/usr/bin/perl
- #----------------------------------------------------------------------
- #
- # duplicate_oids
- # Identifies any manually-assigned OIDs that are used multiple times
- # in the Postgres catalog data.
- #
- # While duplicate OIDs would only cause a failure if they appear in
- # the same catalog, our project policy is that manually assigned OIDs
- # should be globally unique, to avoid confusion.
- #
- # Portions Copyright (c) 1996-2022, PostgreSQL Global Development Group
- # Portions Copyright (c) 1994, Regents of the University of California
- #
- # src/include/catalog/duplicate_oids
- #
- #----------------------------------------------------------------------
- use strict;
- use warnings;
- # Must run in src/include/catalog
- use FindBin;
- chdir $FindBin::RealBin or die "could not cd to $FindBin::RealBin: $!\n";
- use lib "$FindBin::RealBin/../../backend/catalog/";
- use Catalog;
- my @input_files = glob("pg_*.h");
- my $oids = Catalog::FindAllOidsFromHeaders(@input_files);
- my %oidcounts;
- foreach my $oid (@{$oids})
- {
- $oidcounts{$oid}++;
- }
- my $found = 0;
- foreach my $oid (sort { $a <=> $b } keys %oidcounts)
- {
- next unless $oidcounts{$oid} > 1;
- $found = 1;
- print "$oid\n";
- }
- exit $found;
|