diff --git a/src/tutorial/Makefile b/src/tutorial/Makefile
index acd6311727083035716475dd525d533ed92d1e79..9ba5096f0a16f57af5508c1a9623ff427ce800db 100644
--- a/src/tutorial/Makefile
+++ b/src/tutorial/Makefile
@@ -4,22 +4,14 @@
 #    Makefile for tutorial
 #
 # IDENTIFICATION
-#    $Header: /cvsroot/pgsql/src/tutorial/Makefile,v 1.8 1998/03/01 04:52:55 scrappy Exp $
+#    $Header: /cvsroot/pgsql/src/tutorial/Makefile,v 1.9 2000/03/28 02:49:19 tgl Exp $
 #
 #-------------------------------------------------------------------------
 
 SRCDIR= ..
-include ../Makefile.global
+include $(SRCDIR)/Makefile.global
 
-CFLAGS+= -I$(LIBPQDIR) -I../../include
-
-#
-# And where libpq goes, so goes the authentication stuff...
-#
-ifdef KRBVERS
-LDFLAGS+= $(KRBLIBS)
-CFLAGS+= $(KRBFLAGS)
-endif
+CFLAGS+= -I$(SRCDIR)/include $(CFLAGS_SL)
 
 #
 # DLOBJS is the dynamically-loaded object files.  The "funcs" queries
@@ -42,7 +34,5 @@ all: $(DLOBJS) $(QUERIES)
 	    -e "s:_DLSUFFIX_:$(DLSUFFIX):g" \
 	    -e "s/_USER_/$$USER/g" < $< > $@
 
-funcs.sql: $(DLOBJS)
-
 clean:
 	rm -f $(DLOBJS) $(QUERIES)
diff --git a/src/tutorial/complex.source b/src/tutorial/complex.source
index bc71e34c9ed7de391c8bf9b6cdcbe8145d2540e3..361007ced9db65df2ca681967f560ebaa490a42d 100644
--- a/src/tutorial/complex.source
+++ b/src/tutorial/complex.source
@@ -7,7 +7,7 @@
 --
 -- Copyright (c) 1994, Regents of the University of California
 --
--- $Id: complex.source,v 1.6 2000/01/24 07:16:48 tgl Exp $
+-- $Id: complex.source,v 1.7 2000/03/28 02:49:19 tgl Exp $
 --
 ---------------------------------------------------------------------------
 
@@ -18,7 +18,7 @@
 --	called 'complex' which represents complex numbers.
 -----------------------------
 
--- Assume the user defined functions are in _OBJWD_/complex.so
+-- Assume the user defined functions are in _OBJWD_/complex_DLSUFFIX_
 -- Look at $PWD/complex.c for the source.
 
 -- the input function 'complex_in' takes a null-terminated string (the 
@@ -28,7 +28,7 @@
 
 CREATE FUNCTION complex_in(opaque)
    RETURNS complex
-   AS '_OBJWD_/complex.so'
+   AS '_OBJWD_/complex_DLSUFFIX_'
    LANGUAGE 'c';
 
 -- the output function 'complex_out' takes the internal representation and
@@ -36,7 +36,7 @@ CREATE FUNCTION complex_in(opaque)
 
 CREATE FUNCTION complex_out(opaque)
    RETURNS opaque
-   AS '_OBJWD_/complex.so'
+   AS '_OBJWD_/complex_DLSUFFIX_'
    LANGUAGE 'c';
 
 -- now, we can create the type. The internallength specifies the size of the
@@ -80,7 +80,7 @@ SELECT * FROM test_complex;
 -- first, define a function complex_add (also in complex.c)
 CREATE FUNCTION complex_add(complex, complex)
    RETURNS complex
-   AS '_OBJWD_/complex.so'
+   AS '_OBJWD_/complex_DLSUFFIX_'
    LANGUAGE 'c';
 
 -- we can now define the operator. We show a binary operator here but you
@@ -138,15 +138,15 @@ SELECT 'READ ABOVE!' AS STOP;
 
 -- first, define the required operators
 CREATE FUNCTION complex_abs_lt(complex, complex) RETURNS bool
-   AS '_OBJWD_/complex.so' LANGUAGE 'c';
+   AS '_OBJWD_/complex_DLSUFFIX_' LANGUAGE 'c';
 CREATE FUNCTION complex_abs_le(complex, complex) RETURNS bool
-   AS '_OBJWD_/complex.so' LANGUAGE 'c';
+   AS '_OBJWD_/complex_DLSUFFIX_' LANGUAGE 'c';
 CREATE FUNCTION complex_abs_eq(complex, complex) RETURNS bool
-   AS '_OBJWD_/complex.so' LANGUAGE 'c';
+   AS '_OBJWD_/complex_DLSUFFIX_' LANGUAGE 'c';
 CREATE FUNCTION complex_abs_ge(complex, complex) RETURNS bool
-   AS '_OBJWD_/complex.so' LANGUAGE 'c';
+   AS '_OBJWD_/complex_DLSUFFIX_' LANGUAGE 'c';
 CREATE FUNCTION complex_abs_gt(complex, complex) RETURNS bool
-   AS '_OBJWD_/complex.so' LANGUAGE 'c';
+   AS '_OBJWD_/complex_DLSUFFIX_' LANGUAGE 'c';
 
 CREATE OPERATOR < (
    leftarg = complex, rightarg = complex, procedure = complex_abs_lt,
@@ -169,9 +169,11 @@ CREATE OPERATOR > (
    restrict = scalargtsel, join = scalargtjoinsel
 );
 
-INSERT INTO pg_opclass VALUES ('complex_abs_ops');
+INSERT INTO pg_opclass (opcname, opcdeftype)
+    SELECT 'complex_abs_ops', oid FROM pg_type WHERE typname = 'complex';
 
-SELECT oid, opcname FROM pg_opclass WHERE opcname = 'complex_abs_ops';
+SELECT oid, opcname, opcdeftype
+    FROM pg_opclass WHERE opcname = 'complex_abs_ops';
 
 SELECT o.oid AS opoid, o.oprname
 INTO TABLE complex_ops_tmp
@@ -214,7 +216,7 @@ INSERT INTO pg_amop (amopid, amopclaid, amopopr, amopstrategy)
 
 --
 CREATE FUNCTION complex_abs_cmp(complex, complex) RETURNS int4
-   AS '_OBJWD_/complex.so' LANGUAGE 'c';
+   AS '_OBJWD_/complex_DLSUFFIX_' LANGUAGE 'c';
 
 SELECT oid, proname FROM pg_proc WHERE proname = 'complex_abs_cmp';
 
diff --git a/src/tutorial/funcs.source b/src/tutorial/funcs.source
index b8e03218fd96b77a9d500b19358e4bdf8da8fb23..b2b20e6928da7d1502d2b581ba336804b9c3ba9e 100644
--- a/src/tutorial/funcs.source
+++ b/src/tutorial/funcs.source
@@ -6,7 +6,7 @@
 --
 -- Copyright (c) 1994-5, Regents of the University of California
 --
--- $Id: funcs.source,v 1.3 1999/03/14 15:22:15 momjian Exp $
+-- $Id: funcs.source,v 1.4 2000/03/28 02:49:19 tgl Exp $
 --
 ---------------------------------------------------------------------------
 
@@ -126,16 +126,16 @@ SELECT name(high_pay()) AS overpaid;
 -----------------------------
 
 CREATE FUNCTION add_one(int4) RETURNS int4
-   AS '_OBJWD_/funcs.so' LANGUAGE 'c';
+   AS '_OBJWD_/funcs_DLSUFFIX_' LANGUAGE 'c';
 
 CREATE FUNCTION makepoint(point, point) RETURNS point
-   AS '_OBJWD_/funcs.so' LANGUAGE 'c';
+   AS '_OBJWD_/funcs_DLSUFFIX_' LANGUAGE 'c';
 
 CREATE FUNCTION copytext(text) RETURNS text
-   AS '_OBJWD_/funcs.so' LANGUAGE 'c';
+   AS '_OBJWD_/funcs_DLSUFFIX_' LANGUAGE 'c';
 
 CREATE FUNCTION c_overpaid(EMP, int4) RETURNS bool
-   AS '_OBJWD_/funcs.so' LANGUAGE 'c';
+   AS '_OBJWD_/funcs_DLSUFFIX_' LANGUAGE 'c';
 
 SELECT add_one(3) AS four;