Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included in RH7.2 - Mailing list pgsql-hackers

From teg@redhat.com (Trond Eivind Glomsrød)
Subject Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included in RH7.2
Date
Msg-id xuysnbn7gwe.fsf@halden.devel.redhat.com
Whole thread Raw
Responses Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included in RH7.2
Re: Error on stock postgresql-tcl-7.1.3-2.i386.rpm included
List pgsql-hackers
Deds Castillo <deds@infiniteinfo.com> writes:

> Good day to you.  I've searched the net but I can't seem to find the solution 
> for this.  I've found a few more posts which are exactly the same as my error 
> but no solution was given.
> 
> The problem is when I install the postgresql-tcl rpm and I try to createlang 
> pltcl.  The error below occurs:
> 
> ERROR:  Load of file /usr/lib/pgsql/pltcl.so failed: /usr/lib/pgsql/pltcl.so: 
>  undefined symbol: Tcl_CreateSlave
> 
> So instead of executing createlang, I try to isolate the error using this 
> command:
> 
> testdb=# CREATE FUNCTION pltcl_call_handler () RETURNS OPAQUE AS
> '/usr/lib/pgsql/pltcl.so' LANGUAGE 'C';

During the build process, the tcl shared module is created like this:

gcc -pipe -shared -Wl,-soname,libtcl.so.0 -o pltcl.so pltcl.o -L/usr/lib -ltcl -ldl  -lieee -lm -lc

specifying the soname "libtcl.so.0" and at the same time linking to
libtcl.so.0 (which is the name of the shared tcl library in RHL 7.2)
results in trouble when loading it later. 

Creating the module with a different so-name ("libtcl" seems like a
bad idea to use outside the main package) solves the problem and gives
you a module which loads

gcc -pipe -shared -Wl,-soname,libpgtcl.so.0 -o pltcl.so pltcl.o -L/usr/lib -ltcl -ldl  -lieee -lm -lc

-- 
Trond Eivind Glomsrød
Red Hat, Inc.


pgsql-hackers by date:

Previous
From: "Ross J. Reedstrom"
Date:
Subject: Re: Possible major bug in PlPython (plus some other ideas)
Next
From: David Ford
Date:
Subject: best method of reloading pg_hba.conf