Search Postgresql Archives

Re: Wishlist of PL/Perl Enhancements for PostgreSQL 8.5

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Tue, Oct 06, 2009 at 09:34:52AM -0400, Alvaro Herrera wrote:
> David Fetter wrote:
> > On Tue, Oct 06, 2009 at 09:57:39AM +0100, Tim Bunce wrote:
> 
> > > * Enable configuration of perl at initialization
> > > 
> > > Add ability to specify in postgresql.conf some code to be run
> > > when a perl interpreter is initialized. For example:
> > > 
> > > plperl.at_init_do = 'use lib qw(/path/to/mylib); use
> > > MyPlPerlUtils; use List::Util qw(sum);'
> > 
> > Would there be some way to integrate this with the per-ROLE,
> > per-database GUC infrastructure?
> 
> I don't have that patch installed right now but I don't think it
> would change the current behavior, which is that it should work just
> fine (and if it doesn't, that's a bug).
> 
> One thing that's not clear to me is how would this work for
> non-superusers.  Wouldn't this violate the Safe containment?  If it
> does then it should be superuser-only, no?

Setting it, sure.  I was thinking it could be handy for different
roles in different DBs to be able to have different PL/Perls :)

> > > For a PL/Perl function called “foo”, a minimal implementation would use
> > > a name like “foo__id54321″ where 54321 is the oid of the function. This
> > > avoids having to deal with polymorphic functions (where multiple
> > > functions have the same name but different arguments).
> > > 
> > > The names won’t enable inter-function calling
> > 
> > Inter-function calling could be handy, too.
> 
> I agree.  This would mean that the function name mangling would have to
> be more predictable ... maybe using the argument types instead of OID?

As Andrew Dunstan pointed out off-list, the argument type naming
scheme is quite vulnerable to naming oddities:

foo(int,text,int)
foo_int(text,int)
foo_int_text(int)
foo_int_text_int()

Cheers,
David.
-- 
David Fetter <david@xxxxxxxxxx> http://fetter.org/
Phone: +1 415 235 3778  AIM: dfetter666  Yahoo!: dfetter
Skype: davidfetter      XMPP: david.fetter@xxxxxxxxx

Remember to vote!
Consider donating to Postgres: http://www.postgresql.org/about/donate

-- 
Sent via pgsql-general mailing list (pgsql-general@xxxxxxxxxxxxxx)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-general

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [Postgresql Jobs]     [Postgresql Admin]     [Postgresql Performance]     [Linux Clusters]     [PHP Home]     [PHP on Windows]     [Kernel Newbies]     [PHP Classes]     [PHP Books]     [PHP Databases]     [Postgresql & PHP]     [Yosemite]
  Powered by Linux