2 #------------------------------------------------------------------------------
4 # This shell script attempts to intelligently manage the process
5 # of launching a program with Wine. It adds some level of
6 # visual feedback to an end user.
9 # winelauncher [options] "<windows program> [program arguments]"
11 # This script is meant to be installed to /usr/bin/wine, and
12 # to be used to invoke a Windows executable.
13 # The options are passed through directly to Wine, and are
14 # documented in the Wine man page.
16 # Copyright (c) 2000 by Jeremy White for CodeWeavers
18 # This library is free software; you can redistribute it and/or
19 # modify it under the terms of the GNU Lesser General Public
20 # License as published by the Free Software Foundation; either
21 # version 2.1 of the License, or (at your option) any later version.
23 # This library is distributed in the hope that it will be useful,
24 # but WITHOUT ANY WARRANTY; without even the implied warranty of
25 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
26 # Lesser General Public License for more details.
28 # You should have received a copy of the GNU Lesser General Public
29 # License along with this library; if not, write to the Free Software
30 # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
31 #------------------------------------------------------------------------------
33 #------------------------------------------------------------------------------
34 # Primary configuration area - change this if you installed Wine to
35 # a different location
36 #------------------------------------------------------------------------------
42 #------------------------------------------------------------------------------
43 # Establish Color Scheme
44 #------------------------------------------------------------------------------
45 COLOR
=' -xrm *.Command.background:darkgrey
46 -xrm *.Command.foreground:black
47 -xrm *.Text.background:black
48 -xrm *.Text.foreground:green
49 -xrm *.Form.background:grey
50 -xrm *.Form.foreground:green
51 -xrm *.foreground:green
52 -xrm *.background:black'
55 #------------------------------------------------------------------------------
56 # Locate either xmessage or gmessage, if we can.
57 #------------------------------------------------------------------------------
58 type xmessage
>/dev
/null
2>/dev
/null
59 if [ $?
-ne 0 ] ; then
60 # xmessage not found; make sure the user notices this error
61 # (GUI users wouldn't even notice if we printed the text on console !)
62 MSGFILE
=`mktemp "/tmp/wine.xmessage.XXXXXX"`
65 The Wine launcher is unable to find the xmessage program,
66 which it needs to properly notify you of Wine execution status
69 This launcher script relies heavily on finding this tool,
70 and without it, it will behave very poorly.
72 We strongly recommend that you use your distribution's
73 software methods to locate xmessage, or alternatively
74 use your favourite internet search engine to find out
75 how you are supposed to install xmessage on your system.
78 # try to display message file with tons of different X11 editors
79 # until we find one that's installed and working
80 for EDITPRG
in nedit gedit kedit gvim xemacs
; do
81 type $EDITPRG >/dev
/null
2>/dev
/null
82 if [ $?
-eq 0 ] ; then
83 # execute editor and exit if successful
84 $EDITPRG $MSGFILE && exit
88 # ok, we really give up now, this system is hosed ;-)
92 XMESSAGE
="xmessage $COLOR"
98 if [ $?
-eq 0 ] ; then
101 if [ -x /opt
/wine
/bin
/winesetup
] ; then
102 /opt
/wine
/bin
/winesetup
104 $XMESSAGE -title "Error" \
105 "Error: Unable to find winesetup in your PATH or in /opt/wine/bin:
106 I am not able to configure Wine.
108 If winesetup is being distributed in a separate package
109 that is not installed yet on your system, then please install this
111 winesetup can also be downloaded from www.codeweavers.com.
113 If you choose to not use winesetup for configuration, then
114 you can find information on how to prepare a Wine config file manually
115 in the Wine README / README.gz file or in the Wine User Guide."
120 #------------------------------------------------------------------------------
121 # We're going to do a lot of fancy footwork below.
122 # Before we get started, it would be nice to know the argv0
123 # of the actual script we're running (and lets remove at least
124 # one level of symlinking).
125 #------------------------------------------------------------------------------
126 argv0_path
=`which $0`
127 if [ -z $argv0_path ] ; then
131 real_name
=`find $argv0_path -type l -printf "%l\n"`
132 if [ ! $real_name ]; then
133 real_name
=$argv0_path
134 elif [ ! -x $real_name ]; then
135 real_name
=`find $argv0_path -printf "%h\n"`/$real_name
138 argv0_dir
=`find $real_name -printf "%h\n"`
140 if [ -z $argv0_dir ] ; then
144 #------------------------------------------------------------------------------
145 # Okay, now all that junk above was established at configure time.
146 # However, if this is an RPM install, they may have chosen
147 # to relocate this installation. If so, that stuff above
148 # is all broken and we should rejigger it.
149 #------------------------------------------------------------------------------
150 WINE_BIN_NAME
=wine.bin
151 if [ ! -x $WINEBIN/$WINE_BIN_NAME ] ; then
152 WINEBIN
=`find $argv0_dir -maxdepth 1 -perm +0111 -type f -name "$WINE_BIN_NAME" -printf "%h\n" | head -n 1`
155 if [ ! -x $WINEBIN/$WINE_BIN_NAME ] ; then
156 WINEBIN
=`find $argv0_dir/../ -maxdepth 1 -perm +0111 -type f -name "$WINE_BIN_NAME" -printf "%h\n" | head -n 1`
159 if [ ! -x $WINEBIN/$WINE_BIN_NAME ] ; then
161 if [ ! -x $WINEBIN/$WINE_BIN_NAME ] ; then
162 WINEBIN
=`find $argv0_dir -maxdepth 1 -perm +0111 -type f -name "$WINE_BIN_NAME" -printf "%h\n" | head -n 1`
165 if [ ! -x $WINEBIN/$WINE_BIN_NAME ] ; then
166 WINEBIN
=`find $argv0_dir/../ -maxdepth 1 -perm +0111 -type f -name "$WINE_BIN_NAME" -printf "%h\n" | head -n 1`
170 if [ ! -r $WINELIB/libwine.so
] ; then
171 WINELIB
=`find $argv0_dir -maxdepth 2 -name 'libwine.so' -printf "%h\n" | head -n 1`
174 if [ ! -r $WINELIB/libwine.so
] ; then
175 WINELIB
=`find $argv0_dir/../ -maxdepth 2 -name 'libwine.so' -printf "%h\n" | head -n 1`
178 if [ -x $WINEBIN/wineserver
] ; then
179 WINESERVER
=$WINEBIN/wineserver
182 #------------------------------------------------------------------------------
183 # Hey, if we built Wine from source, let's add a little extra fun to
185 #------------------------------------------------------------------------------
186 if [ -x $WINEBIN/server
/wineserver
] ; then
187 WINESERVER
=$WINEBIN/server
/wineserver
190 if [ -r $WINELIB/dlls
/ntdll.dll.so
] ; then
191 WINEDLLPATH
=$WINELIB/dlls
195 #------------------------------------------------------------------------------
196 # Okay, set the paths and move on.
197 #------------------------------------------------------------------------------
198 export LD_LIBRARY_PATH
=$WINELIB:$LD_LIBRARY_PATH
199 export PATH
=$WINEBIN:$PATH
200 export WINELOADER
=$WINEBIN/$WINE_BIN_NAME
204 info_flag
=~
/.wine
/.no_prelaunch_window_flag
205 debug_flag
=~
/.wine
/.no_debug_window_flag
206 debug_options
="warn+all"
208 if [ -f $info_flag ] ; then
214 if [ -f $debug_flag ] ; then
221 #------------------------------------------------------------------------------
222 # Handle winelib apps going through here
223 #------------------------------------------------------------------------------
225 if [ -f $argv0_path.so
] ; then
227 export WINEPRELOAD
=$argv0_path.so
231 #------------------------------------------------------------------------------
232 # No arguments? Help 'em out
233 #------------------------------------------------------------------------------
236 if [ $# -eq 0 ] ; then
240 if [ $# -eq 1 -a "$1" = "" ] ; then
244 if [ $winelib -eq 1 ] ; then
248 if [ $no_args -eq 1 ] ; then
249 echo "Wine called with no arguments."
250 echo "Invoking $WINEBIN/$WINE_BIN_NAME $@ ..."
251 $XMESSAGE -buttons " Okay ":0," See the Wine Usage Statement ":1," Configure Wine ":2 \
252 -title "Welcome to Wine" \
255 You have started Wine without specifying any arguments.
257 Wine requires at least one argument - the name of the Windows
258 application you would like to run.
260 If you have launched this through the KDE menu system
261 and your KDE installation is specially configured for Wine,
262 then you can use the KDE file browser to select a Windows
263 executable and then click on it to launch Wine with
266 You can similarly use the GNOME file manager to
267 select a Windows executable and double click on it.
269 If you would like to see the command line arguments
270 for Wine, select the second option, below.
274 if [ $welcome_rc -eq 0 ] ; then
278 if [ $welcome_rc -eq 2 ] ; then
287 #------------------------------------------------------------------------------
288 # No config file? Offer to help 'em out...
289 #------------------------------------------------------------------------------
292 while [ $conf -eq 0 ] ; do
294 if [ -f ~
/.winerc
] ; then
297 if [ -f ~
/.wine
/config
] ; then
300 if [ -f /etc
/wine.conf
] ; then
304 if [ $conf -ne 0 ] ; then
308 echo "No configuration file detected."
309 $XMESSAGE -buttons " Cancel ":0," Proceed ":1," Configure Wine ":2 \
310 -title "Welcome to Wine" \
313 You have started Wine, but we cannot find a Wine
316 This is normal if you have never run Wine before.
317 If this is the case, select the 'Configure Wine'
318 option, below, to create a configuration file.
322 if [ $init_rc -eq 0 ] ; then
326 if [ $init_rc -eq 1 ] ; then
330 if [ $init_rc -eq 2 ] ; then
334 # 127 == xmessage not available
335 if [ $init_rc -eq 127 ] ; then
341 #------------------------------------------------------------------------------
342 # Optionally Warn the user we're going to be launching Wine...
343 #------------------------------------------------------------------------------
344 if [ $use_info_message -ne 0 ] ; then
345 echo "Invoking $WINEBIN/$WINE_BIN_NAME $@ ..."
346 $XMESSAGE -timeout 30 -buttons " Dismiss ":0," Never display this message again ":3 \
347 -title "Wine Launch Window" \
348 "Invoking $WINEBIN/$WINE_BIN_NAME $@ ...
350 This dialog box is a temporary status dialog to let you know
351 that Wine is attempting to launch your application.
353 Since Wine is still very much in a development stage,
354 many applications will fail silently.
355 This dialog box is your indication
356 that we're *trying* to run your application.
358 This dialog box will automatically disappear after 30 seconds,
359 or after your application finishes.
361 You can permanently disable this dialog by selecting
367 #------------------------------------------------------------------------------
368 # Here's a little function to clean up after that dialog...
369 #------------------------------------------------------------------------------
370 clean_up_info_message
()
372 if [ $use_info_message -ne 0 ] ; then
374 #------------------------------------------------------------------------------
375 # Okay, make sure that the notice window is dead (and kill it if it ain't)
376 #------------------------------------------------------------------------------
377 ps
$info_message_pid >/dev
/null
2>&1
378 if [ $?
-ne 0 ] ; then
379 wait $info_message_pid
383 kill $info_message_pid
386 #------------------------------------------------------------------------------
387 # If they didn't like the warning window, turn it off
388 #------------------------------------------------------------------------------
389 if [ $info_return -eq 3 ] ; then
390 $XMESSAGE -title "Wine Prelaunch Control" \
391 "Wine will now disable the prelaunch window you just saw.
392 You will no longer be notified when Wine is attempting
393 to start a Windows application.
395 Please take note that you can reenable this window
396 by removing the $info_flag file." -buttons " Okay ":0," Cancel ":1
397 if [ $?
-eq 0 ] ; then
405 #------------------------------------------------------------------------------
406 # Generate a temporary log file name
407 #------------------------------------------------------------------------------
408 if [ -n "$TMP" ] ; then
414 log_name
=`mktemp "$log_dir/wine.log.XXXXXX"`
415 if [ $?
-eq 0 ] ; then
419 status_name
=`mktemp "$log_dir/wine.status.XXXXXX"`
420 if [ $?
-eq 0 ] ; then
424 #------------------------------------------------------------------------------
425 # Okay, really launch Wine...
426 #------------------------------------------------------------------------------
427 if [ $use_log_name -ne 0 -a $use_status_name -ne 0 ] ; then
428 ( $WINEBIN/$WINE_BIN_NAME "$@"; echo $?
>$status_name ) 2>&1 |
tee "$log_name"
429 wine_return
=`cat $status_name`
431 $WINEBIN/$WINE_BIN_NAME "$@"
434 if [ $use_status_name -ne 0 ] ; then
438 #------------------------------------------------------------------------------
439 # Test the return code, and see if it fails
440 #------------------------------------------------------------------------------
441 if [ $always_see_output -eq 0 -a $wine_return -eq 0 ] ; then
442 echo "Wine exited with a successful status"
443 if [ $use_log_name -ne 0 ] ; then
447 if [ $always_see_output -eq 0 ] ; then
448 echo "Wine failed with return code $wine_return"
451 #------------------------------------------------------------------------------
452 # Gracefully display a debug message if they like...
453 #------------------------------------------------------------------------------
454 while [ $use_debug_message -gt 0 ] ; do
456 #------------------------------------------------------------------------------
457 # Build up the menu of choices they can make...
458 #------------------------------------------------------------------------------
460 if [ $use_log_name -ne 0 ] ; then
461 BUTTONS
="$BUTTONS"', View Log :1'
464 BUTTONS
="$BUTTONS"', Debug :2'
465 BUTTONS
="$BUTTONS"', Configure :4'
466 BUTTONS
="$BUTTONS"', Disable :3'
468 #------------------------------------------------------------------------------
469 # Build an error message
470 #------------------------------------------------------------------------------
472 Wine has exited with a failure status of $wine_return.
474 Wine is still development software, so there can be many
475 explanations for this problem.
477 You can choose to run Wine again with a higher level
478 of debug messages (the debug option, below).
480 You can attempt to reconfigure Wine to make it work better.
481 Note that one change you can make that will dramatically
482 effect Wine's behaviour is to change whether or not
483 Wine uses a true Windows partition, mounted under Linux,
484 or whether it uses an empty Windows directory.
485 The Wine Configuration program can assist you in making
486 those changes (select Configure, below, for more).
488 You can disable this message entirely by selecting the
489 Disable option below."
491 if [ $always_see_output -ne 0 -a $wine_return -eq 0 ] ; then
493 Wine has exited with a failure status of $wine_return.
495 You can disable this message entirely by selecting the
496 Disable option below."
500 if [ $use_log_name -ne 0 ] ; then
503 Wine has captured a log of the Wine output in the file $log_name.
504 You may view this file by selecting View Log, below."
507 #------------------------------------------------------------------------------
508 # Display the message
509 #------------------------------------------------------------------------------
510 $XMESSAGE -title "Wine Finished With Error" -buttons "$BUTTONS" "$MESSAGE"
513 #------------------------------------------------------------------------------
514 # Dismiss the other window...
515 #------------------------------------------------------------------------------
516 clean_up_info_message
518 #------------------------------------------------------------------------------
519 # Process a configure instruction
520 #------------------------------------------------------------------------------
521 if [ $debug_return -eq 4 ] ; then
526 #------------------------------------------------------------------------------
527 # Process a view instruction
528 #------------------------------------------------------------------------------
529 if [ $debug_return -eq 1 ] ; then
530 $XMESSAGE -title "View Wine Log" -file "$log_name" -buttons " Okay ":0,"Delete $log_name":1
531 if [ $?
-eq 1 ] ; then
532 echo "Deleting $log_name"
540 #------------------------------------------------------------------------------
541 # If they didn't like the warning window, turn it off
542 #------------------------------------------------------------------------------
543 if [ $debug_return -eq 3 ] ; then
544 $XMESSAGE -title "Wine Debug Log Control" \
545 "Wine will now disable the Wine debug output control window you just saw.
546 You will no longer be notified when Wine fails to start a
549 Please take note that you can reenable this window
550 by removing the $debug_flag file." -buttons " Okay ":0," Cancel ":1
552 if [ $?
-eq 0 ] ; then
558 #------------------------------------------------------------------------------
559 # If they want to retry with debug, let 'em.
560 #------------------------------------------------------------------------------
561 if [ $debug_return -eq 2 ] ; then
562 echo "Rerunning WINEDEBUG=$debug_options $0 $@"
563 WINEDEBUG
=$debug_options exec $0 "$@"
569 clean_up_info_message
572 if [ $wine_return -ge 128 ]; then
573 # try to kill myself with the same signal
574 kill -$
[wine_return
- 128] $$
575 # if we get here the kill didn't work