[24428] | 1 | #!/bin/bash
|
---|
| 2 | # Used to merge in the code needed to add TDB support to Greenstone. The script
|
---|
| 3 | # is responsible for updating both Makefile.in and source code files. You can
|
---|
| 4 | # later run 'disable_tdb.sh' to undo these changes.
|
---|
| 5 | # @author John Thompson, University of Waikato, NZ
|
---|
| 6 |
|
---|
| 7 | echo
|
---|
| 8 | echo '===== Merging TDB support code into Greenstone ====='
|
---|
| 9 | echo
|
---|
| 10 |
|
---|
| 11 | # Test that GSDLHOME is set otherwise we won't be able to find the required files
|
---|
[30253] | 12 | if [ "${GSDLHOME}x" == "x" ]
|
---|
| 13 | then
|
---|
| 14 | echo 'Error! GSDLHOME not set. Please source setup.bash before running.'
|
---|
| 15 | echo
|
---|
| 16 | exit 0
|
---|
| 17 | fi
|
---|
| 18 | if [ "${GSDLOS}x" == "x" ]
|
---|
| 19 | then
|
---|
| 20 | echo 'Error! GSDLOS not set. Please source setup.bash before running.'
|
---|
| 21 | echo
|
---|
| 22 | exit 0
|
---|
| 23 | fi
|
---|
[24428] | 24 |
|
---|
[30239] | 25 | # Black magic to determine the actual name of the extension folder (in case I
|
---|
| 26 | # change from tdb-edit to tdb in the future (writing in hindsight))
|
---|
[30254] | 27 | EXTDIR="${PWD}"
|
---|
| 28 | EXTNAME="${PWD##*/}"
|
---|
[30239] | 29 |
|
---|
[24428] | 30 | # - Symlink the source file into place
|
---|
[30253] | 31 | printf ' * Symlinking TDB source files into place... '
|
---|
| 32 | if [ -f "${GSDLHOME}/common-src/src/lib/tdbclass.h" ]
|
---|
| 33 | then
|
---|
| 34 | echo 'already present'
|
---|
| 35 | else
|
---|
[30254] | 36 | ln -f -s "${EXTDIR}/src/lib/tdbclass.h" "${GSDLHOME}/common-src/src/lib/tdbclass.h"
|
---|
| 37 | ln -f -s "${EXTDIR}/src/lib/tdbclass.cpp" "${GSDLHOME}/common-src/src/lib/tdbclass.cpp"
|
---|
[30253] | 38 | echo 'Done!'
|
---|
| 39 | fi
|
---|
| 40 |
|
---|
[24428] | 41 | # - Makefile.in
|
---|
[30253] | 42 | printf ' * Enabling TDB support in common function library... '
|
---|
[30239] | 43 | MAKEFILE="${GSDLHOME}/common-src/src/lib/Makefile.in"
|
---|
[25408] | 44 | # - I have no idea why this is commented out in the Makefile
|
---|
[30239] | 45 | sed -i 's:#GSDL_DIR = ../../..:GSDL_DIR = ../../..:' "${MAKEFILE}"
|
---|
| 46 | grep -q 'DUSE_TDB' "${MAKEFILE}"
|
---|
[24428] | 47 | if [ $? -eq 1 ]
|
---|
| 48 | then
|
---|
[30253] | 49 | # - Test for extension support in the makefile
|
---|
| 50 | grep -q 'EXT_DEFINES' "${MAKEFILE}"
|
---|
| 51 | if [ $? -eq 1 ]
|
---|
| 52 | then
|
---|
| 53 | # - No Extension variables yet - add them in with TDB parts
|
---|
[30257] | 54 | sed -i 's:AR = ar:# Support for adding in extension classes\nEXT_DEFINES = -DUSE_TDB\nEXT_INCLUDES = -I'${EXTDIR}'/'${GSDLOS}'/include\nEXT_SOURCES = tdbclass.cpp\nEXT_OBJECTS = tdbclass.o\n\n&:' "${MAKEFILE}"
|
---|
[30253] | 55 | sed -i 's:DEFS = @DEFS@ .*:& $(EXT_DEFINES):' "${MAKEFILE}"
|
---|
| 56 | sed -i 's:INCLUDES = -I. .*:& $(EXT_INCLUDES):' "${MAKEFILE}"
|
---|
| 57 | sed -i 's:unitool.cpp:& \\\n $(EXT_SOURCES):' "${MAKEFILE}"
|
---|
| 58 | sed -i 's:unitool.o:& \\\n $(EXT_OBJECTS):' "${MAKEFILE}"
|
---|
| 59 | else
|
---|
| 60 | # - Extension support already present - add TDB parts
|
---|
| 61 | sed -i 's:EXT_DEFINES =.*:& -DUSE_TDB:' "${MAKEFILE}"
|
---|
[30257] | 62 | sed -i 's:EXT_INCLUDES =.*:& -I'${EXTDIR}'/'${GSDLOS}'/include:' "${MAKEFILE}"
|
---|
[30253] | 63 | sed -i 's:EXT_SOURCES =.*:& tdbclass.cpp:' "${MAKEFILE}"
|
---|
| 64 | sed -i 's:EXT_OBJECTS =.*:& tdbclass.o:' "${MAKEFILE}"
|
---|
| 65 | fi
|
---|
| 66 | echo 'Done!'
|
---|
| 67 | else
|
---|
| 68 | echo 'already enabled'
|
---|
[24428] | 69 | fi
|
---|
[30239] | 70 | grep -q 'DUSE_TDB' "${MAKEFILE}"
|
---|
[25408] | 71 | if [ $? -eq 1 ]
|
---|
| 72 | then
|
---|
[30239] | 73 | echo "Error! Update of ${MAKEFILE} failed."
|
---|
[25408] | 74 | exit
|
---|
| 75 | fi
|
---|
[24428] | 76 |
|
---|
[30255] | 77 | # No runtime support needed for Greenstone3 - that's done via JNI
|
---|
| 78 | if [ "${GSDL3HOME}x" == "x" ]
|
---|
[24428] | 79 | then
|
---|
[30255] | 80 | printf ' * Enabling TDB support in collection server... '
|
---|
| 81 | # - Makefile.in
|
---|
| 82 | MAKEFILE="${GSDLHOME}/runtime-src/src/colservr/Makefile.in"
|
---|
| 83 | grep -q 'DUSE_TDB' "${MAKEFILE}"
|
---|
[30253] | 84 | if [ $? -eq 1 ]
|
---|
| 85 | then
|
---|
[30255] | 86 | # - Test for extension support in the makefile
|
---|
| 87 | grep -q 'EXT_DEFINES' "${MAKEFILE}"
|
---|
| 88 | if [ $? -eq 1 ]
|
---|
| 89 | then
|
---|
| 90 | sed -i 's:AR = ar:# Support for adding in extension classes\nEXT_DEFINES = -DUSE_TDB\nEXT_INCLUDES = -I$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/include -I$(GSDL_DIR)/ext/'${EXTNAME}'/src/lib\n\n&:' "${MAKEFILE}"
|
---|
| 91 | sed -i 's:DEFS = @DEFS@:& $(EXT_DEFINES):' "${MAKEFILE}"
|
---|
| 92 | sed -i 's:INCLUDES = -I. -I$(GSDL_DIR):& $(EXT_INCLUDES):' "${MAKEFILE}"
|
---|
| 93 | else
|
---|
| 94 | sed -i 's:EXT_DEFINES =.*:& -DUSE_TDB:' "${MAKEFILE}"
|
---|
| 95 | sed -i 's:EXT_INCLUDES =.*:& -I$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/include -I$(GSDL_DIR)/ext/'${EXTNAME}'/src/lib:' "${MAKEFILE}"
|
---|
| 96 | fi
|
---|
| 97 | echo 'Done!'
|
---|
[30253] | 98 | else
|
---|
[30255] | 99 | echo 'already enabled'
|
---|
[30253] | 100 | fi
|
---|
[30255] | 101 | grep -q 'DUSE_TDB' "${MAKEFILE}"
|
---|
| 102 | if [ $? -eq 1 ]
|
---|
| 103 | then
|
---|
| 104 | echo "Error! Update of ${MAKEFILE} failed."
|
---|
| 105 | exit
|
---|
| 106 | fi
|
---|
[25408] | 107 |
|
---|
[30255] | 108 | # - collectset.cpp
|
---|
| 109 | SRCFILE="${GSDLHOME}/runtime-src/src/colservr/collectset.cpp"
|
---|
| 110 | grep -q 'tdbclass.h' "${SRCFILE}"
|
---|
[30253] | 111 | if [ $? -eq 1 ]
|
---|
| 112 | then
|
---|
[30255] | 113 | grep -q '@EXTENSION HEADERS@' "${SRCFILE}"
|
---|
| 114 | if [ $? -eq 1 ]
|
---|
| 115 | then
|
---|
| 116 | sed -i 's:collectset\:\:collectset (text_t& gsdlhome, text_t& collecthome):// @EXTENSION HEADERS@\n#include "tdbclass.h //TDB\n\n&:' "${SRCFILE}"
|
---|
| 117 | sed -i 's: // Use GDBM if the infodb type is empty or not one of the values above: // @EXTENSION DATASOURCES@\n if (infodbtype == "tdb") {db_ptr = new tdbclass(gsdlhome);} //TDB\n if (infodbtype == "tdbserver") {db_ptr = new tdbclass(gsdlhome);} //TDBServer\n\n&:' "${SRCFILE}"
|
---|
| 118 | else
|
---|
| 119 | sed -i 's:// @EXTENSION HEADERS@:&\n#include "tdbclass.h" //TDB:' "${SRCFILE}"
|
---|
| 120 | sed -i 's:// @EXTENSION DATASOURCES@:&\n if (infodbtype == "tdb") {db_ptr = new tdbclass(gsdlhome);} //TDB\n if (infodbtype == "tdbserver") {db_ptr = new tdbclass(gsdlhome);} //TDBServer:' "${SRCFILE}"
|
---|
| 121 | fi
|
---|
[30253] | 122 | fi
|
---|
[30255] | 123 | grep -q 'tdbclass.h' "${SRCFILE}"
|
---|
| 124 | if [ $? -eq 1 ]
|
---|
| 125 | then
|
---|
| 126 | echo "Error! Update of ${SRCFILE} failed."
|
---|
| 127 | exit
|
---|
| 128 | fi
|
---|
[24428] | 129 |
|
---|
[30255] | 130 | # - collectserver.cpp
|
---|
| 131 | # There are now sanity tests in collectserver to ensure appropriate indexer
|
---|
| 132 | # and infodbtype are compiled into colservr. While not fatal to leave this
|
---|
| 133 | # as is, it does cause vast amounts of error messages in (Apache) logs
|
---|
| 134 | SRCFILE="${GSDLHOME}/runtime-src/src/colservr/collectserver.cpp"
|
---|
| 135 | grep -q 'TDB' "${SRCFILE}"
|
---|
[30253] | 136 | if [ $? -eq 1 ]
|
---|
| 137 | then
|
---|
[30255] | 138 | grep -q '@EXTENSION DATASOURCES@' "${SRCFILE}"
|
---|
| 139 | if [ $? -eq 1 ]
|
---|
| 140 | then
|
---|
| 141 | sed -i 's: if (infodbtype=="gdbm") {: // @EXTENSION DATASOURCES@\n if (infodbtype == "tdb") { return; } // TDB Do nothing\n if (infodbtype == "tdbserver") { return; } // TDBServer Do nothing\n\n&:' "${SRCFILE}"
|
---|
| 142 | else
|
---|
| 143 | sed -i 's: // @EXTENSION DATASOURCES@:&\n if (infodbtype == "tdb") { return; } // TDB Do nothing\n if (infodbtype == "tdbserver") { return; } // TDBServer Do nothing:' "${SRCFILE}"
|
---|
| 144 | fi
|
---|
[30253] | 145 | fi
|
---|
[30255] | 146 | grep -q 'TDB' "${SRCFILE}"
|
---|
| 147 | if [ $? -eq 1 ]
|
---|
| 148 | then
|
---|
| 149 | echo "Error! Update of ${SRCFILE} failed."
|
---|
| 150 | exit
|
---|
| 151 | fi
|
---|
[25251] | 152 |
|
---|
[30255] | 153 | printf ' * Enabling TDB support in Greenstone receptionist... '
|
---|
| 154 | # - Makefile.in
|
---|
| 155 | MAKEFILE="${GSDLHOME}/runtime-src/src/recpt/Makefile.in"
|
---|
| 156 | grep -q 'DUSE_TDB' "${MAKEFILE}"
|
---|
[30253] | 157 | if [ $? -eq 1 ]
|
---|
| 158 | then
|
---|
[30255] | 159 | grep -q 'EXT_DEFINES' "${MAKEFILE}"
|
---|
| 160 | if [ $? -eq 1 ]
|
---|
| 161 | then
|
---|
| 162 | sed -i 's:AR = ar:# Support for adding in extension classes\nEXT_DEFINES = -DUSE_TDB\nEXT_INCLUDES = -I$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/include -I$(GSDL_DIR)/ext/'${EXTNAME}'/src/lib\nEXT_LDFLAGS = -L$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/lib\nEXT_LIBS = -ltdb\n\n&:' "${MAKEFILE}"
|
---|
| 163 | sed -i 's:DEFS = @DEFS@ -DNZDL -DQUIET -DSHORT_SUFFIX -DPARADOCNUM -DHAVE_CONFIG_H:& $(EXT_DEFINES):' "${MAKEFILE}"
|
---|
| 164 | sed -i 's:INCLUDES = -I. -I$(GSDL_DIR):& $(EXT_INCLUDES):' "${MAKEFILE}"
|
---|
| 165 | sed -i 's:LDFLAGS = @LDFLAGS@ @ARCH_DEP_FLAGS@:& $(EXT_LDFLAGS):' "${MAKEFILE}"
|
---|
| 166 | sed -i 's:LIBS = @LIBS@ $(GDBM_LIBS):& $(EXT_LIBS):' "${MAKEFILE}"
|
---|
| 167 | else
|
---|
| 168 | sed -i 's:EXT_DEFINES =.*:& -DUSE_TDB:' "${MAKEFILE}"
|
---|
| 169 | sed -i 's:EXT_INCLUDES =.*:& -I$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/include -I$(GSDL_DIR)/ext/'${EXTNAME}'/src/lib:' "${MAKEFILE}"
|
---|
| 170 | sed -i 's:EXT_LDFLAGS =.*:& -L$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/lib:' "${MAKEFILE}"
|
---|
| 171 | sed -i 's:EXT_LIBS =.*:& -ltdb:' "${MAKEFILE}"
|
---|
| 172 | fi
|
---|
| 173 | echo 'Done!'
|
---|
[30253] | 174 | else
|
---|
[30255] | 175 | echo 'already enabled'
|
---|
[30253] | 176 | fi
|
---|
[30255] | 177 | grep -q 'DUSE_TDB' "${MAKEFILE}"
|
---|
| 178 | if [ $? -eq 1 ]
|
---|
| 179 | then
|
---|
| 180 | echo "Error! Update of ${MAKEFILE} failed."
|
---|
| 181 | fi
|
---|
[24428] | 182 |
|
---|
[30255] | 183 | printf ' * Enabling TDB support in OAI Server receptionist... '
|
---|
| 184 | # - Makefile.in
|
---|
| 185 | MAKEFILE="${GSDLHOME}/runtime-src/src/oaiservr/Makefile.in"
|
---|
| 186 | grep -q 'DUSE_TDB' "${MAKEFILE}"
|
---|
[30253] | 187 | if [ $? -eq 1 ]
|
---|
| 188 | then
|
---|
[30255] | 189 | grep -q 'EXT_DEFINES' "${MAKEFILE}"
|
---|
| 190 | if [ $? -eq 1 ]
|
---|
| 191 | then
|
---|
| 192 | sed -i 's:CC = @CC@:# Support for adding in extension classes\nEXT_DEFINES = -DUSE_TDB\nEXT_INCLUDES = -I$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/include -I$(GSDL_DIR)/ext/'${EXTNAME}'/src/lib\nEXT_LDFLAGS = -L$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/lib\nEXT_LIBS = -ltdb\n\n&:' "${MAKEFILE}"
|
---|
| 193 | sed -i 's:DEFS = @DEFS@:& $(EXT_DEFINES):' "${MAKEFILE}"
|
---|
| 194 | sed -i 's:INCLUDES = -I$(COMMON_DIR)/src/lib:& $(EXT_INCLUDES):' "${MAKEFILE}"
|
---|
| 195 | sed -i 's:LDFLAGS = @LDFLAGS@ @ARCH_DEP_FLAGS@:& $(EXT_LDFLAGS):' "${MAKEFILE}"
|
---|
| 196 | sed -i 's:LIBS = @LIBS@ $(GDBM_LIBS):& $(EXT_LIBS):' "${MAKEFILE}"
|
---|
| 197 | else
|
---|
| 198 | sed -i 's:EXT_DEFINES =.*:& -DUSE_TDB:' "${MAKEFILE}"
|
---|
| 199 | sed -i 's:EXT_INCLUDES =.*:& -I$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/include -I$(GSDL_DIR)/ext/'${EXTNAME}'/src/lib:' "${MAKEFILE}"
|
---|
| 200 | sed -i 's:EXT_LDFLAGS =.*:& -L$(GSDL_DIR)/ext/'${EXTNAME}'/'${GSDLOS}'/lib:' "${MAKEFILE}"
|
---|
| 201 | sed -i 's:EXT_LIBS =.*:& -ltdb:' "${MAKEFILE}"
|
---|
| 202 | fi
|
---|
| 203 | echo 'Done!'
|
---|
[30253] | 204 | else
|
---|
[30255] | 205 | echo 'already enabled'
|
---|
[30253] | 206 | fi
|
---|
[30255] | 207 | grep -q 'DUSE_TDB' "${MAKEFILE}"
|
---|
| 208 | if [ $? -eq 1 ]
|
---|
| 209 | then
|
---|
| 210 | echo "Error! Update of ${MAKEFILE} failed."
|
---|
| 211 | fi
|
---|
[30253] | 212 | else
|
---|
[30255] | 213 | echo " * Runtime TDB support delegated to Java/JNI/TDB bridge."
|
---|
[24428] | 214 | fi
|
---|
| 215 |
|
---|
| 216 | echo
|
---|
| 217 | echo '===================================================='
|
---|
| 218 | echo
|
---|
| 219 | echo 'TDB support has now been merged into Greenstone.'
|
---|
| 220 | echo 'Please return to the main Greenstone directory and '
|
---|
| 221 | echo 'rerun:'
|
---|
| 222 | echo
|
---|
[30257] | 223 | if [ "${GSDL3HOME}x" == "x" ]
|
---|
| 224 | then
|
---|
| 225 | echo ' ./configure <any required arguments>'
|
---|
| 226 | echo ' make'
|
---|
| 227 | echo ' make install'
|
---|
| 228 | else
|
---|
| 229 | echo ' ant install'
|
---|
| 230 | fi
|
---|
[24428] | 231 | echo
|
---|
| 232 | echo 'to complete TDB installation.'
|
---|
| 233 | echo
|
---|
[30239] | 234 | echo 'Should you later wish to remove TDB support run:'
|
---|
| 235 | echo
|
---|
| 236 | echo ' ./disable_tdb.sh'
|
---|
| 237 | echo
|
---|
[24428] | 238 | echo '===================================================='
|
---|
| 239 | echo
|
---|
| 240 |
|
---|
[30239] | 241 | exit 0
|
---|