Re: Bugs: Programming Language Functions

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: Bugs: Programming Language Functions
Дата
Msg-id 734.955464746@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Bugs: Programming Language Functions  ("Andrew C.R. Martin" <a.c.r.martin@reading.ac.uk>)
Список pgsql-interfaces
"Andrew C.R. Martin" <a.c.r.martin@reading.ac.uk> writes:
> This then links onto the code installation problems, as the header
> files in the installed include directory do not have a typedef for
> TupleTableSlot. This is defined in .../src/include/executor/tuptable.h
> Just copying this across to the installation directory causes no end
> of other files to be needed as well (e.g.  storgae/buf.h,
> access/tupdesc.h, access/htup.h - and these in turn require loads of
> other files.....)

Yes, this has been complained of before: trying to write an extension
that touches anything but the most basic system types requires including
a mess of files that we don't normally export ... and we don't really
*want* to export the whole set of include files.  For the moment,
I'd suggest compiling with a -I pointing at a source tree rather than
the install tree.  (If you're doing any serious extension development,
you surely have a source tree around for reference, so I don't think
this is totally unreasonable.)

Bruce did some work a while ago to eliminate unnecessary cross-includes,
so it could be that in 7.0 it would be easier to deal with the problem.
But really, someone needs to go through the backend header files and
figure out what makes sense to export.

> Surely TupleTableSlot should be defined in libpq-fe.h as should the
> prototype for GetAttributeByName().

Surely *not*.  Neither the type nor the function exist in the frontend.
We may need to export more backend header files, but confusing backend
and frontend isn't going to help anyone.

> It would be nice to have TUPLE
> #defined as TupleTableSlot so that old code doesn't break!!!!

If that were the only thing breaking old code, I'd agree with you,
but extensions usually need to be looked at for every version anyway...
        regards, tom lane


В списке pgsql-interfaces по дате отправления:

Предыдущее
От: Paolo Sommaruga
Дата:
Сообщение: Re: Why fields order is wrong ?
Следующее
От: "Andrew C.R. Martin"
Дата:
Сообщение: Re: Bugs: Programming Language Functions