svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.framework / org.gvsig.andami / src / main / resources-application / gvSIG.sh @ 42296
History | View | Annotate | Download (10.3 KB)
1 | 42045 | jjdelcerro | #!/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 | 42113 | fdiaz | else |
41 | 42045 | jjdelcerro | 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 | 42113 | fdiaz | # Si la arquitectura del SO es x86 decimos |
63 | 42045 | jjdelcerro | # 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 | 42113 | fdiaz | fi |
74 | 42045 | jjdelcerro | } |
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 | mkdir -p "$GVSIG_HOME_FOLDER" |
||
95 | |||
96 | #################### |
||
97 | # Load config file # |
||
98 | #################### |
||
99 | |||
100 | if [ -f "$GVSIG_INSTALL_FOLDER/gvSIG.config" ] ; then |
||
101 | . "$GVSIG_INSTALL_FOLDER/gvSIG.config" |
||
102 | fi |
||
103 | |||
104 | ################# |
||
105 | # Logger config # |
||
106 | ################# |
||
107 | |||
108 | LOGGER_FILE="$GVSIG_HOME_FOLDER/${GVSIG_APPLICATION_NAME}-launcher.log" |
||
109 | 42149 | jjdelcerro | echo > "$LOGGER_FILE" |
110 | 42045 | jjdelcerro | |
111 | 42149 | jjdelcerro | |
112 | 42045 | jjdelcerro | logger () { |
113 | # level (INFO/WARNIG) message |
||
114 | local LOGGER_LEVEL="$1" |
||
115 | shift |
||
116 | echo "$LOGGER_LEVEL launch $@" |
||
117 | echo "$LOGGER_LEVEL launch $@" >> "$LOGGER_FILE" |
||
118 | } |
||
119 | |||
120 | logger_info () { |
||
121 | logger "INFO" "$@" |
||
122 | } |
||
123 | |||
124 | logger_warn () { |
||
125 | logger "WARNING" "$@" |
||
126 | } |
||
127 | |||
128 | 42149 | jjdelcerro | logger_cmd() { |
129 | logger_info "$@" |
||
130 | eval $@ | tee -a "$LOGGER_FILE" |
||
131 | } |
||
132 | |||
133 | 42045 | jjdelcerro | ######################### |
134 | # Locate whitch command # |
||
135 | ######################### |
||
136 | |||
137 | if type which >/dev/null; then |
||
138 | WHICH=which |
||
139 | else |
||
140 | WHICH=type |
||
141 | fi |
||
142 | |||
143 | logger_info "gvSIG Installation folder: $GVSIG_INSTALL_FOLDER" |
||
144 | logger_info "gvSIG home folder: $GVSIG_HOME_FOLDER" |
||
145 | |||
146 | ########################################################## |
||
147 | 42113 | fdiaz | # Search in gvSIG/extensiones the architecture of plugins |
148 | 42045 | jjdelcerro | # installeds and set as PREFERED_ARCHITECTURE |
149 | ########################################################## |
||
150 | |||
151 | cd "$GVSIG_INSTALL_FOLDER" |
||
152 | x=$(find "./gvSIG/extensiones" -name package.info) |
||
153 | x=$(grep -h "architecture=[^a]" $x | sort|head -n 1) |
||
154 | if [ "X${x}X" != "XX" ] ; then |
||
155 | eval $x |
||
156 | PREFERED_ARCHITECTURE="$architecture" |
||
157 | else |
||
158 | PREFERED_ARCHITECTURE="$ARCH" |
||
159 | fi |
||
160 | cd - |
||
161 | |||
162 | ########################################################## |
||
163 | |||
164 | FORCE_JAVA_32BITS="" |
||
165 | JAVA_HOME_OTHER_ARCHITECTURE="" |
||
166 | |||
167 | # PRIVATE JAVA HOMEs |
||
168 | PJH1=$(ls -dt "$GVSIG_HOME_FOLDER/jre/"*1.6* 2>/dev/null | head -1) |
||
169 | PJH2=$(ls -dt "$GVSIG_HOME_FOLDER/jre/"*1.5* 2>/dev/null | head -1) |
||
170 | PJH3= |
||
171 | PJH4= |
||
172 | PJH5= |
||
173 | PJH6= |
||
174 | if [ -d "$GVSIG_INSTALL_FOLDER/gvSIG/extensiones/jre_7_windows_i586/jre" ] ; then |
||
175 | PJH5="$GVSIG_INSTALL_FOLDER/gvSIG/extensiones/jre_7_windows_i586/jre" |
||
176 | fi |
||
177 | if [ -d /usr/lib/jvm ] ; then |
||
178 | PJH6=$(find /usr/lib/jvm -maxdepth 1 ! -name "jvm" -name "[a-zA-Z]*" ! -type l -print) |
||
179 | fi |
||
180 | |||
181 | # |
||
182 | # in next line, JAVA_HOME is set during instalation process |
||
183 | DEFAULT_JAVA_HOME="${JAVA_HOME}" |
||
184 | # |
||
185 | # |
||
186 | # Try to use java from: |
||
187 | # 1. Java specified in JAVA_HOME variable |
||
188 | # 2. Java specified in the instalation process |
||
189 | # 3. Java in the HOME/gvsig/jre folder (optionally created during installation process) |
||
190 | # 4. Java in the system path. |
||
191 | # |
||
192 | export JAVA_HOME |
||
193 | export JAVA |
||
194 | export FORCE_JAVA_32BITS |
||
195 | |||
196 | |||
197 | for JAVA_HOME_TO_USE in "$JAVA_HOME" "$DEFAULT_JAVA_HOME" "$PJH1" "$PJH2" "$PJH3" "$PJH4" "$PJH5" $PJH6 "" |
||
198 | do |
||
199 | if [ "$JAVA_HOME_TO_USE" = "" ] ; then |
||
200 | continue |
||
201 | fi |
||
202 | logger_info "Checking JAVA_HOME ${JAVA_HOME_TO_USE}..." |
||
203 | if [ ! -d "$JAVA_HOME_TO_USE" ] ; then |
||
204 | logger_warn "Folder not found ($JAVA_HOME_TO_USE), skip" |
||
205 | continue |
||
206 | fi |
||
207 | if [ ! -x "$JAVA_HOME_TO_USE/bin/java" ] ; then |
||
208 | logger_warn "Not a valid JAVA_HOME ($JAVA_HOME_TO_USE), bin/java not found, skip" |
||
209 | continue |
||
210 | fi |
||
211 | JAVA_ARCH="$(getJavaArchitecture $JAVA_HOME_TO_USE/bin/java)" |
||
212 | if [ "$JAVA_ARCH" != "$PREFERED_ARCHITECTURE" ] ; then |
||
213 | JAVA_HOME_OTHER_ARCHITECTURE="$JAVA_HOME_TO_USE" |
||
214 | logger_warn "Prefered architecture is $PREFERED_ARCHITECTURE, java $JAVA_ARCH found in $JAVA_HOME_TO_USE, skip" |
||
215 | continue |
||
216 | fi |
||
217 | break |
||
218 | done |
||
219 | |||
220 | if [ "$JAVA_HOME_TO_USE" = "" ] ; then |
||
221 | # Try to use the java in the system path |
||
222 | if ! type java >/dev/null ; then |
||
223 | # java not found in the system path |
||
224 | if [ "$JAVA_HOME_OTHER_ARCHITECTURE" != "" ] ; then |
||
225 | JAVA_HOME="$JAVA_HOME_OTHER_ARCHITECTURE" |
||
226 | JAVA="$JAVA_HOME/bin/java" |
||
227 | logger_warn "java $PREFERED_ARCHITECTURE not found in the system path, using $JAVA_HOME_OTHER_ARCHITECTURE" |
||
228 | else |
||
229 | logger_warn "java not found in the system" |
||
230 | exit 1 |
||
231 | fi |
||
232 | else |
||
233 | if [ "$(getJavaArchitecture $($WHICH java))" != "$PREFERED_ARCHITECTURE" ] ; then |
||
234 | logger_warn "java $PREFERED_ARCHITECTURE not found, using $($WHICH java)" |
||
235 | fi |
||
236 | unset JAVA_HOME |
||
237 | JAVA="java" |
||
238 | fi |
||
239 | else |
||
240 | JAVA_HOME="$JAVA_HOME_TO_USE" |
||
241 | JAVA="$JAVA_HOME/bin/java" |
||
242 | fi |
||
243 | |||
244 | if [ "$PREFERED_ARCHITECTURE" = "x86" ] ; then |
||
245 | FORCE_JAVA_32BITS="$ARG_D32" |
||
246 | 42113 | fdiaz | else |
247 | 42045 | jjdelcerro | FORCE_JAVA_32BITS="" |
248 | |||
249 | fi |
||
250 | logger_info "Using java " $($WHICH "$JAVA") |
||
251 | |||
252 | ################################################################### |
||
253 | # gvSIG native libraries location |
||
254 | ################################################################### |
||
255 | |||
256 | export GVSIG_NATIVE_LIBS="" |
||
257 | 42113 | fdiaz | export LD_LIBRARY_PATH="" |
258 | 42045 | jjdelcerro | |
259 | add_library_path() { |
||
260 | LD_LIBRARY_PATH="$LD_LIBRARY_PATH${CPSEP}$1" |
||
261 | GVSIG_NATIVE_LIBS="$GVSIG_NATIVE_LIBS${CPSEP}$1" |
||
262 | } |
||
263 | |||
264 | 42149 | jjdelcerro | list_shared_library_dependencies() { |
265 | logger_info "Cheking shared library dependencies for $1" |
||
266 | set +e |
||
267 | if [ "$OS" = "win" ] ; then |
||
268 | logger_cmd cygcheck.exe "$1" |
||
269 | else |
||
270 | logger_cmd ldd "$1" |
||
271 | fi || logger_warn "Problens checking shared library $1" |
||
272 | set -e |
||
273 | } |
||
274 | 42045 | jjdelcerro | |
275 | ################################################################### |
||
276 | # gvSIG java libraries location |
||
277 | ################################################################### |
||
278 | |||
279 | export LIBRARIES="" |
||
280 | 42113 | fdiaz | # Load gvSIG Andami jars and dependencies for the classpath |
281 | 42045 | jjdelcerro | for i in "$GVSIG_INSTALL_FOLDER/lib/"*.jar ; do |
282 | if [ "$i" != "$GVSIG_INSTALL_FOLDER/lib/*.jar" -a "$i" != "" ]; then |
||
283 | LIBRARIES="${LIBRARIES}${CPSEP}${i}" |
||
284 | 42113 | fdiaz | fi |
285 | 42045 | jjdelcerro | done |
286 | for i in "$GVSIG_INSTALL_FOLDER/lib/"*.zip ; do |
||
287 | if [ "$i" != "$GVSIG_INSTALL_FOLDER/lib/*.zip" -a "$i" != "" ]; then |
||
288 | LIBRARIES="${LIBRARIES}${CPSEP}${i}" |
||
289 | 42113 | fdiaz | fi |
290 | 42045 | jjdelcerro | done |
291 | |||
292 | # echo Initial libraries found: ${LIBRARIES} |
||
293 | |||
294 | # gvSIG Andami launcher |
||
295 | |||
296 | if [ "$GVSIG_LAUNCHER" = "" ] ; then |
||
297 | GVSIG_LAUNCHER=org.gvsig.andamiupdater.Updater |
||
298 | fi |
||
299 | if [ "$GVSIG_PARAMS" = "" ] ; then |
||
300 | GVSIG_PARAMS="$GVSIG_APPLICATION_NAME gvSIG/extensiones $@" |
||
301 | fi |
||
302 | |||
303 | export GVSIG_LAUNCHER |
||
304 | export GVSIG_PARAMS |
||
305 | |||
306 | # gvSIG initial classpath |
||
307 | export GVSIG_CLASSPATH="$LIBRARIES:$GVSIG_CLASSPATH" |
||
308 | |||
309 | ######################## |
||
310 | # Memory configuration # |
||
311 | ######################## |
||
312 | |||
313 | # Initial gvSIG memory (M=Megabytes, G=Gigabytes) |
||
314 | export GVSIG_INITIAL_MEM=256M |
||
315 | # Maximum gvSIG memory (M=Megabytes, G=Gigabytes) |
||
316 | export GVSIG_MAX_MEM=1024M |
||
317 | # Maximum permanent memory size: needed to load classes and statics |
||
318 | export GVSIG_MAX_PERM_SIZE=96M |
||
319 | |||
320 | |||
321 | ############################# |
||
322 | # Execute plugin's autorun # |
||
323 | ############################# |
||
324 | |||
325 | 42113 | fdiaz | for PLUGIN_FOLDER in "$GVSIG_INSTALL_FOLDER/gvSIG/extensiones/"* |
326 | 42045 | jjdelcerro | do |
327 | if [ -f "$PLUGIN_FOLDER/autorun.sh" ] ; then |
||
328 | logger_info "Running autorun from plugin " $(basename "$PLUGIN_FOLDER") |
||
329 | . "$PLUGIN_FOLDER/autorun.sh" |
||
330 | cd "$GVSIG_INSTALL_FOLDER" |
||
331 | fi |
||
332 | done |
||
333 | |||
334 | 42149 | jjdelcerro | if [ "$OS" = "win" ] ; then |
335 | add_library_path "$GVSIG_INSTALL_FOLDER" |
||
336 | else |
||
337 | add_library_path "/usr/lib" |
||
338 | fi |
||
339 | |||
340 | 42045 | jjdelcerro | logger_info "LD_LIBRARY_PATH=$LD_LIBRARY_PATH" |
341 | |||
342 | ##################### |
||
343 | # Java debug mode ? # |
||
344 | ##################### |
||
345 | |||
346 | DEBUG_ARGS="X${@}X" |
||
347 | 42113 | fdiaz | if expr match "$DEBUG_ARGS" "X.*--pause.*X" >/dev/null; then |
348 | 42045 | jjdelcerro | DEBUG_PAUSE="y" |
349 | else |
||
350 | DEBUG_PAUSE="n" |
||
351 | fi |
||
352 | |||
353 | 42113 | fdiaz | if expr match "$DEBUG_ARGS" "X.*--debug.*X" >/dev/null; then |
354 | 42045 | jjdelcerro | DEBUG_OPTIONS="-agentlib:jdwp=transport=dt_socket,address=8765,server=y,suspend=$DEBUG_PAUSE" |
355 | else |
||
356 | DEBUG_OPTIONS="" |
||
357 | fi |
||
358 | |||
359 | ################ |
||
360 | # Launch gvSIG # |
||
361 | ################ |
||
362 | |||
363 | # For Java parameters documentation and more parameters look at: |
||
364 | # http://download.oracle.com/javase/6/docs/technotes/tools/windows/java.html |
||
365 | # http://www.oracle.com/technetwork/java/javase/tech/vmoptions-jsp-140102.html |
||
366 | |||
367 | logger_info Launching gvSIG: ${JAVA} \ |
||
368 | $FORCE_JAVA_32BITS \ |
||
369 | -Xms${GVSIG_INITIAL_MEM} \ |
||
370 | -Xmx${GVSIG_MAX_MEM} \ |
||
371 | -XX:MaxPermSize=${GVSIG_MAX_PERM_SIZE} \ |
||
372 | $DEBUG_OPTIONS \ |
||
373 | -Djava.library.path=\"${GVSIG_NATIVE_LIBS}\" \ |
||
374 | -cp $GVSIG_CLASSPATH \ |
||
375 | $GVSIG_JAVA_PARAMS \ |
||
376 | $GVSIG_LAUNCHER $GVSIG_PARAMS |
||
377 | |||
378 | "${JAVA}" \ |
||
379 | $FORCE_JAVA_32BITS \ |
||
380 | -Xms${GVSIG_INITIAL_MEM} \ |
||
381 | -Xmx${GVSIG_MAX_MEM} \ |
||
382 | -XX:MaxPermSize=${GVSIG_MAX_PERM_SIZE} \ |
||
383 | $DEBUG_OPTIONS \ |
||
384 | -Djava.library.path="${GVSIG_NATIVE_LIBS}" \ |
||
385 | -cp "$GVSIG_CLASSPATH" \ |
||
386 | $GVSIG_JAVA_PARAMS \ |
||
387 | $GVSIG_LAUNCHER $GVSIG_PARAMS |