> On 25 Apr 2018, at 17:55, John Naylor <jcnay...@gmail.com> wrote:
> 
> On 4/25/18, Stas Kelvich <s.kelv...@postgrespro.ru> wrote:
>>> On 25 Apr 2018, at 17:18, Tom Lane <t...@sss.pgh.pa.us> wrote:
>>> I think we should rewrite
>>> both of them to use the Catalog.pm infrastructure.
>> 
>> Okay, seems reasonable. I'll put shared code in Catalog.pm and
>> update patch.
> 
> I don't think you need any new code in Catalog.pm, I believe the
> suggestion was just to use that module as a stable interface to the
> data. Looking at your patch, I'll mention that we have an idiom for
> extracting #define'd OID symbols, e.g.:
> 
> my $FirstBootstrapObjectId = Catalog::FindDefinedSymbol(
>       'access/transam.h', \@include_path, 'FirstBootstrapObjectId');
> 
> This is preferred over using awk, which would have its own portability
> issues (Windows for starters).
> 
> While I'm thinking out loud, it might be worthwhile to patch genbki.pl
> for the duplicate test, since they're run at the same time anyway (see
> catalog/Makefile), and we've already read all the data.
> 
> -John Naylor
> 


New version is attached. I've put iterator into Catalog.pm to avoid copy-pasting
it over two scripts. Also instead of greping through *.dat and *.h files I've
used parsers provided in Catalog module. That way should be more sustainable
to format changes.

Anyone who wanted to help with scripts -- feel free to rewrite.


Attachment: 0001-Rewrite-unused_oids-in-perl.patch
Description: Binary data



--
Stas Kelvich
Postgres Professional: http://www.postgrespro.com
The Russian Postgres Company


Reply via email to