From e39a1186941200fdab0187e6022d714f41fc1945 Mon Sep 17 00:00:00 2001
From: Michael Meskes <meskes@postgresql.org>
Date: Wed, 17 May 2000 06:03:14 +0000
Subject: [PATCH] *** empty log message ***

---
 src/interfaces/ecpg/ChangeLog       |  5 +++++
 src/interfaces/ecpg/lib/Makefile.in |  4 ++--
 src/interfaces/ecpg/lib/data.c      | 24 +++++++++++++++++++++---
 src/interfaces/ecpg/test/Makefile   |  5 +++--
 src/interfaces/ecpg/test/test1.pgc  | 18 ++++++++++--------
 src/interfaces/ecpg/test/test4.pgc  |  6 +++---
 6 files changed, 44 insertions(+), 18 deletions(-)

diff --git a/src/interfaces/ecpg/ChangeLog b/src/interfaces/ecpg/ChangeLog
index 29a59fa3207..6f292eeb4c3 100644
--- a/src/interfaces/ecpg/ChangeLog
+++ b/src/interfaces/ecpg/ChangeLog
@@ -919,4 +919,9 @@ Mon May 15 10:51:31 CEST 2000
 	- Added patch by SAKAIDA Masaaki <sakaida@psn.co.jp> to fix segfault.
 	- Set ecpg version to 2.7.1.
 
+Wed May 17 07:52:59 CEST 2000
+
+	- Added patch by SAKAIDA Masaaki <sakaida@psn.co.jp> to fix array
+	  handling.
+	- Set library version to 3.1.1.
 
diff --git a/src/interfaces/ecpg/lib/Makefile.in b/src/interfaces/ecpg/lib/Makefile.in
index 20f5c314dd1..d48c75ea230 100644
--- a/src/interfaces/ecpg/lib/Makefile.in
+++ b/src/interfaces/ecpg/lib/Makefile.in
@@ -6,13 +6,13 @@
 # Copyright (c) 1994, Regents of the University of California
 #
 # IDENTIFICATION
-#    $Header: /cvsroot/pgsql/src/interfaces/ecpg/lib/Attic/Makefile.in,v 1.65 2000/03/30 11:41:34 meskes Exp $
+#    $Header: /cvsroot/pgsql/src/interfaces/ecpg/lib/Attic/Makefile.in,v 1.66 2000/05/17 06:03:13 meskes Exp $
 #
 #-------------------------------------------------------------------------
 
 NAME= ecpg
 SO_MAJOR_VERSION= 3
-SO_MINOR_VERSION= 1.0
+SO_MINOR_VERSION= 1.1
 
 SRCDIR= @top_srcdir@
 include $(SRCDIR)/Makefile.global
diff --git a/src/interfaces/ecpg/lib/data.c b/src/interfaces/ecpg/lib/data.c
index 29675a89728..18ac49805bd 100644
--- a/src/interfaces/ecpg/lib/data.c
+++ b/src/interfaces/ecpg/lib/data.c
@@ -1,4 +1,5 @@
 #include <stdlib.h>
+#include <string.h>
 
 #include <ecpgtype.h>
 #include <ecpglib.h>
@@ -26,8 +27,18 @@ get_data(PGresult *results, int act_tuple, int act_field, int lineno,
 			ECPGraise(lineno, ECPG_DATA_NOT_ARRAY, NULL);
 			return (false);
 		}
-		else
-			++pval;
+
+		switch (type)
+		{
+			case ECPGt_char:
+		        case ECPGt_unsigned_char:
+		        case ECPGt_varchar:
+		 		break;
+		
+		        default:
+		                pval++;
+		                break;
+		}
 	}
 
 	/* We will have to decode the value */
@@ -144,7 +155,14 @@ get_data(PGresult *results, int act_tuple, int act_field, int lineno,
 			case ECPGt_double:
 				if (pval)
 				{
-					dres = strtod(pval, &scan_length);
+					if (isarray && *pval == '"')
+						dres = strtod(pval + 1, &scan_length);
+					else
+						dres = strtod(pval, &scan_length);
+					
+					if (isarray && *scan_length == '"')
+					        scan_length++;
+					
 					if ((isarray && *scan_length != ',' && *scan_length != '}')
 						|| (!isarray && *scan_length != '\0'))	/* Garbage left */
 					{
diff --git a/src/interfaces/ecpg/test/Makefile b/src/interfaces/ecpg/test/Makefile
index 72f38035d3a..0b9135a5afb 100644
--- a/src/interfaces/ecpg/test/Makefile
+++ b/src/interfaces/ecpg/test/Makefile
@@ -2,7 +2,8 @@ all: test1 test2 test3 test4 perftest dyntest dyntest2
 
 LDFLAGS=-g -I /usr/local/pgsql/include -L/usr/local/pgsql/lib -lecpg -lpq
 
-ECPG=../preproc/ecpg -I../include
+ECPG=/usr/local/pgsql/bin/ecpg -I../include
+#ECPG=../preproc/ecpg -I../include
 
 .SUFFIXES: .pgc .c
 
@@ -18,4 +19,4 @@ dyntest2: dyntest2.c
 	$(ECPG) $? 
 
 clean:
-	rm -f test1 test2 test3 test4 perftest *.c *.o log dyntest dyntest2
+	rm -f test1 test2 test3 test4 perftest *.c log dyntest dyntest2
diff --git a/src/interfaces/ecpg/test/test1.pgc b/src/interfaces/ecpg/test/test1.pgc
index 67c1aa847fc..f98719d56f8 100644
--- a/src/interfaces/ecpg/test/test1.pgc
+++ b/src/interfaces/ecpg/test/test1.pgc
@@ -1,5 +1,3 @@
-
-
 exec sql include sqlca;
 
 exec sql whenever sqlerror do PrintAndStop(msg);
@@ -88,8 +86,9 @@ exec sql end declare section;
 	strcpy(msg, "commit");
 	exec sql commit;
 
-	/* Stop automatic transactioning for connection pm. */
-	exec sql at pm set autocommit to off;
+	/* Start automatic transactioning for connection pm. */
+	exec sql at pm set autocommit to on;
+	exec sql at pm begin transaction;
 
         strcpy(msg, "select");
         exec sql select name, amount, letter into :name, :amount, :letter from "Test";
@@ -117,14 +116,17 @@ exec sql end declare section;
         for (i=0, j=sqlca.sqlerrd[2]; i<j; i++)
             printf("name[%d]=%8.8s\tamount[%d]=%d\tletter[%d]=%c\n", i, name[i], i, amount[i],i, letter[i][0]);
         
-	strcpy(msg, "drop");
-	exec sql drop table "Test";
-	exec sql at pm drop table "Test";
-
 	strcpy(msg, "commit");
 	exec sql commit;
 	exec sql at pm commit;
 
+	/* Start automatic transactioning for connection main. */
+	exec sql set autocommit to on;
+
+	strcpy(msg, "drop");
+	exec sql drop table "Test";
+	exec sql at pm drop table "Test";
+
 	strcpy(msg, "disconnect"); 
         exec sql disconnect main;
 	exec sql disconnect pm;
diff --git a/src/interfaces/ecpg/test/test4.pgc b/src/interfaces/ecpg/test/test4.pgc
index 0ac00008e49..a45abc1ae6a 100644
--- a/src/interfaces/ecpg/test/test4.pgc
+++ b/src/interfaces/ecpg/test/test4.pgc
@@ -8,7 +8,7 @@ int
 main ()
 {
 EXEC SQL BEGIN DECLARE SECTION;
-	int i = 3;
+	int i = 1;
 	int *did = &i;
 	int a[10] = {9,8,7,6,5,4,3,2,1,0};
 	char text[10] = "klmnopqrst";
@@ -31,7 +31,7 @@ EXEC SQL END DECLARE SECTION;
 
 	EXEC SQL CREATE TABLE test (f float, i int, a int[10], text char(10), b bool);
 
-	EXEC SQL INSERT INTO test(f,i,a,text,b) VALUES(404.90,1,'{0,1,2,3,4,5,6,7,8,9}','abcdefghij', 'f');
+	EXEC SQL INSERT INTO test(f,i,a,text,b) VALUES(404.90,3,'{0,1,2,3,4,5,6,7,8,9}','abcdefghij', 'f');
 
 	EXEC SQL INSERT INTO test(f,i,a,text,b) VALUES(140787.0,2,:a,:text,'t');
 	
@@ -48,7 +48,7 @@ EXEC SQL END DECLARE SECTION;
 
 	printf("Found f=%f text=%10.10s b=%d\n", f, text, b);
 
-	f=14.07;
+	f=140787;
 	EXEC SQL SELECT a,text
 	 INTO :a,:t
 	 FROM test
-- 
GitLab