Thread: PL/Perl compilation error

PL/Perl compilation error

From
Alex Guryanow
Date:
Hi,

I have just installed Perl 5.6.0 and PostgreSQL 7.0.2. After successfull installation of both these
programs I tried to make PL/Perl support. After running the commands from Postgres manual I have
received the following errors


[root@eaccess plperl]# perl Makefile.PL
Writing Makefile for plperl
[root@eaccess plperl]# make
cc -c -I../../../src/include -I../../../src/backend  -fno-strict-aliasing -D_LAR
GEFILE_SOURCE -D_FILE_OFFSET_BITS=64 -O2     -DVERSION=\"0.10\" -DXS_VERSION=\"0
.10\" -fpic -I/usr/local/lib/perl5/5.6.0/i686-linux/CORE  plperl.c
In file included from plperl.c:76:
/usr/local/lib/perl5/5.6.0/i686-linux/CORE/perl.h:467: warning: `USE_LOCALE' red
efined
../../../src/include/config.h:213: warning: this is the location of the previous
 definition
In file included from plperl.c:76:
/usr/local/lib/perl5/5.6.0/i686-linux/CORE/perl.h:2027: warning: `DEBUG' redefin
ed
../../../src/include/utils/elog.h:22: warning: this is the location of the previ
ous definition
plperl.c: In function `plperl_create_sub':
plperl.c:328: `errgv' undeclared (first use in this function)
plperl.c:328: (Each undeclared identifier is reported only once
plperl.c:328: for each function it appears in.)
plperl.c:334: `na' undeclared (first use in this function)
plperl.c: In function `plperl_call_perl_func':
plperl.c:444: `errgv' undeclared (first use in this function)
plperl.c:450: `na' undeclared (first use in this function)
plperl.c: In function `plperl_func_handler':
plperl.c:654: `na' undeclared (first use in this function)
plperl.c: In function `plperl_build_tuple_argument':
plperl.c:2192: `na' undeclared (first use in this function)
make: *** [plperl.o] Error 1
[root@eaccess plperl]#

What I'm doing wrong?

Regards,
Alex



Re: PL/Perl compilation error

From
Tom Lane
Date:
Alex Guryanow <gav@nlr.ru> writes:
> [root@eaccess plperl]# perl Makefile.PL

For recent Perl versions you need to do
        perl Makefile.PL POLLUTE=1
instead.  The src/pl Makefile would've done it that way for you,
but it looks like that code patch didn't make it to the docs...

Someone needs to update our Perl code so that it will compile cleanly
against both newer and not-so-new Perls.  There are notes in our mail
archives about how to do this (basically "use Devel::PPPort" is the
long-term answer) but it hasn't gotten to the top of anyone's to-do
list.

            regards, tom lane

Re: PL/Perl compilation error

From
Jan Wieck
Date:
Tom Lane wrote:
> Alex Guryanow <gav@nlr.ru> writes:
> > [root@eaccess plperl]# perl Makefile.PL
>
> For recent Perl versions you need to do
>         perl Makefile.PL POLLUTE=1
> instead.  The src/pl Makefile would've done it that way for you,
> but it looks like that code patch didn't make it to the docs...
>
> Someone needs to update our Perl code so that it will compile cleanly
> against both newer and not-so-new Perls.  There are notes in our mail
> archives about how to do this (basically "use Devel::PPPort" is the
> long-term answer) but it hasn't gotten to the top of anyone's to-do
> list.

    Can someone eventually enlighten me a little?

    We've    had   problems   like   platform/version   dependant
    compilation errors with PL/Tcl in the past too, but they  got
    fixed  pretty  quick and a reasonable number of people worked
    on that all together.

    We have frequent compilation error reports with  PL/perl  but
    nobody seems to be able/willing to do anything about it.

    PL/perl  was  once  highly  requested feature. Now there is a
    code base and lesser experienced programmers  could  continue
    the work, but nobody does.

    What  is  the problem with perl? Are there only alot of users
    but no hackers? The frequent fail reports suggest that  there
    are  folks  who  want  to  have  that  thing running. I can't
    believe that a piece of open  source  software,  that  is  so
    popular, is implemented in such an ugly way that nobody has a
    clue how to fix that damned thing.

    So please tell me why people spend their time  writing  error
    reports  again  and  again  instead  of  simply fixing it and
    submitting a patch.


Jan

--

#======================================================================#
# It's easier to get forgiveness for being wrong than for being right. #
# Let's break this rule - forgive me.                                  #
#================================================== JanWieck@Yahoo.com #



Re: PL/Perl compilation error

From
Tom Lane
Date:
Jan Wieck <janwieck@Yahoo.com> writes:
>  [ why hasn't plperl been fixed yet? ]

IMHO, the portability problems with plperl will need a Perl guru to fix.
Specifically somebody who knows the ins and outs of embedding Perl into
other applications, which is not such a commonly done thing.  pltcl was
a simpler project because Tcl has always been designed to be embedded as
a library into other applications.  Perl is still in process of being
redesigned from a standalone program into an embeddable library, and
most everyday Perl programmers don't know much about the pitfalls that
still remain in using it that way.

Just to give you one example of the ways in which Perl is not designed
to be embeddable: last I checked, libperl was not built as PIC code by
default.  On machines where that makes a difference (like HPUX) that
means that plperl cannot work with a default Perl installation. Period.
Not one damn thing you can do about it except reconfigure/rebuild/
reinstall Perl, which is a tad outside the charter of our build process.

The cross-version compatibility issues could be fixed more easily, but
probably not with just an hour or two's work (has anyone here actually
done anything with Devel::PPPort? how hard is it?).  When working around
them just takes "add POLLUTE=1 to Makefile build", I can see why people
aren't eager to invest the work for a cleaner solution.

Perl is getting better over time (indeed 5.6.0 may do the right thing
already on the PIC front; I haven't installed it yet) but I think in
the near term it's going to be difficult to have a really robust
portability solution for plperl.

            regards, tom lane

Re: PL/Perl compilation error

From
Gilles DAROLD
Date:
Hi,

I have take a look to the source code concerning PL/Perl, it seems that 2 variables
have a bad call : errgv and na.

If you replace them by their normal call (in 5.6.0) PL_errgv and PL_na you will get
success to compile the lib plperl.so.

Also in Perl documentation you will find the answer for backward compatibility :

> The API function perl_get_sv("@",FALSE) should be used instead of directly accessing
> perl globals as GvSV(errgv). The API call is backward compatible with existing perls and
> provides source compatibility with threading is enabled.

It seems to be easily repared. I have no time yet but I will take a look as soon as possible.

Regards
Gilles

Alex Guryanow wrote:

> Hi,
>
> I have just installed Perl 5.6.0 and PostgreSQL 7.0.2. After successfull installation of both these
> programs I tried to make PL/Perl support. After running the commands from Postgres manual I have
> received the following errors
>


Report of performance on Alpha vs. Intel

From
"Steve Wolfe"
Date:
   This week, I had the opportunity to compare the performance of PostgreSQL
on an Alpha and an Intel server, and the results kind of surprised me.  I'd
love to hear if this has been the case for others as well...

-------------
Intel Machine

SuperMicro 8050 quad Xeon server
512 MB RAM
4 x PII Xeon 400 MHz (secondary cache disabled)
RAID array w/ 5 9-gig drives

Approximate cost:  $6000
--------------
Alpha Machine
AlphaServer DS20E
2 x CPU (500 MHz or 667 MHz)
2 GB RAM
9-gig SCSI drive

Approximate cost:  $20,000 - $25,000
-----------------------

General System notes

    I'm not sure which chips the Alpha uses, the 500 MHz or the 667 MHz.
Also, because the SuperMicro board is meant for the newer Xeons, the
secondary cache had to be completely disabled on the PII 400 Xeons, so that
machine was definitely not running up to potential.

-------------------------
Test method

   This wasn't exactly the ANSI tests, but it accurately reflected what we
need out of a machine.  A while back we logged 87,000 individual queries on
our production machine, and I selected one thousand distinct queries from
that.

   On each machine I spawned 20 parallel processes, each performing the
1,000 queries, and timed how long it took for all processes to finish.

   To try and keep the disk subsystem from being a factor, this used only
selects, no updates or deletes.  Also, the database is small enough that the
entire thing was easily in the disk cache at all times.
--------------------------
Test results

  The Alpha finished in just over 60 minutes, the Xeon finished in just over
90.

-----------------------------
Test interpretation

  Once I started looking at the numbers, I was suprised.  On a
processor-for-processor basis, the Alpha was three times as fast as the
Intels.  However, the Intels that it was pitted against were only 400 MHz
chips, only PII (not the PIII), *and* had the external cache completely
disabled.

   So, the Alpha provided three times the performance for four times the
cost - but if the megabyte of cache had been enabled on the Xeons, I think
that the results would have been significantly different.  Also, if the
chips had been even relatively recent chips (say, some 700 or 800 MHz Xeons)
with the cache enabled, it's possible that it could have come close to the
performance of the Alpha, at a much lower cost.

  Overall, I was expecting the Alpha to give the Intel a better trouncing,
especially considering the difference in cost, but I guess it's hard to beat
Intel for transactions/dollar.  If sheer server capacity is the only
relevant factor, forget Intel (You won't find Intels with 64 processors, and
I don't think you'll see them even with the Itaniums).  If your needs are
more down-to-Earth, they're the best you can get for the money.

steve



Re: Report of performance on Alpha vs. Intel

From
"Mitch Vincent"
Date:
I'm curious, what OS did you perform these test under?

-Mitch

----- Original Message -----
From: "Steve Wolfe" <steve@iboats.com>
To: <pgsql-general@postgresql.org>
Sent: Tuesday, September 05, 2000 10:14 AM
Subject: [GENERAL] Report of performance on Alpha vs. Intel


>
>    This week, I had the opportunity to compare the performance of
PostgreSQL
> on an Alpha and an Intel server, and the results kind of surprised me.
I'd
> love to hear if this has been the case for others as well...
>
> -------------
> Intel Machine
>
> SuperMicro 8050 quad Xeon server
> 512 MB RAM
> 4 x PII Xeon 400 MHz (secondary cache disabled)
> RAID array w/ 5 9-gig drives
>
> Approximate cost:  $6000
> --------------
> Alpha Machine
> AlphaServer DS20E
> 2 x CPU (500 MHz or 667 MHz)
> 2 GB RAM
> 9-gig SCSI drive
>
> Approximate cost:  $20,000 - $25,000
> -----------------------
>
> General System notes
>
>     I'm not sure which chips the Alpha uses, the 500 MHz or the 667 MHz.
> Also, because the SuperMicro board is meant for the newer Xeons, the
> secondary cache had to be completely disabled on the PII 400 Xeons, so
that
> machine was definitely not running up to potential.
>
> -------------------------
> Test method
>
>    This wasn't exactly the ANSI tests, but it accurately reflected what we
> need out of a machine.  A while back we logged 87,000 individual queries
on
> our production machine, and I selected one thousand distinct queries from
> that.
>
>    On each machine I spawned 20 parallel processes, each performing the
> 1,000 queries, and timed how long it took for all processes to finish.
>
>    To try and keep the disk subsystem from being a factor, this used only
> selects, no updates or deletes.  Also, the database is small enough that
the
> entire thing was easily in the disk cache at all times.
> --------------------------
> Test results
>
>   The Alpha finished in just over 60 minutes, the Xeon finished in just
over
> 90.
>
> -----------------------------
> Test interpretation
>
>   Once I started looking at the numbers, I was suprised.  On a
> processor-for-processor basis, the Alpha was three times as fast as the
> Intels.  However, the Intels that it was pitted against were only 400 MHz
> chips, only PII (not the PIII), *and* had the external cache completely
> disabled.
>
>    So, the Alpha provided three times the performance for four times the
> cost - but if the megabyte of cache had been enabled on the Xeons, I think
> that the results would have been significantly different.  Also, if the
> chips had been even relatively recent chips (say, some 700 or 800 MHz
Xeons)
> with the cache enabled, it's possible that it could have come close to the
> performance of the Alpha, at a much lower cost.
>
>   Overall, I was expecting the Alpha to give the Intel a better trouncing,
> especially considering the difference in cost, but I guess it's hard to
beat
> Intel for transactions/dollar.  If sheer server capacity is the only
> relevant factor, forget Intel (You won't find Intels with 64 processors,
and
> I don't think you'll see them even with the Itaniums).  If your needs are
> more down-to-Earth, they're the best you can get for the money.
>
> steve
>
>
>


Re: Report of performance on Alpha vs. Intel

From
"Steve Wolfe"
Date:
> I'm curious, what OS did you perform these test under?

  Doh!  Silly me.

  The Xeon ran a Linux 2.2.16 kernel, and the Alpha ran "Tru64".

Steve


Re: Report of performance on Alpha vs. Intel

From
Zeljko Trogrlic
Date:
Memory and cache are the most important parameters for db server, and PC
lacks both.

At 19:14 5.9.2000 , Steve Wolfe wrote:
>
>   This week, I had the opportunity to compare the performance of PostgreSQL
>on an Alpha and an Intel server, and the results kind of surprised me.  I'd
>love to hear if this has been the case for others as well...
>
>-------------
>Intel Machine
>
>SuperMicro 8050 quad Xeon server
>512 MB RAM
>4 x PII Xeon 400 MHz (secondary cache disabled)
>RAID array w/ 5 9-gig drives
>
>Approximate cost:  $6000
>--------------
>Alpha Machine
>AlphaServer DS20E
>2 x CPU (500 MHz or 667 MHz)
>2 GB RAM
>9-gig SCSI drive
>
>Approximate cost:  $20,000 - $25,000
>-----------------------
>
>General System notes
>
>    I'm not sure which chips the Alpha uses, the 500 MHz or the 667 MHz.
>Also, because the SuperMicro board is meant for the newer Xeons, the
>secondary cache had to be completely disabled on the PII 400 Xeons, so that
>machine was definitely not running up to potential.
>
>-------------------------
>Test method
>
>   This wasn't exactly the ANSI tests, but it accurately reflected what we
>need out of a machine.  A while back we logged 87,000 individual queries on
>our production machine, and I selected one thousand distinct queries from
>that.
>
>   On each machine I spawned 20 parallel processes, each performing the
>1,000 queries, and timed how long it took for all processes to finish.
>
>   To try and keep the disk subsystem from being a factor, this used only
>selects, no updates or deletes.  Also, the database is small enough that the
>entire thing was easily in the disk cache at all times.
>--------------------------
>Test results
>
>  The Alpha finished in just over 60 minutes, the Xeon finished in just over
>90.
>
>-----------------------------
>Test interpretation
>
>  Once I started looking at the numbers, I was suprised.  On a
>processor-for-processor basis, the Alpha was three times as fast as the
>Intels.  However, the Intels that it was pitted against were only 400 MHz
>chips, only PII (not the PIII), *and* had the external cache completely
>disabled.
>
>   So, the Alpha provided three times the performance for four times the
>cost - but if the megabyte of cache had been enabled on the Xeons, I think
>that the results would have been significantly different.  Also, if the
>chips had been even relatively recent chips (say, some 700 or 800 MHz Xeons)
>with the cache enabled, it's possible that it could have come close to the
>performance of the Alpha, at a much lower cost.
>
>  Overall, I was expecting the Alpha to give the Intel a better trouncing,
>especially considering the difference in cost, but I guess it's hard to beat
>Intel for transactions/dollar.  If sheer server capacity is the only
>relevant factor, forget Intel (You won't find Intels with 64 processors, and
>I don't think you'll see them even with the Itaniums).  If your needs are
>more down-to-Earth, they're the best you can get for the money.
>
>steve
>
>
v
Zeljko Trogrlic
____________________________________________________________

Aeris d.o.o.
Sv. Petka 60 b, HR-31000 Osijek, Croatia
Tel: +385 (31) 53 00 15
Email: mailto:zeljko@post.hinet.hr

Re: PL/Perl compilation error

From
Jan Wieck
Date:
Tom Lane wrote:
> Alex Guryanow <gav@nlr.ru> writes:
> > [root@eaccess plperl]# perl Makefile.PL
>
> For recent Perl versions you need to do
>         perl Makefile.PL POLLUTE=1
> instead.  The src/pl Makefile would've done it that way for you,
> but it looks like that code patch didn't make it to the docs...
>
> Someone needs to update our Perl code so that it will compile cleanly
> against both newer and not-so-new Perls.  There are notes in our mail
> archives about how to do this (basically "use Devel::PPPort" is the
> long-term answer) but it hasn't gotten to the top of anyone's to-do
> list.
   Can someone eventually enlighten me a little?
   We've    had   problems   like   platform/version   dependant   compilation errors with PL/Tcl in the past too, but
they got   fixed  pretty  quick and a reasonable number of people worked   on that all together.
 
   We have frequent compilation error reports with  PL/perl  but   nobody seems to be able/willing to do anything about
it.
   PL/perl  was  once  highly  requested feature. Now there is a   code base and lesser experienced programmers  could
continue  the work, but nobody does.
 
   What  is  the problem with perl? Are there only alot of users   but no hackers? The frequent fail reports suggest
that there   are  folks  who  want  to  have  that  thing running. I can't   believe that a piece of open  source
software, that  is  so   popular, is implemented in such an ugly way that nobody has a   clue how to fix that damned
thing.
   So please tell me why people spend their time  writing  error   reports  again  and  again  instead  of  simply
fixingit and   submitting a patch.
 


Jan

--

#======================================================================#
# It's easier to get forgiveness for being wrong than for being right. #
# Let's break this rule - forgive me.                                  #
#================================================== JanWieck@Yahoo.com #






Re: PL/Perl compilation error

From
Bruce Momjian
Date:
Can you send me a patch?


> Hi,
>
> I have take a look to the source code concerning PL/Perl, it seems that 2 variables
> have a bad call : errgv and na.
>
> If you replace them by their normal call (in 5.6.0) PL_errgv and PL_na you will get
> success to compile the lib plperl.so.
>
> Also in Perl documentation you will find the answer for backward compatibility :
>
> > The API function perl_get_sv("@",FALSE) should be used instead of directly accessing
> > perl globals as GvSV(errgv). The API call is backward compatible with existing perls and
> > provides source compatibility with threading is enabled.
>
> It seems to be easily repared. I have no time yet but I will take a look as soon as possible.
>
> Regards
> Gilles
>
> Alex Guryanow wrote:
>
> > Hi,
> >
> > I have just installed Perl 5.6.0 and PostgreSQL 7.0.2. After successfull installation of both these
> > programs I tried to make PL/Perl support. After running the commands from Postgres manual I have
> > received the following errors
> >
>
>


--
  Bruce Momjian                        |  http://candle.pha.pa.us
  pgman@candle.pha.pa.us               |  (610) 853-3000
  +  If your life is a hard drive,     |  830 Blythe Avenue
  +  Christ can be your backup.        |  Drexel Hill, Pennsylvania 19026

Re: PL/Perl compilation error

From
Gilles DAROLD
Date:
Bruce Momjian wrote:

> Can you send me a patch?
>
> > Hi,
> >
> > I have take a look to the source code concerning PL/Perl, it seems that 2 variables
> > have a bad call : errgv and na.
> >
> > If you replace them by their normal call (in 5.6.0) PL_errgv and PL_na you will get
> > success to compile the lib plperl.so.
> >

This patch (simple diff) applies to postgresql-7.0.2.
See attachment...

Regards

Gilles DAROLD



328c328
<     if (SvTRUE(GvSV(PL_errgv)))
---
>     if (SvTRUE(GvSV(errgv)))
334c334
<         elog(ERROR, "creation of function failed : %s", SvPV(GvSV(PL_errgv), PL_na));
---
>         elog(ERROR, "creation of function failed : %s", SvPV(GvSV(errgv), na));
444c444
<     if (SvTRUE(GvSV(PL_errgv)))
---
>     if (SvTRUE(GvSV(errgv)))
450c450
<         elog(ERROR, "plperl : error from function : %s", SvPV(GvSV(PL_errgv), PL_na));
---
>         elog(ERROR, "plperl : error from function : %s", SvPV(GvSV(errgv), na));
654c654
<         (SvPV(perlret, PL_na),
---
>         (SvPV(perlret, na),
2192c2192
<     output = perl_eval_pv(SvPV(output, PL_na), TRUE);
---
>     output = perl_eval_pv(SvPV(output, na), TRUE);

Re: PL/Perl compilation error

From
Tom Lane
Date:
Gilles DAROLD <gilles@darold.net> writes:
>>>> I have take a look to the source code concerning PL/Perl, it seems that 2 variables
>>>> have a bad call : errgv and na.
>>>>
>>>> If you replace them by their normal call (in 5.6.0) PL_errgv and PL_na you will get
>>>> success to compile the lib plperl.so.
>>>>

> This patch (simple diff) applies to postgresql-7.0.2.


The problem is this will break on older copies of Perl.

            regards, tom lane

Re: PL/Perl compilation error

From
Gilles DAROLD
Date:
Tom Lane wrote:

> Gilles DAROLD <gilles@darold.net> writes:
> >>>> I have take a look to the source code concerning PL/Perl, it seems that 2 variables
> >>>> have a bad call : errgv and na.
> >>>>
> >>>> If you replace them by their normal call (in 5.6.0) PL_errgv and PL_na you will get
> >>>> success to compile the lib plperl.so.
> >>>>
>
> > This patch (simple diff) applies to postgresql-7.0.2.
>
> The problem is this will break on older copies of Perl.
>
>                         regards, tom lane

This problem is solved by perl itself !

I know it work under perl > 5.005_3 and certainly all versions after perl 5.004.
Give me a reason to keep buggy perl versions compatibility ! People still
running version prior of 5.005_3 does not really want perl running well so
why plperl :-)

If you are not agree with my last comment, just take a look to the change log
of the perl version history and you will understand what I mean (security, memory,
etc.) ...

Regards

Gilles DAROLD


do triggers/procedures run instantly?

From
"chris markiewicz"
Date:
hello.

i have the following trigger:

CREATE TRIGGER trig_person_accessorclass BEFORE INSERT ON Person FOR EACH
ROW EXECUTE PROCEDURE sp_person_accessorclass();

the corresponding function inserts a row into the accessor_class table.

the issue is that when i insert a row into person and immediately query the
accessor_class table, i don't find anything.  does it take some amount of
time for the trigger/sp to run?  is it just placed in a queue or something?
can i speed this up or is it best to not count on the performance of the
function?

thanks

chris



Re: PL/Perl compilation error

From
Tom Lane
Date:
Gilles DAROLD <gilles@darold.net> writes:
>> The problem is this will break on older copies of Perl.

> This problem is solved by perl itself !

Yeah, it is: there is a module called Devel::PPPort that isolates
user C code from the incompatibilities of different Perl APIs.  Until
someone gets around to submitting a proper fix using PPPort, we'll stick
with the POLLUTE=1 solution we have now.  I see no reason to install an
incomplete solution that will fail on older Perls --- we are not in the
business of forcing people to update their Perls.

I was going to point you to the pgsql-bugs archive for 3/25/00, but
there seems to be a gap in the archive in March, so attached are the
relevant messages.

            regards, tom lane


------- Forwarded Messages

Date:    Sat, 25 Mar 2000 13:15:28 +0100
From:    Marc Lehmann <pcg@goof.com>
To:      pgsql-bugs@postgresql.org
Subject: [BUGS] perl5 interface won't compile

============================================================================
                        POSTGRESQL BUG REPORT TEMPLATE
============================================================================


Your name        :    Marc Lehmann
Your email address    :    pcg@goof.com


System Configuration
---------------------
  Architecture (example: Intel Pentium)      :

  Operating System (example: Linux 2.0.26 ELF)     :

  PostgreSQL version (example: PostgreSQL-6.5.1):   PostgreSQL-7.0beta3

  Compiler used (example:  gcc 2.8.0)        :


Please enter a FULL description of your problem:
------------------------------------------------

the perl interface does not compile with newer perl versions (5.006 and
probably 5.005 without options).

Please describe a way to repeat the problem.   Please try to provide a

(sorry, just found out that plperl also won't compile, so I have "re-added"
another, a second diff against plperl ;)

concise reproducible example, if at all possible:
----------------------------------------------------------------------

"make"




If you know how this problem might be fixed, list the solution below:
---------------------------------------------------------------------

A diff against Pg.xs is attached, however, it will not compile with older
perl versions (it is the prefered long-term solution).

So, for the forseeable future, it might be a better to create the Makefile
using

   perl Makefile.PL POLLUTE=1

which will enable some kind of compatibility mode.

A preferable but better solution would be to use the Devel::PPPort module
(on CPAN) to get rid of versiondependonitis (in which case you will need
to apply both diffs and additionally include ppport.h, preferably after
renaming it to something else.

===PATCH 1===================================================================

diff -r -u perl5o/Pg.c perl5/Pg.c
--- perl5o/Pg.c    Sat Mar 25 13:09:05 2000
+++ perl5/Pg.c    Sat Mar 25 13:10:38 2000
@@ -1407,7 +1407,7 @@
         ps.caption   = caption;
         Newz(0, ps.fieldName, items + 1 - 11, char*);
         for (i = 11; i < items; i++) {
-            ps.fieldName[i - 11] = (char *)SvPV(ST(i), na);
+            ps.fieldName[i - 11] = (char *)SvPV_nolen(ST(i));
         }
         PQprint(fout, res, &ps);
         Safefree(ps.fieldName);
@@ -3182,7 +3182,7 @@
                 EXTEND(sp, cols);
                 while (col < cols) {
                     if (PQgetisnull(res->result, res->row, col)) {
-                        PUSHs(&sv_undef);
+                        PUSHs(&PL_sv_undef);
                     } else {
                         char *val = PQgetvalue(res->result, res->row, col);
                         PUSHs(sv_2mortal((SV*)newSVpv(val, 0)));
@@ -3238,7 +3238,7 @@
         ps.caption   = caption;
         Newz(0, ps.fieldName, items + 1 - 11, char*);
         for (i = 11; i < items; i++) {
-            ps.fieldName[i - 11] = (char *)SvPV(ST(i), na);
+            ps.fieldName[i - 11] = (char *)SvPV_nolen(ST(i));
         }
         PQprint(fout, res->result, &ps);
         Safefree(ps.fieldName);
diff -r -u perl5o/Pg.xs perl5/Pg.xs
--- perl5o/Pg.xs    Sat Mar 11 04:08:37 2000
+++ perl5/Pg.xs    Sat Mar 25 13:10:36 2000
@@ -581,7 +581,7 @@
         ps.caption   = caption;
         Newz(0, ps.fieldName, items + 1 - 11, char*);
         for (i = 11; i < items; i++) {
-            ps.fieldName[i - 11] = (char *)SvPV(ST(i), na);
+            ps.fieldName[i - 11] = (char *)SvPV_nolen(ST(i));
         }
         PQprint(fout, res, &ps);
         Safefree(ps.fieldName);
@@ -1252,7 +1252,7 @@
                 EXTEND(sp, cols);
                 while (col < cols) {
                     if (PQgetisnull(res->result, res->row, col)) {
-                        PUSHs(&sv_undef);
+                        PUSHs(&PL_sv_undef);
                     } else {
                         char *val = PQgetvalue(res->result, res->row, col);
                         PUSHs(sv_2mortal((SV*)newSVpv(val, 0)));
@@ -1292,7 +1292,7 @@
         ps.caption   = caption;
         Newz(0, ps.fieldName, items + 1 - 11, char*);
         for (i = 11; i < items; i++) {
-            ps.fieldName[i - 11] = (char *)SvPV(ST(i), na);
+            ps.fieldName[i - 11] = (char *)SvPV_nolen(ST(i));
         }
         PQprint(fout, res->result, &ps);
         Safefree(ps.fieldName);

===PATCH 2===================================================================

diff -u -r plperlo/plperl.c plperl/plperl.c
--- plperlo/plperl.c    Sat Mar 25 13:17:31 2000
+++ plperl/plperl.c    Sat Mar 25 13:18:32 2000
@@ -309,12 +309,12 @@
     perl_eval_sv(s, G_SCALAR | G_EVAL | G_KEEPERR);
     SPAGAIN;

-    if (SvTRUE(GvSV(errgv))) {
+    if (SvTRUE(GvSV(PL_errgv))) {
         POPs;
         PUTBACK;
         FREETMPS;
         LEAVE;
-        elog(ERROR, "creation of function failed : %s", SvPV(GvSV(errgv), na));
+        elog(ERROR, "creation of function failed : %s", SvPV_nolen(GvSV(PL_errgv)));
     }

     /*
@@ -413,12 +413,12 @@
         elog(ERROR, "plperl : didn't get a return item from function");
     }

-    if (SvTRUE(GvSV(errgv))) {
+    if (SvTRUE(GvSV(PL_errgv))) {
         POPs;
         PUTBACK ;
         FREETMPS ;
         LEAVE;
-        elog(ERROR, "plperl : error from function : %s", SvPV(GvSV(errgv), na));
+        elog(ERROR, "plperl : error from function : %s", SvPV_nolen(GvSV(PL_errgv)));
     }

     retval = newSVsv(POPs);
@@ -632,7 +632,7 @@
         elog(ERROR, "plperl: SPI_finish() failed");

     retval = (Datum) (*fmgr_faddr(&prodesc->result_in_func))
-            (SvPV(perlret, na),
+            (SvPV_nolen(perlret),
              prodesc->result_in_elem,
             prodesc->result_in_len);

@@ -2168,6 +2168,6 @@
         }
     }
     sv_catpv(output, "}");
-    output = perl_eval_pv(SvPV(output, na), TRUE);
+    output = perl_eval_pv(SvPV_nolen(output), TRUE);
     return output;
 }

=============================================================================

--
      -----==-                                             |
      ----==-- _                                           |
      ---==---(_)__  __ ____  __       Marc Lehmann      +--
      --==---/ / _ \/ // /\ \/ /       pcg@opengroup.org |e|
      -=====/_/_//_/\_,_/ /_/\_\       XX11-RIPE         --+
    The choice of a GNU generation                       |
                                                         |

------- Message 2

Date:    Sat, 25 Mar 2000 11:49:09 -0500
From:    Tom Lane <tgl@sss.pgh.pa.us>
To:      Marc Lehmann <pcg@goof.com>
cc:      pgsql-bugs@postgresql.org, pgsql-hackers@postgreSQL.org
Subject: Re: [BUGS] perl5 interface won't compile

Marc Lehmann <pcg@goof.com> writes:
> the perl interface does not compile with newer perl versions (5.006 and
> probably 5.005 without options).

We've seen this reported a few times, but in fact the perl code *does*
compile against 5.005_03 --- without options --- and AFAICT that is
still considered the current stable release of Perl.  I'm pretty
hesitant to break backwards compatibility with pre-5.005 versions
just yet.

However, you are the first complainant who has suggested approaches
other than a non-backward-compatible source patch, so I'm all ears.

> So, for the forseeable future, it might be a better to create the Makefile
> using
>    perl Makefile.PL POLLUTE=1
> which will enable some kind of compatibility mode.

Interesting.  I could not find anything about POLLUTE at www.perl.com.
What does it do, and will it cause problems on pre-5.005 perls?

> A preferable but better solution would be to use the Devel::PPPort module
> (on CPAN) to get rid of versiondependonitis (in which case you will need
> to apply both diffs and additionally include ppport.h, preferably after
> renaming it to something else.

This looks like it could be the Right Thing To Do.  Anyone have time to
make it happen (and perhaps even access to a few different perl versions
to test it)?

            regards, tom lane

------- Message 3

Date:    Sat, 25 Mar 2000 15:27:17 -0500
From:    Tom Lane <tgl@sss.pgh.pa.us>
To:      Bruce Momjian <pgman@candle.pha.pa.us>, Marc Lehmann <pcg@goof.com>,
     pgsql-bugs@postgresql.org
Subject: Re: [BUGS] perl5 interface won't compile

I said
> Bruce Momjian <pgman@candle.pha.pa.us> writes:
>> I have added your POLLUTE=1 solution to interfaces/perl5 and
>> plperl.  Please try tomorrow's snapshot to see if this works for you.

> I think the more interesting question is whether that breaks older
> Perls...

I have now tried it with perl 5.004_04 (which was current about two
years ago), and I get

$ make plperl/Makefile
cd plperl && perl Makefile.PL POLLUTE=1
'POLLUTE' is not a known MakeMaker parameter name.
Writing Makefile for plperl

after which it seems to be happy.  Assuming this fixes the problem
for bleeding-edge perls, this looks like a good stopgap answer until
someone feels like doing something with Devel::PPPort.

            regards, tom lane

------- End of Forwarded Messages

Re: PL/Perl compilation error

From
Alex Pilosov
Date:
On Tue, 17 Oct 2000, Tom Lane wrote:

> Gilles DAROLD <gilles@darold.net> writes:
> >> The problem is this will break on older copies of Perl.
>
> > This problem is solved by perl itself !
>
> Yeah, it is: there is a module called Devel::PPPort that isolates
> user C code from the incompatibilities of different Perl APIs.  Until
> someone gets around to submitting a proper fix using PPPort, we'll stick
> with the POLLUTE=1 solution we have now.  I see no reason to install an
> incomplete solution that will fail on older Perls --- we are not in the
> business of forcing people to update their Perls.
I believe that POLLUTE should be a default. People who are using perl5.004
are definitely a minority now. 5.004 is 3 years old now...

-alex


Re: PL/Perl compilation error

From
Tom Lane
Date:
Alex Pilosov <alex@pilosoft.com> writes:
> I believe that POLLUTE should be a default.

It is --- the src/pl and src/interfaces Makefiles will create the
sub-makefiles with POLLUTE=1.  Unfortunately it's easy to miss that
fine point when you're building the Perl modules by hand.  Not sure
if there's a good way to remind people about it.

            regards, tom lane

PL/Perl compilation error

From
Gilles DAROLD
Date:
Hi,

I have done a little work concerning the famous PL/Perl compilation Error and
also into Interfaces/Perl5.

The confusing POLLUTE option is no more used to see these parts compiled.
I thinks it's now fully compatible with all Perl versions, yes Tom I use PPPort :-)

The way to put it into the distribution package is very simple.

1) Replace the current GNUmakefile in these directories src/interface/perl5 and src/pl/plperl

by those given in the attachment.
2) Copy the lastest version of the ppport.h file into the same directories (latest can be
found
on CPAN) I provide one in the attachment (the latest at this day Version 1.0007)

That done, just compile postgresql exactly as before (with ./configure --with-perl at least).

What I have done is very simple :

    -  cp Devel-PPPort-1.0007/ppport.h postgresql-snapshotsrc/pl/plperl/
    -  cp Devel-PPPort-1.0007/ppport.h postgresql-snapshot/src/interfaces/perl5/

And in the 2 GNUmakefile in the "Makefile: Makefile.PL" section:

    - I have remove the call to the POLLUTE option
    - Added the following lines at the begining of the section:
            $(PERL) -x ppport.h *.c *.h *.xs > ppport.patch
            patch < ppport.patch
            rm ppport.patch

Thanks to Kenneth Albanowski for his PPPort.pm usefull package and to Tom Lane
for his ligth.

Note: the attachment is a tar of all modified and added files in the source tree.

Regards,

Gilles DAROLD

Attachment

Re: PL/Perl compilation error

From
Tom Lane
Date:
Gilles DAROLD <gilles@darold.net> writes:
> The confusing POLLUTE option is no more used to see these parts compiled.
> I thinks it's now fully compatible with all Perl versions,
> yes Tom I use PPPort :-)

Excellent!  I'll check it over and put it in the tree.  Thank you.

            regards, tom lane

Re: Re: PL/Perl compilation error

From
Larry Rosenman
Date:
Broke my build on UnixWare 7.1.1...  May be perl version confusion...

See my post to -hackers.

Larry
* Tom Lane <tgl@sss.pgh.pa.us> [001024 18:38]:
> Gilles DAROLD <gilles@darold.net> writes:
> > The confusing POLLUTE option is no more used to see these parts compiled.
> > I thinks it's now fully compatible with all Perl versions,
> > yes Tom I use PPPort :-)
>
> Excellent!  I'll check it over and put it in the tree.  Thank you.
>
>             regards, tom lane
--
Larry Rosenman                      http://www.lerctr.org/~ler
Phone: +1 972-414-9812 (voice) Internet: ler@lerctr.org
US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749

Re: Re: PL/Perl compilation error

From
Gilles DAROLD
Date:
Hi,

Do you use the file GNUmakefile and ppport.h I recently send to the list ?
What is your version of Perl ?
Could you send me output of your build ?

Regards,

Gilles DAROLD

Larry Rosenman wrote:

> Broke my build on UnixWare 7.1.1...  May be perl version confusion...
>
> See my post to -hackers.
>
> Larry
> * Tom Lane <tgl@sss.pgh.pa.us> [001024 18:38]:
> > Gilles DAROLD <gilles@darold.net> writes:
> > > The confusing POLLUTE option is no more used to see these parts compiled.
> > > I thinks it's now fully compatible with all Perl versions,
> > > yes Tom I use PPPort :-)
> >
> > Excellent!  I'll check it over and put it in the tree.  Thank you.
> >
> >                       regards, tom lane
> --
> Larry Rosenman                      http://www.lerctr.org/~ler
> Phone: +1 972-414-9812 (voice) Internet: ler@lerctr.org
> US Mail: 1905 Steamboat Springs Drive, Garland, TX 75044-6749