Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.framework / org.gvsig.andami / src / main / resources-application / gvSIG.sh @ 41312

History | View | Annotate | Download (9.69 KB)

1
#!/bin/sh
2
#
3
# gvSIG. Desktop Geographic Information System.
4
#
5
# Copyright (C) 2007-2013 gvSIG Association.
6
#
7
# This program is free software; you can redistribute it and/or
8
# modify it under the terms of the GNU General Public License
9
# as published by the Free Software Foundation; either version 3
10
# of the License, or (at your option) any later version.
11
#
12
# This program is distributed in the hope that it will be useful,
13
# but WITHOUT ANY WARRANTY; without even the implied warranty of
14
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15
# GNU General Public License for more details.
16
#
17
# You should have received a copy of the GNU General Public License
18
# along with this program; if not, write to the Free Software
19
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
20
# MA  02110-1301, USA.
21
#
22
# For any additional information, do not hesitate to contact us
23
# at info AT gvsig.com, or visit our website www.gvsig.com.
24
#
25

    
26
# gvSIG.sh
27

    
28
set -e
29
#set -x
30

    
31
####################
32
# Identify OS and Architecture  #
33
####################
34

    
35
UNAME=$(uname -a)
36
if echo "$UNAME" | grep -i "win" >/dev/null; then
37
	OS="win"
38
	ARG_D32=""
39
        CPSEP=";"
40
else 
41
	if echo "$UNAME" | grep -i "lin" >/dev/null ; then
42
		OS="lin"
43
		# Only linux support -d32 arg
44
		ARG_D32="-d32"
45
                CPSEP=":"
46
	else
47
		OS="unknown"
48
		ARG_D32=""
49
                CPSEP=":"
50
	fi
51
fi
52
if echo "$UNAME" | egrep -i "(x86_64)|(amd64)" >/dev/null ; then
53
	ARCH="x86_64"
54
else
55
	ARCH="x86"
56
fi
57

    
58
########################
59

    
60
getJavaArchitecture() {
61
	if [ "$ARCH" = "x86" ] ; then
62
                # Si la arquitectura del SO es x86 decimos 
63
                # que la de java es x86
64
		echo "x86"
65
	else
66
                # si la arquitectura es x86_64, comprobamos
67
                # la arquitectura de la java que nos pasan
68
		if "$1" -version 2>&1 | egrep -i "64-Bit" >/dev/null ; then
69
			echo "x86_64"
70
		else
71
			echo "x86"
72
		fi
73
	fi 
74
}
75

    
76
#################################
77
# Set install and home folders  #
78
#################################
79

    
80
# Go into the gvSIG installation folder, just in case
81
cd "$(dirname $0)"
82

    
83
if [ "$GVSIG_APPLICATION_NAME" = "" ] ; then
84
  GVSIG_APPLICATION_NAME=gvSIG
85
fi
86
export GVSIG_APPLICATION_NAME
87

    
88
# gvSIG installation folder
89
export GVSIG_INSTALL_FOLDER="$PWD"
90

    
91
# gvSIG home folder
92
export GVSIG_HOME_FOLDER="$HOME/$GVSIG_APPLICATION_NAME"
93

    
94
#################
95
# Logger config #
96
#################
97

    
98
LOGGER_FILE="$GVSIG_HOME_FOLDER/${GVSIG_APPLICATION_NAME}-launcher.log"
99

    
100
logger () {
101
  # level (INFO/WARNIG) message
102
  local LOGGER_LEVEL="$1"
103
  shift
104
  echo "$LOGGER_LEVEL launch $@"
105
  if [ ! -f "$LOGGER_FILE" ] ; then
106
    mkdir -p "$(dirname $LOGGER_FILE)"
107
  fi
108
  echo "$LOGGER_LEVEL launch $@" >> "$LOGGER_FILE"
109
}
110

    
111
logger_info () {
112
  logger "INFO" "$@"
113
}
114

    
115
logger_warn () {
116
  logger "WARNING" "$@"
117
}
118

    
119
#########################
120
# Locate whitch command #
121
#########################
122

    
123
if type which >/dev/null; then
124
        WHICH=which
125
else
126
        WHICH=type
127
fi
128

    
129
logger_info "gvSIG Installation folder: $GVSIG_INSTALL_FOLDER"
130
logger_info "gvSIG home folder: $GVSIG_HOME_FOLDER"
131

    
132
##########################################################
133
# Search in gvSIG/extensiones the architecture of plugins 
134
# installeds and set as PREFERED_ARCHITECTURE
135
##########################################################
136

    
137
x=$(find $GVSIG_INSTALL_FOLDER/gvSIG/extensiones -name package.info -exec grep "architecture=[^a]" {} ';' | sort|head -n 1)
138
if [ "X${x}X" != "XX" ] ; then
139
	eval $x
140
	PREFERED_ARCHITECTURE="$architecture"
141
else
142
	PREFERED_ARCHITECTURE="$ARCH"
143
fi
144

    
145
##########################################################
146

    
147
FORCE_JAVA_32BITS=""
148
JAVA_HOME_OTHER_ARCHITECTURE=""
149

    
150
# PRIVATE JAVA HOMEs
151
PJH1=$(ls -dt "$GVSIG_HOME_FOLDER/jre/"*1.6* 2>/dev/null | head -1)
152
PJH2=$(ls -dt "$GVSIG_HOME_FOLDER/jre/"*1.5* 2>/dev/null | head -1)
153
PJH3=
154
PJH4=
155
PJH5=
156
PJH6=
157
if [ -d "$GVSIG_INSTALL_FOLDER/gvSIG/extensiones/jre_6_windows_i586/jre" ] ; then
158
    PJH5="$GVSIG_INSTALL_FOLDER/gvSIG/extensiones/jre_6_windows_i586/jre"
159
fi
160
if [ -d /usr/lib/jvm ] ; then
161
    PJH6=$(find /usr/lib/jvm -maxdepth 1 ! -name "jvm" -name "[a-zA-Z]*" ! -type l -print)
162
fi
163

    
164
#
165
# in next line, JAVA_HOME is set during instalation process
166
DEFAULT_JAVA_HOME="${JAVA_HOME}"
167
#
168
#
169
# Try to use java from:
170
# 1. Java specified in JAVA_HOME variable
171
# 2. Java specified in the instalation process
172
# 3. Java in the HOME/gvsig/jre folder (optionally created during installation process)
173
# 4. Java in the system path.
174
#
175
export JAVA_HOME
176
export JAVA
177
export FORCE_JAVA_32BITS
178

    
179

    
180
for JAVA_HOME_TO_USE in "$JAVA_HOME" "$DEFAULT_JAVA_HOME" "$PJH1" "$PJH2" "$PJH3" "$PJH4" "$PJH5" $PJH6 ""
181
do
182
        if [ "$JAVA_HOME_TO_USE" = "" ] ; then
183
                continue
184
        fi
185
	logger_info "Checking JAVA_HOME ${JAVA_HOME_TO_USE}..."
186
        if [ ! -d "$JAVA_HOME_TO_USE" ] ; then
187
                logger_warn "Folder not found ($JAVA_HOME_TO_USE), skip"
188
                continue
189
        fi
190
        if [ ! -x "$JAVA_HOME_TO_USE/bin/java" ] ; then
191
                logger_warn "Not a valid JAVA_HOME ($JAVA_HOME_TO_USE), bin/java not found, skip"
192
                continue
193
        fi
194
	JAVA_ARCH="$(getJavaArchitecture $JAVA_HOME_TO_USE/bin/java)"
195
	if [ "$JAVA_ARCH" != "$PREFERED_ARCHITECTURE" ] ; then
196
                JAVA_HOME_OTHER_ARCHITECTURE="$JAVA_HOME_TO_USE"
197
                logger_warn "Prefered architecture is $PREFERED_ARCHITECTURE, java $JAVA_ARCH found in $JAVA_HOME_TO_USE, skip"
198
                continue
199
        fi
200
        break
201
done
202

    
203
if [ "$JAVA_HOME_TO_USE" = "" ] ; then
204
        # Try to use the java in the system path
205
        if ! type java >/dev/null ; then
206
                # java not found in the system path
207
                if [ "$JAVA_HOME_OTHER_ARCHITECTURE" != "" ] ; then
208
                        JAVA_HOME="$JAVA_HOME_OTHER_ARCHITECTURE"
209
                        JAVA="$JAVA_HOME/bin/java"
210
                        logger_warn "java $PREFERED_ARCHITECTURE not found in the system path, using $JAVA_HOME_OTHER_ARCHITECTURE"
211
                else
212
                        logger_warn "java not found in the system"
213
                        exit 1
214
                fi
215
        else
216
		if [ "$(getJavaArchitecture $($WHICH java))" != "$PREFERED_ARCHITECTURE" ] ; then
217
                      logger_warn "java $PREFERED_ARCHITECTURE not found, using $($WHICH java)"
218
                fi
219
                unset JAVA_HOME
220
                JAVA="java"
221
        fi
222
else
223
        JAVA_HOME="$JAVA_HOME_TO_USE"
224
        JAVA="$JAVA_HOME/bin/java"
225
fi
226

    
227
if [ "$PREFERED_ARCHITECTURE" = "x86" ] ; then
228
	FORCE_JAVA_32BITS="$ARG_D32"
229
else 
230
	FORCE_JAVA_32BITS=""
231

    
232
fi
233
logger_info "Using java " $($WHICH "$JAVA")
234

    
235
###################################################################
236
# Variables not depending (at least directly) on the installation #
237
###################################################################
238

    
239
# gvSIG native libraries location 
240
export GVSIG_NATIVE_LIBS=${GVSIG_INSTALL_FOLDER}/native:${HOME}/.depman/lib
241

    
242
# Native libraries path
243
export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$GVSIG_NATIVE_LIBS"
244

    
245
export LIBRARIES=""
246
# Load gvSIG Andami jars and dependencies for the classpath 
247
for i in ./lib/*.jar ; do
248
  if [ "$i" != "./lib/*.jar" -a "$i" != "" ]; then
249
	LIBRARIES="${LIBRARIES}${CPSEP}${i}"
250
  fi 
251
done
252
for i in ./lib/*.zip ; do
253
  if [ "$i" != "./lib/*.zip" -a "$i" != "" ]; then
254
	LIBRARIES="${LIBRARIES}${CPSEP}${i}"
255
  fi 
256
done
257

    
258
# echo Initial libraries found: ${LIBRARIES}
259

    
260
# gvSIG Andami launcher
261

    
262
if [ "$GVSIG_LAUNCHER" = "" ] ; then
263
  GVSIG_LAUNCHER=org.gvsig.andamiupdater.Updater
264
fi
265
if [ "$GVSIG_PARAMS" = "" ] ; then
266
  GVSIG_PARAMS="$GVSIG_APPLICATION_NAME gvSIG/extensiones $@"
267
fi
268

    
269
export GVSIG_LAUNCHER
270
export GVSIG_PARAMS
271

    
272
# gvSIG initial classpath
273
export GVSIG_CLASSPATH="$LIBRARIES:$GVSIG_CLASSPATH"
274

    
275
########################
276
# Memory configuration #
277
########################
278

    
279
# Initial gvSIG memory (M=Megabytes, G=Gigabytes)
280
export GVSIG_INITIAL_MEM=256M
281
# Maximum gvSIG memory (M=Megabytes, G=Gigabytes)
282
export GVSIG_MAX_MEM=1024M
283
# Maximum permanent memory size: needed to load classes and statics
284
export GVSIG_MAX_PERM_SIZE=96M
285

    
286

    
287
#############################
288
# Plugin specific variables #
289
#############################
290

    
291
### ecw provider
292
export NCS_USER_PREFS="$HOME/.erm/ncsuserprefs.xml"
293

    
294
### gdal provider
295
# GDAL data files
296
export GDAL_DATA="${GVSIG_INSTALL_FOLDER}/data/gdal"
297

    
298
#############################
299
# Execute plugin's autorun  #
300
#############################
301

    
302
for PLUGIN_FOLDER in "$GVSIG_INSTALL_FOLDER/gvSIG/extensiones/"* 
303
do
304
  if [ -f "$PLUGIN_FOLDER/autorun.sh" ] ; then
305
    logger_info "Running autorun from plugin $(basename $PLUGIN_FOLDER)"
306
    . "$PLUGIN_FOLDER/autorun.sh"
307
  fi
308
done
309

    
310
logger_info "LD_LIBRARY_PATH=$LD_LIBRARY_PATH"
311

    
312
#####################
313
# Java debug mode ? #
314
#####################
315

    
316
DEBUG_ARGS="X${@}X"
317
if expr match "$DEBUG_ARGS" "X.*--pause.*X" >/dev/null; then           
318
    DEBUG_PAUSE="y"
319
else
320
    DEBUG_PAUSE="n"
321
fi
322

    
323
if expr match "$DEBUG_ARGS" "X.*--debug.*X" >/dev/null; then           
324
  DEBUG_OPTIONS="-agentlib:jdwp=transport=dt_socket,address=8000,server=y,suspend=$DEBUG_PAUSE"
325
else
326
  DEBUG_OPTIONS=""
327
fi
328

    
329
################
330
# Launch gvSIG #
331
################
332

    
333
# For Java parameters documentation and more parameters look at:
334
# http://download.oracle.com/javase/6/docs/technotes/tools/windows/java.html
335
# http://www.oracle.com/technetwork/java/javase/tech/vmoptions-jsp-140102.html
336

    
337
logger_info Launching gvSIG: ${JAVA} \
338
	$FORCE_JAVA_32BITS \
339
	-Xms${GVSIG_INITIAL_MEM} \
340
	-Xmx${GVSIG_MAX_MEM} \
341
	-XX:MaxPermSize=${GVSIG_MAX_PERM_SIZE} \
342
        $DEBUG_OPTIONS \
343
	-Djava.library.path="${GVSIG_NATIVE_LIBS}":/usr/lib \
344
	-cp $GVSIG_CLASSPATH \
345
	$GVSIG_LAUNCHER $GVSIG_PARAMS
346

    
347
${JAVA} \
348
	$FORCE_JAVA_32BITS \
349
	-Xms${GVSIG_INITIAL_MEM} \
350
	-Xmx${GVSIG_MAX_MEM} \
351
	-XX:MaxPermSize=${GVSIG_MAX_PERM_SIZE} \
352
        $DEBUG_OPTIONS \
353
	-Djava.library.path="${GVSIG_NATIVE_LIBS}":/usr/lib \
354
	-cp $GVSIG_CLASSPATH \
355
	$GVSIG_LAUNCHER $GVSIG_PARAMS