Bumped precompiler patchlevel.
- Removed duplicate include of ecpgtype.h.
- Changed INFORMIX mode symbol definition yet again because the old
way didn't work on NetBSD.
+
+Sun, 02 Mar 2008 11:50:48 +0100
+
+ - Fixed bug that caused arrays of varchar to be output with incomplete
+ name.
+
+Thu, 20 Mar 2008 16:54:27 +0100
+
+ - Changed statement escaping to not escape continuation line markers.
+ - Bumped ecpg version number to 4.4.1.
#
# Copyright (c) 1998-2008, PostgreSQL Global Development Group
#
-# $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/Makefile,v 1.130 2008/01/01 19:45:59 momjian Exp $
+# $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/Makefile,v 1.130.2.1 2008/03/20 16:04:52 meskes Exp $
#
#-------------------------------------------------------------------------
MAJOR_VERSION= 4
MINOR_VERSION= 4
-PATCHLEVEL=0
+PATCHLEVEL=1
override CPPFLAGS := -I../include -I$(top_srcdir)/src/interfaces/ecpg/include \
-I$(srcdir) -DMAJOR_VERSION=$(MAJOR_VERSION) \
-/* $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/output.c,v 1.23 2007/11/15 21:14:45 momjian Exp $ */
+/* $PostgreSQL: pgsql/src/interfaces/ecpg/preproc/output.c,v 1.23.2.1 2008/03/20 16:04:52 meskes Exp $ */
#include "postgres_fe.h"
else if (str[i] == '\n')
fputs("\\\n", yyout);
else if (str[i] == '\\')
- fputs("\\\\", yyout);
+ {
+ int j = i;
+
+ /* check whether this is a continuation line
+ * if it is, do not output anything because newlines are escaped anyway */
+
+ /* accept blanks after the '\' as some other compilers do too */
+ do { j++; } while (str[j] == ' ' || str[j] == '\t');
+
+ if ((str[j] != '\n') && (str[j] != '\r' || str[j + 1] != '\n')) /* not followed by a newline */
+ fputs("\\\\", yyout);
+ }
else if (str[i] == '\r' && str[i + 1] == '\n')
{
fputs("\\\r\n", yyout);