Re: get rid of Pointer type, mostly
| От | Chao Li |
|---|---|
| Тема | Re: get rid of Pointer type, mostly |
| Дата | |
| Msg-id | EEE9FB40-05BA-4AD4-9BE0-24ABE4EA4FE7@gmail.com обсуждение исходный текст |
| Ответ на | get rid of Pointer type, mostly (Peter Eisentraut <peter@eisentraut.org>) |
| Список | pgsql-hackers |
> On Nov 24, 2025, at 18:20, Peter Eisentraut <peter@eisentraut.org> wrote: > > In a previous thread[0], the question was asked, 'Why do we bother with a "Pointer" type?'. So I looked into get rid ofit. > > There are two stages to this. One is changing all code that wants to do pointer arithmetic to use char * instead of relyingon Pointer being char *. Then we can change Pointer to be void * and remove a bunch of casts. > > The second is getting rid of uses of Pointer for variables where you might as well use void * directly. These are actuallynot that many. > > This gets rid of all uses, except in the GIN code, which is full of Pointer use, and it's part of the documented API. I'm not touching that, not least because this kind of code > > Pointer **extra_data = (Pointer **) PG_GETARG_POINTER(4); > > needs more brain-bending to understand that I'm prepared to spend. So as far as I'm concerned, the pointer type can continueto exist as a curiosity of the GIN API, but in all other places, it wasn't really doing much of anything anyway. > > > [0]: https://www.postgresql.org/message-id/CA%2BhUKG%2BNFKnr%3DK4oybwDvT35dW%3DVAjAAfiuLxp%2B5JeZSOV3nBg%40mail.gmail.com<0001-Remove-useless-casts-to-Pointer.patch><0002-Use-better-DatumGet-function.patch><0003-Don-t-rely-on-pointer-arithmetic-with-Pointer-type.patch><0004-Change-Pointer-to-void.patch><0005-Remove-no-longer-needed-casts-to-Pointer.patch><0006-Remove-some-uses-of-the-Pointer-type.patch> 0001 - Removed type cast from memcpy(), which should be safe, as memcpy doesn’t care about types of source and dest pointersreferring to, type casting is redundant. 0002 - Changed DatumGetPointer() to DatumGetCString() for %s. Basically, DatumGetPointer() returns a void * pointer and DatumGetCString()returns a char * pointers, but they return the same addresses, thus DatumGetCString() better fits %s. 0003 - Changed type casting from Pointer to char *. Now, Pointer is a typedef of char *, so the replacement is safe. In generic_desc(),Pointer is replaced with const char *, which should be safe also. 0004 - Changed typedef of Pointer from char * to void *. I guess the purpose is to let compiler alter for missed usages ofPointer. 0005/0006 - Removed all usages of Pointer expect in Gin code. All look good. Only things is that, as Pointer is changed from char * to void *, and Gin code are still using Pointer, sothese is a change for Gin code. But I don’t think that would impact runtime, as long as build passes, that should be fine.Build passed on my MacBook M4. If there is a breakage, build farm should be able to catch the error. Best regards, -- Chao Li (Evan) HighGo Software Co., Ltd. https://www.highgo.com/
В списке pgsql-hackers по дате отправления: