Re: plperl arginfo

Поиск
Список
Период
Сортировка
От Andrew Dunstan
Тема Re: plperl arginfo
Дата
Msg-id 4CC9C3E0.4000706@dunslane.net
обсуждение исходный текст
Ответ на Re: plperl arginfo  (Garick Hamlin <ghamlin@isc.upenn.edu>)
Список pgsql-hackers

On 10/28/2010 02:11 PM, Garick Hamlin wrote:
> On Thu, Oct 28, 2010 at 01:03:24PM -0400, Andrew Dunstan wrote:
>>
>> On 10/28/2010 12:34 PM, Tom Lane wrote:
>>> BTW, maybe we could have the best of both worlds?  Dunno about Perl,
>>> but in some languages it would be possible to instantiate the hash
>>> only if it's actually touched.  Passing the data as a hash definitely
>>> seems to fit with the spirit of things otherwise, so as long as it
>>> didn't cost cycles when not needed, I'd be in favor of that API.
>> Maybe, but I think that's getting rather beyond my perlguts-fu. I think
>> we'd need to do that via PERL_MAGIC_tied, but it's new territory for me.
>> Anyone else want to chime in?
> Warning, I don't know the plperl, I am just a perl coder.
>
> I do think all the anonymous array are worth worrying about in terms of
> performance.
>
> I don't think that tie is necessarily good for performance.  tie() is not
> generally fast.  I think you'd likely be better off writing plain accessors
> or using a function to add type info.
>
> Use an accessor for type information, like this?
> $ref->typeof($key)
>
> ...
> or perhaps use a special function?
>
> add_type_info(\%args);
>
> ...
> or if you want attibute based syntax sugar for the add_type_info() solution...
>
> my %args : pg_record(add_type_info);
>
> Again, these I don't know the plperl code, so I might be missing something
> here.
>

This wouldn't be done at the perl level. It would be done in C code. Run 
"man perlguts" and search for "Understanding the Magic of Tied Hashes 
and Arrays". The overhead in setting it up is likely to be very low 
unless I'm not understanding correctly. There might be some price paid 
when accessing the object, but that's another affair.

OTOH, a pg_get_arg_info() function would probably be a substantially 
simpler if slightly less perlish solution.

cheers

andrew


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

Предыдущее
От: Garick Hamlin
Дата:
Сообщение: Re: plperl arginfo
Следующее
От: Ben
Дата:
Сообщение: Re: contsel and gist