summaryrefslogtreecommitdiff
path: root/databases/firebird-server/files
diff options
context:
space:
mode:
authorYing-Chieh Liao <ijliao@FreeBSD.org>2002-11-11 17:23:49 +0000
committerYing-Chieh Liao <ijliao@FreeBSD.org>2002-11-11 17:23:49 +0000
commit1f412c28a53a1b08c4f6c3a64677e0568388577c (patch)
tree7b8c29151266c541a5201c165909c912cbd3cc59 /databases/firebird-server/files
parentupgrade to 20021103 (diff)
Add SuperServer build
Remove perl from scripts Remove scripts + consolidate into pkg-install PR: 45185 Submitted by: maintainer
Notes
Notes: svn path=/head/; revision=69904
Diffstat (limited to 'databases/firebird-server/files')
-rw-r--r--databases/firebird-server/files/RELNOTES9
-rw-r--r--databases/firebird-server/files/buildit.sh3
-rw-r--r--databases/firebird-server/files/patch-builds::original::boot.sfx.interbase38
-rw-r--r--databases/firebird-server/files/patch-builds::original::edit_make32
-rw-r--r--databases/firebird-server/files/patch-builds::original::platform13
-rw-r--r--databases/firebird-server/files/patch-builds::original::prefix.freebsd102
-rw-r--r--databases/firebird-server/files/patch-jrd::gds.c24
-rw-r--r--databases/firebird-server/files/patch-jrd::isc_file.c15
-rw-r--r--databases/firebird-server/files/patch-jrd::isc_sync.c38
-rw-r--r--databases/firebird-server/files/patch-jrd::jrd.h12
-rw-r--r--databases/firebird-server/files/patch-jrd::thd.c20
-rw-r--r--databases/firebird-server/files/patch-jrd::thd.h14
-rw-r--r--databases/firebird-server/files/patch-lock::lock.h13
13 files changed, 332 insertions, 1 deletions
diff --git a/databases/firebird-server/files/RELNOTES b/databases/firebird-server/files/RELNOTES
index 5434347e24d2..a452990122ee 100644
--- a/databases/firebird-server/files/RELNOTES
+++ b/databases/firebird-server/files/RELNOTES
@@ -1,4 +1,4 @@
-Firebird 1.0.0 FreeBSD Release Notes 13-Mar-2002
+Firebird 1.0.0 FreeBSD Release Notes 10-Nov-2002
--------------------------------------
FB-T6.2.796 Firebird Final Release
@@ -64,6 +64,13 @@ try stopping PostgreSQL:
and see if that helps.
+ Super Server support has recently been added. However, there is
+anecdotal evidence that it is not as reliable nor as scalable as the
+Classic Server version. For this reason, I have not included a
+start up method for Super Server. For those that are interested,
+traversing to /usr/interbase/misc will find the startup scripts for
+the various flavours of Linux.
+
Complete documentation for InterBase(tm) is available (free of
charge) from http://www.interbase.com/ in PDF format. While
InterBase and Firebird are two distinct entities, all InterBase
diff --git a/databases/firebird-server/files/buildit.sh b/databases/firebird-server/files/buildit.sh
new file mode 100644
index 000000000000..d48627c0e21e
--- /dev/null
+++ b/databases/firebird-server/files/buildit.sh
@@ -0,0 +1,3 @@
+#!/bin/sh
+. Configure_SetupEnv.sh
+make super_firebird
diff --git a/databases/firebird-server/files/patch-builds::original::boot.sfx.interbase b/databases/firebird-server/files/patch-builds::original::boot.sfx.interbase
new file mode 100644
index 000000000000..62d0b483a07d
--- /dev/null
+++ b/databases/firebird-server/files/patch-builds::original::boot.sfx.interbase
@@ -0,0 +1,38 @@
+--- builds/original/boot.sfx.interbase.orig Tue Dec 18 01:40:08 2001
++++ builds/original/boot.sfx.interbase Sat Nov 9 17:44:54 2002
+@@ -68,7 +68,7 @@
+ #added completed according to inprise tree
+ #FSG 093000
+
+-firebird: gds.h includes fireboot run_codes executables help msgs msgs_intl extlib examples completed
++firebird: gds.h includes fireboot run_codes executables help msgs msgs_intl extlib completed
+
+ # burp wanted to build gpre
+ # we break this dependency
+@@ -159,14 +159,14 @@
+ # 1995-June-7 David Schnepper
+ # removed pyxis 3-Aug-00 TMC
+ #executables: alice burp dudley gpre miscFiles $(INTL) isql locks \
+- $(SUPER_SERVER) qli remote spit utilities \
+- $(SHARED_AM) $(LINKABLE_LIBS)
++# $(SUPER_SERVER) qli remote spit utilities \
++# $(SHARED_AM) $(LINKABLE_LIBS)
+
+ executables: alice dudley miscFiles $(INTL) isql locks \
+ $(SUPER_SERVER) qli remote spit utilities \
+ $(SHARED_AM) $(LINKABLE_LIBS)
+
+-super_firebird: gds.h includes fireboot super_targets dudley superMiscFiles $(INTL) isql locks qli remote spit help msgs msgs_intl dba gfix gsec security_db extlib examples completed
++super_firebird: gds.h includes fireboot super_targets dudley superMiscFiles $(INTL) isql locks qli remote spit help msgs msgs_intl dba gfix relay gsec security_db extlib completed
+
+ super_targets: s_run_codes s_alice s_burp s_dba s_security_c super_client super_server super_utils
+
+@@ -195,7 +195,7 @@
+
+ super_client: force
+ $(QUIET_ECHO) "Building super/client..."
+- $(SH) '$(CD) source/super/client; $(MAKE) CFLAGS="$(CFLAGS) -DSUPERCLIENT" SYSTEM="$(SYSTEM)" super_client'
++ $(SH) '$(CD) source/super/client; $(MAKE) SYSTEM="$(SYSTEM)" super_client'
+
+ csu gcsu: $(ACCESS_METHOD) force
+ $(QUIET_ECHO) "Building GCSU..."
diff --git a/databases/firebird-server/files/patch-builds::original::edit_make b/databases/firebird-server/files/patch-builds::original::edit_make
new file mode 100644
index 000000000000..d107078c7a59
--- /dev/null
+++ b/databases/firebird-server/files/patch-builds::original::edit_make
@@ -0,0 +1,32 @@
+--- builds/original/edit_make.orig Fri Aug 4 06:42:41 2000
++++ builds/original/edit_make Sat Nov 9 16:06:59 2002
+@@ -16,13 +16,25 @@
+ # Contributor(s): ______________________________________.
+ if [ "$SYS_TYPE" != "NOLINK_OS" -a "$1" != "WIN_NT" -a "$1" != "OS2" -a $1 != 'WIN_NTS' ]; then
+ if [ "$3" = "make.client" ]; then
+- sed -e "s/\$(SUPER_FLAG)/-DSUPERCLIENT/g" \
+- -e "s/\$(SYSTEM)/$1/g" \
+- -e "s/\$(VERSION)/$2/g" \
+- -e "s?\$(DB_DIR)?$DB_DIR?g" $3 > $4
++ if [ "$FBBUILDHACK" = "FREEBSD" ]; then
++ sed -e "s/\$(SUPER_FLAG)/-DSUPERCLIENT -D_REENTRANT -D_THREAD_SAFE/g" \
++ -e "s/\$(SYSTEM)/$1/g" \
++ -e "s/\$(VERSION)/$2/g" \
++ -e "s?\$(DB_DIR)?$DB_DIR?g" $3 > $4
++ else
++ sed -e "s/\$(SUPER_FLAG)/-DSUPERCLIENT/g" \
++ -e "s/\$(SYSTEM)/$1/g" \
++ -e "s/\$(VERSION)/$2/g" \
++ -e "s?\$(DB_DIR)?$DB_DIR?g" $3 > $4
++ fi
+ elif [ "$3" = "make.dsql_ss" -o "$3" = "make.intl_ss" -o "$3" = "make.journal_ss" -o "$3" = "make.jrd_ss" -o "$3" = "make.lock_ss" -o "$3" = "make.remote_ss" -o "$3" = "make.wal_ss" -o "$3" = "make.burp_ss" -o "$3" = "make.alice_ss" -o "$3" = "make.utilities_ss" ]; then
+ if [ "$1" = "HP10" -o "$1" = "LINUX" ]; then
+ sed -e "s/\$(SUPER_FLAG)/-DSUPERSERVER -D_REENTRANT/g" \
++ -e "s/\$(SYSTEM)/$1/g" \
++ -e "s/\$(VERSION)/$2/g" \
++ -e "s?\$(DB_DIR)?$DB_DIR?g" $3 > $4
++ elif [ "$FBBUILDHACK" = "FREEBSD" ]; then
++ sed -e "s/\$(SUPER_FLAG)/-DSUPERSERVER -D_REENTRANT -D_THREAD_SAFE/g" \
+ -e "s/\$(SYSTEM)/$1/g" \
+ -e "s/\$(VERSION)/$2/g" \
+ -e "s?\$(DB_DIR)?$DB_DIR?g" $3 > $4
diff --git a/databases/firebird-server/files/patch-builds::original::platform b/databases/firebird-server/files/patch-builds::original::platform
new file mode 100644
index 000000000000..149f2fe3a4f6
--- /dev/null
+++ b/databases/firebird-server/files/patch-builds::original::platform
@@ -0,0 +1,13 @@
+--- builds/original/platform.orig Sun Sep 16 22:15:14 2001
++++ builds/original/platform Sat Nov 9 16:16:23 2002
+@@ -32,6 +32,10 @@
+ SYS_TYPE=GENERIC
+ fi
+ export SYS_TYPE
++if [ $1 = 'FREEBSD' ]; then
++ FBBUILDHACK=$1
++ export FBBUILDHACK
++fi
+ #
+ if [ $1 = 'SUN3_4' -o $1 = 'SUN4' -o $1 = 'AP' -o $1 = 'AX' ]; then
+ TR='tr "A-Z" "a-z"'
diff --git a/databases/firebird-server/files/patch-builds::original::prefix.freebsd b/databases/firebird-server/files/patch-builds::original::prefix.freebsd
new file mode 100644
index 000000000000..ec8d8343f61d
--- /dev/null
+++ b/databases/firebird-server/files/patch-builds::original::prefix.freebsd
@@ -0,0 +1,102 @@
+--- builds/original/prefix.freebsd.orig Sat Jan 13 05:18:13 2001
++++ builds/original/prefix.freebsd Sat Nov 9 16:49:17 2002
+@@ -28,20 +28,20 @@
+
+
+ PROD_DEBUG_OBJECTS= nodebug.o
+-PROD_SHRLIB_DIR= -Lsource/jrd
++PROD_SHRLIB_DIR= -Lsource/jrd -Lsource/interbase/lib
+ PROD_VERSION_FLAG= -DPROD_BUILD
+-PROD_CFLAGS= -O -m486 -fpic -DFLINTSTONE
++PROD_CFLAGS= -O -pipe -march=i486 -fpic -DFLINTSTONE
+
+
+ DEV_DEBUG_OBJECTS= grammar.o dbg.o dbt.o dmp.o
+-DEV_SHRLIB_DIR= -Lsource/jrd
++DEV_SHRLIB_DIR= -Lsource/jrd -Lsource/interbase/lib
+ DEV_VERSION_FLAG= -DDEV_BUILD
+ DEV_CFLAGS= -ggdb
+
+ DEBUG_OBJECTS= $($(VERSION)_DEBUG_OBJECTS)
+ SHRLIB_DIR= $($(VERSION)_SHRLIB_DIR)
+ VERSION_FLAG= $($(VERSION)_VERSION_FLAG)
+-CFLAGS_COMMON= $($(VERSION)_CFLAGS) -Isource/interbase/include -DFREEBSD -w -fwritable-strings
++CFLAGS_COMMON= $($(VERSION)_CFLAGS) -DFREEBSD -w -fwritable-strings -Isource/interbase/include
+ CFLAGS= $(CFLAGS_COMMON) $(SUPER_FLAG)
+ PIC_J_CFLAGS= $(CFLAGS_COMMON) -DPIPE_IS_SHRLIB -fPIC
+ SPECIAL_OBJECTS= j
+@@ -62,21 +62,21 @@
+ BIN_PATH= interbase/bin
+ BRIDGE_MISC= head5.o allp.o
+ CHMOD_VAL= 666
+-CURSES_LIB= -lncurses
++CURSES_LIB=
+ DSQL_P_OBJS= dsql_p_objects
+-FORM_OBJECTS= form.o
+-FORM_TRN_OBJECTS= form_trn.o
++FORM_OBJECTS= noform.o
++FORM_TRN_OBJECTS=
+ FUNCTIONS= functions.bin
+ FUNCSHR= source/interbase/lib/gdsf.so
+ GDS_LINK= $(GDSSHR_LINK)
+-GDS_PYXIS= gds_pyxis.a
++GDS_PYXIS=
+ GDSLIB_BACKEND= source/interbase/lib/gds_b.a
+ GDSLIB_LINK= -Lsource/jrd -lgds_b -lc -ldescrypt
+
+ GDSSHR= source/interbase/lib/gds.so
+ LINUX_GDSSHR= $(GDSSHR)
+-GDSSHR_LINK= $(SHRLIB_DIR) -lgds -lgds_pyxis -ldescrypt
+-PIPE_GDSSHR_LINK= $(SHRLIB_DIR) -lgds -lgds_pyxis
++GDSSHR_LINK= $(SHRLIB_DIR) -lgds -ldescrypt
++PIPE_GDSSHR_LINK= $(SHRLIB_DIR) -lgds
+ HLPDIR= source/qli/
+ HOSTNAME= `hostname | cut -d'.' -f1`
+ INCLUDES= include_so include_so_ada
+@@ -92,7 +92,7 @@
+ JRD_J_MISC_OBJECTS= source/jrd/sun_ftn.j
+ JRD_P_MISC_OBJECTS= source/jrd/sun_ftn.bin source/jrd/nodebug.bin
+ LANG_OBJECTS= ada.o ftn.o cob.o
+-LANGUAGES= cc cxx ada sun_ada microfocus_cob make16 gdl1 sun_ftn
++LANGUAGES= cc cxx ada microfocus_cob make16 gdl1 sun_ftn
+ LD_LIBS= -lc
+ LD_LIBS_J= -lc
+ LD_OPTS= -shared
+@@ -104,28 +104,28 @@
+ MUISQL_LINK_OPTS= $(MUISQL_MU_LIB) $(PIPE_GDSSHR_LINK) -lm
+ PIC_FLAGS= $(CFLAGS) -fPIC
+ PIPE= gds.a gds_pipe
+-PYXIS= pyxis
+-PYXIS_MISC_OBJS= $(PYXIS_MISC)
+-PYXIS_P_MISC_OBJS= $(PYXIS_P_MISC)
+-PYXIS_OBJECTS= pyxis_objects
+-PYXIS_MISC_OBJECTS= $(PYXDIR)cdm.o $(PYXDIR)vt100.o $(PYXDIR)sun_ftn_pyxis.o
++PYXIS=
++PYXIS_MISC_OBJS=
++PYXIS_P_MISC_OBJS=
++PYXIS_OBJECTS=
++PYXIS_MISC_OBJECTS=
+ REG_HELP= isc_ins_hlp.dat
+ REMOTE_GDSSHR= $(GDSSHR)
+ REMOTE_GDSSHR_LINK= $(SERVER_LINK)
+ REMOTE_P_OBJS= rem_p_objects
+-SCREEN_LIBS=
+-#SCREEN_LIBS= -lncurses
++#SCREEN_LIBS=
++SCREEN_LIBS= -lncurses
+ SERVER_LINK= $(GDSSHR_LINK)
+ SETUP_ISC= ISC_USER=sysdba; ISC_PASSWORD=masterkey; export ISC_USER ISC_PASSWORD;
+ SPECIAL_OPT= source/special_opt
+ NETWORK_LIB=
+ SOCKET_LIB= -lc
+-THREAD_LIB= -llthread
++THREAD_LIB= -pthread
+ SUN_FUNCSHR= $(FUNCSHR)
+ LX_SUPER_GDSSHR= source/interbase/lib/gds.so.1
+ SUPER_CLIENT_GDSSHR= $(LX_SUPER_GDSSHR)
+ SUPER_BACKEND= source/jrd/gds_ss.a
+-SUPER_LINK= -Lsource/jrd -lgds_ss -lc -ldescrypt -L/usr/local/lib -llthread
++SUPER_LINK= -pthread -Lsource/jrd -lgds_ss -ldescrypt
+ SUPER_SERVER=
+ UTILITIES=
+ WAL_P_OBJS= wal_p_objects
diff --git a/databases/firebird-server/files/patch-jrd::gds.c b/databases/firebird-server/files/patch-jrd::gds.c
new file mode 100644
index 000000000000..523abb725403
--- /dev/null
+++ b/databases/firebird-server/files/patch-jrd::gds.c
@@ -0,0 +1,24 @@
+--- jrd/gds.c.orig Sat Mar 2 00:15:11 2002
++++ jrd/gds.c Sun Jul 7 14:27:44 2002
+@@ -159,7 +159,7 @@
+ engine and this change may imply side effect I haven't known
+ about yet. Tomas Nejedlik (tomas@nejedlik.cz)
+ */
+-#if (defined(LINUX) && defined(SUPERCLIENT))
++#if ((defined(LINUX) || defined(FREEBSD)) && defined(SUPERCLIENT))
+ #define V4_THREADING
+ #endif
+
+@@ -3510,9 +3510,9 @@
+ #else
+ (MAP_ANON |
+ #endif
+-#if (!defined LINUX && !defined DARWIN)
+-/* In LINUX, Solaris, and Darwin there is no such thing as MAP_VARIABLE. Hence, it gives
+- compilation error. The equivalent functionality is default,
++#if (!defined LINUX && !defined DARWIN && !defined FREEBSD)
++/* In LINUX, Solaris, FreeBSD and Darwin there is no such thing as MAP_VARIABLE.
++ Hence, it gives compilation error. The equivalent functionality is default,
+ if you do not specify MAP_FIXED */
+ MAP_VARIABLE |
+ #endif /* LINUX */
diff --git a/databases/firebird-server/files/patch-jrd::isc_file.c b/databases/firebird-server/files/patch-jrd::isc_file.c
new file mode 100644
index 000000000000..7047f182d59c
--- /dev/null
+++ b/databases/firebird-server/files/patch-jrd::isc_file.c
@@ -0,0 +1,15 @@
+--- jrd/isc_file.c.orig Tue Dec 18 01:40:18 2001
++++ jrd/isc_file.c Sat Jul 6 18:04:55 2002
+@@ -106,6 +106,12 @@
+ #define MTAB_CLOSE(stream) ib_fclose (stream)
+ #endif
+
++#ifdef FREEBSD
++#define MTAB "/etc/fstab"
++#define MTAB_OPEN(path,type) ib_fopen (path, type)
++#define MTAB_CLOSE(stream) ib_fclose (stream)
++#endif
++
+ #ifdef DARWIN
+ #define MTAB "/etc/fstab.hd"
+ #define MTAB_OPEN(path,type) ib_fopen (path, type)
diff --git a/databases/firebird-server/files/patch-jrd::isc_sync.c b/databases/firebird-server/files/patch-jrd::isc_sync.c
new file mode 100644
index 000000000000..19e327a1705f
--- /dev/null
+++ b/databases/firebird-server/files/patch-jrd::isc_sync.c
@@ -0,0 +1,38 @@
+--- jrd/isc_sync.c.orig Tue Mar 5 21:11:25 2002
++++ jrd/isc_sync.c Sat Jul 6 18:06:30 2002
+@@ -1467,7 +1467,7 @@
+ pthread_mutex_init (event->event_mutex, pthread_mutexattr_default);
+ pthread_cond_init (event->event_semnum, pthread_condattr_default);
+ #else
+-#if (defined linux || defined DARWIN)
++#if (defined linux || defined DARWIN || defined FREEBSD)
+ pthread_mutex_init (event->event_mutex, NULL);
+ pthread_cond_init (event->event_semnum, NULL);
+ #else
+@@ -1596,7 +1596,7 @@
+ #ifdef HP10
+ if (micro_seconds > 0 && (ret == -1) && (errno == EAGAIN))
+ #else
+-#if (defined linux || defined DARWIN)
++#if (defined linux || defined DARWIN || defined FREEBSD)
+ if (micro_seconds > 0 && (ret == ETIMEDOUT))
+ #else
+ if (micro_seconds > 0 && (ret == ETIME))
+@@ -5198,7 +5198,7 @@
+ **************************************/
+ int state;
+
+-#if (!defined HP10 && !defined linux && !defined DARWIN)
++#if (!defined HP10 && !defined linux && !defined DARWIN && !defined FREEBSD)
+
+ pthread_mutexattr_t mattr;
+
+@@ -5218,7 +5218,7 @@
+ server (until we are to implement local IPC using shared
+ memory in which case we need interprocess thread sync.
+ */
+-#if (defined linux || defined DARWIN)
++#if (defined linux || defined DARWIN || defined FREEBSD)
+ return pthread_mutex_init (mutex->mtx_mutex, NULL);
+ #else
+ state = pthread_mutex_init (mutex->mtx_mutex, pthread_mutexattr_default);
diff --git a/databases/firebird-server/files/patch-jrd::jrd.h b/databases/firebird-server/files/patch-jrd::jrd.h
new file mode 100644
index 000000000000..0a280080c74a
--- /dev/null
+++ b/databases/firebird-server/files/patch-jrd::jrd.h
@@ -0,0 +1,12 @@
+--- jrd/jrd.h.orig Tue May 14 19:01:06 2002
++++ jrd/jrd.h Tue May 14 19:23:44 2002
+@@ -717,7 +717,8 @@
+ #ifdef MULTI_THREAD
+ #if (defined APOLLO || defined DECOSF || defined NETWARE_386 || \
+ defined NeXT || defined SOLARIS_MT || defined WIN_NT || \
+- defined OS2_ONLY || defined HP10 || defined LINUX || defined DARWIN)
++ defined OS2_ONLY || defined HP10 || defined LINUX || \
++ defined DARWIN || defined FREEBSD)
+ #define PLATFORM_GET_THREAD_DATA ((TDBB) THD_get_specific())
+ #endif
+ #endif
diff --git a/databases/firebird-server/files/patch-jrd::thd.c b/databases/firebird-server/files/patch-jrd::thd.c
new file mode 100644
index 000000000000..a09c3fe4e1c3
--- /dev/null
+++ b/databases/firebird-server/files/patch-jrd::thd.c
@@ -0,0 +1,20 @@
+--- jrd/thd.c.orig Thu May 24 14:11:11 2001
++++ jrd/thd.c Sun Jul 7 14:52:07 2002
+@@ -2605,7 +2605,7 @@
+ int detach_state=PTHREAD_CREATE_DETACHED
+ #endif
+
+-#if ( !defined HP10 && !defined linux )
++#if ( !defined HP10 && !defined linux && !defined FREEBSD )
+
+ state = pthread_attr_init (&pattr);
+ if (state)
+@@ -2628,7 +2628,7 @@
+ return state;
+
+ #else
+-#ifdef linux
++#if ( defined linux || defined FREEBSD )
+ if (state = pthread_create (&thread, NULL, routine, arg))
+ return state;
+ return pthread_detach (thread);
diff --git a/databases/firebird-server/files/patch-jrd::thd.h b/databases/firebird-server/files/patch-jrd::thd.h
new file mode 100644
index 000000000000..b4e74ecfbe59
--- /dev/null
+++ b/databases/firebird-server/files/patch-jrd::thd.h
@@ -0,0 +1,14 @@
+--- jrd/thd.h.orig Sat Mar 2 00:16:31 2002
++++ jrd/thd.h Mon May 13 19:10:37 2002
+@@ -98,6 +98,11 @@
+ #define MULTI_THREAD 1
+ #endif
+
++#if (defined(FREEBSD) && defined(SUPERSERVER))
++#define POSIX_THREADS 1
++#define MULTI_THREAD 1
++#endif
++
+ #ifdef VMS
+ #ifndef GATEWAY
+ #define MULTI_THREAD 1
diff --git a/databases/firebird-server/files/patch-lock::lock.h b/databases/firebird-server/files/patch-lock::lock.h
new file mode 100644
index 000000000000..fe7ad684d99e
--- /dev/null
+++ b/databases/firebird-server/files/patch-lock::lock.h
@@ -0,0 +1,13 @@
+--- lock/lock.h.orig Wed Jun 6 05:43:58 2001
++++ lock/lock.h Sat Jul 6 18:08:56 2002
+@@ -65,8 +65,10 @@
+ #ifndef SOLARIS_MT
+ #if !(defined(HP10) && defined(SUPERSERVER))
+ #if !(defined(LINUX) && defined(SUPERSERVER))
++#if !(defined(FREEBSD) && defined(SUPERSERVER))
+ #ifndef DARWIN
+ #define MANAGER_PROCESS
++#endif
+ #endif
+ #endif
+ #endif