Opened 15 years ago
Closed 15 years ago
#928 closed defect (fixed)
6.4: wx module GUIs never return
Reported by: | hamish | Owned by: | |
---|---|---|---|
Priority: | critical | Milestone: | 6.4.0 |
Component: | Default | Version: | svn-releasebranch64 |
Keywords: | addons | Cc: | kimbesson, martinl |
CPU: | x86-64 | Platform: | Linux |
Description
6.4 only: (latest svn)
running scripts held in $GRASS_ADDON_PATH from the terminal prompt, with GRASS_GUI=wxpython never returns.
see this mailing list thread for more from Kim:
http://thread.gmane.org/gmane.comp.gis.grass.devel/37887/focus=38143
worse, with GRASS_GUI=tcltk *all* script modules fail with "sh: $GRASS_WISH: command not found
", both official and addon.
When running the addon module from the real terminal prompt with GRASS_GUI=wxpython you get the following error once for every time you press the [Stop] button.
G64:addons > which r.out.gmt /usr/local/src/grass/addons/r.out.gmt Traceback (most recent call last): File "/usr/local/src/grass/svn/releasebranch_6_4/dist.x86_64-unknown-linux-gnu/etc/wxpython/gui_modules/goutput.py", line 486, in OnCmdAbort self.cmdThread.abort() File "/usr/local/src/grass/svn/releasebranch_6_4/dist.x86_64-unknown-linux-gnu/etc/wxpython/gui_modules/goutput.py", line 108, in abort self.requestCmd.abort() AttributeError: 'CmdThread' object has no attribute 'requestCmd'
If run from the wxGUI Cmd> prompt with "r.out.gmt --ui", when you click the window dressing "X" to close the window you get it again in the main Layer Manager output tab, except this time with an additional popup error message:
__Error in command execution r.out.[snip]__ Execution failed: 'r.out.gmt' Details: Error:
If I restart GRASS in tcltk mode and try "r.out.gmt" from the real terminal prompt something even weirder happens:
G64:~ > r.out.gmt sh: $GRASS_WISH: command not found G64:~ > r.out.gmt --ui sh: $GRASS_WISH: command not found G64:~ > $GRASS_WISH [wish window opens, then I manually "X" it closed] % G64:~ >
so $GRASS_WISH is being quoted there once too many times...
I get the same thing if I run "r.out.gmt --ui" from the lower frame in the Output window.
(can we label that tcl command prompt frame somehow? it is impossible to guess that typing something there does anything. perhaps sacrifice one of the 3 input lines for a "Command:" label?)
in 6.5 it all works fine AFAICT.
Hamish
Change History (22)
follow-up: 2 comment:1 by , 15 years ago
follow-up: 3 comment:2 by , 15 years ago
Replying to hamish:
I guess it has to do with this, but unless popen() has different quoting needs I don't see the difference:
r40849 (relbr64)
Replace G_popen() with popen() (backport from devbr6, r40834)
does this need to be backported to 6.x?:
r40904 (trunk)
G_spawn_ex() expects descriptors as "int"s, not "char*".
It can't be; the code which it fixes doesn't exist in 6.4 (and isn't actually used in 6.5, and probably shouldn't have been back-ported).
But that's not the problem here. The problem is r40716, which back-ports r40713. This was fixed in 6.5 with r40724, which also needs to be back-ported.
The various "popen"-related issues which appear to be getting conflated are:
- The [G_]popen() of $GRASS_WISH for the parameter dialogs. Originally, $GRASS_WISH wasn't quoted, which may create problems on Windows if it's somewhere within
$ProgramFiles
. So r40713 quotes it, but I screwed up (the Unix version used single quotes instead of double quotes, and wasn't tested). This was fixed in r40724. It isn't applicable to 7.0, as GRASS_GUI=tcltk isn't supported there.
- Eliminating (the old) G_popen() in favour of popen(). G_popen() just mimics popen() on Unix and doesn't work on Windows (which actually provides a Unix-style popen()).
- In 7.0, G_popen() is implemented on top of G_spawn_ex() and has a completely different interface: it accepts an argument list (char) rather than a string to be interpreted by the shell. Currently, it's only used by G_pager() (interface to $GRASS_PAGER) and the code which emails error messages to the user. In 6.x, it isn't used at all; with popen() being eliminated, lib/gis/popen.c can (and should) be removed.
follow-up: 4 comment:3 by , 15 years ago
Priority: | blocker → critical |
---|---|
Summary: | 6.4: all shell scripts broken from command line + tcl; wx addon scripts broken → 6.4: wx addon scripts never return |
Replying to glynn:
But that's not the problem here. The problem is r40716, which back-ports r40713. This was fixed in 6.5 with r40724, which also needs to be back-ported.
ok, done. "sh: $GRASS_WISH: command not found
" is fixed.
In 6.x, it isn't used at all; with popen() being eliminated,
(I guess you mean G_popen() there)
lib/gis/popen.c can (and should) be removed.
I am not very happy about non-necessary API changes / dropping of long standing functions in the stable branch as we don't know what 3rd party modules are relying on. Adding G_warning("oi! stop using this function! use bar() instead!")
is more productive IMO.
In trunk anything goes, but..
Still broken:
- add-on scripts run through the wx module GUI in 6.4 finish but never return. when you hit the [Stop] button you get this error in the term:
AttributeError: 'CmdThread' object has no attribute 'requestCmd'
Outstanding wish:
- Tcl/Tk gis.m output window: can we label that command prompt frame somehow? it is impossible to guess that typing something there does anything. perhaps sacrifice one of the 3 input lines for a "Command:" label?
thanks, Hamish
comment:4 by , 15 years ago
Replying to hamish:
In 6.x, it isn't used at all; with popen() being eliminated,
(I guess you mean G_popen() there)
Yes.
lib/gis/popen.c can (and should) be removed.
I am not very happy about non-necessary API changes / dropping of long standing functions in the stable branch as we don't know what 3rd party modules are relying on. Adding
G_warning("oi! stop using this function! use bar() instead!")
is more productive IMO.
Anything using G_popen() was broken, as it didn't work on Windows (and offered no advantage to using popen()).
comment:5 by , 15 years ago
Cc: | added |
---|
follow-up: 7 comment:6 by , 15 years ago
would backporting 'g.parser -s' from 6.5 help?
(please document -s in both the help page and add to the --help usage text)
Hamish
follow-up: 8 comment:7 by , 15 years ago
comment:8 by , 15 years ago
comment:10 by , 15 years ago
Markus:
Should the g.parser version from 6.5 be backported to 6.4?
(now done by MarkusN, r41386)
running r.out.gmt shell script addon from wx module GUI tested with g.gisenv set="GRASS_GUI=wxpython"
; it still never returns after module completion with 'requestCmd' Traceback error in the terminal.
Hamish
follow-ups: 12 13 22 comment:11 by , 15 years ago
Summary: | 6.4: wx addon scripts never return → 6.4: wx module GUIs never return |
---|
see also #1010; it also some built in C modules from the command line.
tested
- d.rast - never returned.
- r.info - returned.
- r.cats - returned.
d.erase --ui
- never returned.v.out.ascii
+ roads (no output) - returns.v.report opt=print
- returns.
???
Hamish
ps - v.out.ascii input=roads --ui
fails to pre-seed the GUI as it does with tcktk.
follow-up: 14 comment:12 by , 15 years ago
Cc: | added |
---|---|
Owner: | changed from | to
Status: | new → assigned |
follow-up: 15 comment:13 by , 15 years ago
comment:14 by , 15 years ago
comment:15 by , 15 years ago
Replying to martinl:
Replying to hamish:
ps -
v.out.ascii input=roads --ui
fails to pre-seed the GUI as it does with tcktk.
thanks, works for me with a couple of minor points:
- d.erase only works if color != white. (then answer disappears from command at bottom of window & I guess the command becomes recursive..?)
- "
v.out.ascii roads fs=, --ui
": fs=, gets skipped but other values work. (I guess a syntax thing)
I would suggest to backport this change to relbr64 after 6.4.0. It needs some testing and can affect wxGUI quite significantly.
fine with me. the main point in supporting this is to give better control to the menus. (pre-tick non-interactive mode, etc)
TODO: verify 6.4 wingrass with python addon script and the newly backported g.parser -s.
Hamish
follow-up: 17 comment:16 by , 15 years ago
g.gui in WinGRASS-6.4.SVN-r41749-1 is also a blocker. Running g.gui gui=wxpython locks CMD till exit from GUI. Same with gui=tcltk. Still it's possible to launch old tcltk GUI with gis.m without blocking CMD. 1:0 in favor of gis.m.
Also g.gui -u wxpython has no effect on modules launched from CMD - I still get tcltk GUI afterwards. g.gisenv displays "GRASS_GUI=wxpython"
follow-up: 18 comment:17 by , 15 years ago
Replying to marisn:
Also g.gui -u wxpython has no effect on modules launched from CMD - I still get tcltk GUI afterwards. g.gisenv displays "GRASS_GUI=wxpython"
that is due to the way that the icons/menu items are set up on WinGrass. If you look at the Properties they actually call "grass64 -tcltk
" and "grass64 -wxpython
". Which has the effect of making the selection permanent. Solution: if you want the tcltk gui click on the tcltk menu item, if you want the wx gui click on the wx gui menu item. copy either one to your desktop as desired.
Hamish
comment:18 by , 15 years ago
Replying to hamish:
that is due to the way that the icons/menu items are set up on WinGrass. If you look at the Properties they actually call "
grass64 -tcltk
" and "grass64 -wxpython
". Which has the effect of making the selection permanent. Solution: if you want the tcltk gui click on the tcltk menu item, if you want the wx gui click on the wx gui menu item. copy either one to your desktop as desired.Hamish
Ah. That explains a bit, still I was using grass64 -text
, as it gives me CMD. Lack of normal terminal is PITA. Also then probably g.gui should print a warning when launched with -u on windows, as I expect my later actions to take precedence over startup type.
follow-up: 21 comment:20 by , 15 years ago
Cc: | added; removed |
---|---|
Owner: | changed from | to
Status: | assigned → new |
Replying to hamish:
what's the status of this one?
It seems to be that the ticket could be closed(?)
comment:21 by , 15 years ago
comment:22 by , 15 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
Replying to hamish:
tested
- d.rast - never returned. ...
d.erase --ui
- never returned.v.out.ascii
+ roads (no output) - returns.v.report opt=print
- returns.... ps -
v.out.ascii input=roads --ui
fails to pre-seed the GUI as it does with tcktk.
I have tested these in 6.4 (as far as I understand what to test) and all looks good. Closing.
Replying to hamish:
...
(but from gis.m they run ok)
I guess it has to do with this, but unless popen() has different quoting needs I don't see the difference:
r40849 (relbr64)
Replace G_popen() with popen() (backport from devbr6, r40834)
does this need to be backported to 6.x?:
r40904 (trunk)
G_spawn_ex() expects descriptors as "int"s, not "char*".
Hamish