| From: | Nikolay Shaplov <dhyan(at)nataraj(dot)su> | 
|---|---|
| To: | pgsql-hackers(at)postgresql(dot)org | 
| Cc: | Alvaro Herrera <alvherre(at)2ndquadrant(dot)com> | 
| Subject: | Re: [PATCH] Move all am-related reloption code into src/backend/access/[am-name] and get rid of relopt_kind for custom AM | 
| Date: | 2017-03-28 15:58:37 | 
| Message-ID: | 5867745.FjVmo6n3G8@x200m | 
| Views: | Whole Thread | Raw Message | Download mbox | Resend email | 
| Thread: | |
| Lists: | pgsql-hackers | 
В письме от 17 марта 2017 14:21:26 пользователь Alvaro Herrera написал:
> Please make sure to mark functions as static (e.g. bringetreloptcatalog).
I am a bit confused here:
For brin and nbtree this is a good idea: brin.c and nbtree.c has AM-handler 
inside it, and  there are other static functions there. Adding one more static 
function here seems to be quite logical.
For gin, gist and spgist, authors seems to use [index_name]_private.h files to 
hide internal functions from outside code. In ginutil.c and spgutils.c, where 
AM-handler is located, there is no static functions at all...  gist.c has, but 
I think I should write similar code for all *_private.h indexes. 
So I think it wold be good to hide catalog function via *_pricate.h include 
file for these three indexes.
hash.c is quite a mess...
There is no hash_private.h, AM-handles is located in hash.c, that has "This 
file contains only the public interface routines." comment at the beginning, 
and there is no static functions inside. I do not know what is the right way 
to hide hashgetreloptcatalog function here...
What would you advise?
-- 
Nikolay Shaplov, independent Perl & C/C++ developer. Available for hire.
| From | Date | Subject | |
|---|---|---|---|
| Next Message | Teodor Sigaev | 2017-03-28 15:59:49 | Re: [PATCH] ALTER DEFAULT PRIVILEGES with GRANT/REVOKE ON SCHEMAS | 
| Previous Message | Tom Lane | 2017-03-28 15:56:20 | Re: Today's failures on buildfarm member longfin |