#1184 closed defect (fixed)
"d.vect display=attr" imply grass open process but doesn't close them.
Reported by: | met | Owned by: | martinl |
---|---|---|---|
Priority: | critical | Milestone: | 6.4.2 |
Component: | wxGUI | Version: | 6.4.0 |
Keywords: | wingrass, d.vect | Cc: | grass-dev@… |
CPU: | Unspecified | Platform: | MSWindows XP |
Description (last modified by )
Using version 6.4.0 or 6.4.0 RC7 the defect shows up, instead of RC6 in which not, operative system Windows XP professional.
When you are using a PAN or ZOOM command, or simply adding a layers, (looking from windows taskmanager)map display start a "cmd.exe" process. This process disappear after few seconds but if the option display=attr is active, doesn't shut down properly:
-at every zoom/pan on map the Map display open a new cmd.exe process that will never be closed.
-this trend (adding process) go ahead until the Grass doesn't work and stop following comand .
-even closing Grass before or after its block those process don't disappear.
-the only way in which a user could shut down those process is the windows task manager.
example: d.vect map=reteF display=shape,attr
type=point,area,centroid attrcol='id'
Change History (13)
follow-up: 2 comment:1 by , 14 years ago
Component: | Display → wxGUI |
---|---|
Keywords: | wingrass added; display=attr removed |
Priority: | blocker → critical |
comment:2 by , 14 years ago
Replying to hamish:
Hi,
I can reproduce this using a brand new nightly build of wingrass 6.4 and 6.5 with the wxGUI and spearfish dataset.
- ctrl-alt-del to open the process monitor, click the Image name column in the Processes tab to sort by process name.
- in the wxgui layer manager add the roads vector map, then tick disp=attr and set attrcol to 'label' in the d.vect Labels tab.
- then zoom, pan around and watch the number of cmd.exe and dbf.exe processes grow. exiting grass does not kill them, and they are not visible on the task bar.
in 6.4 it just leaves orphaned processes behind, in 6.5svn it is worse, using d.vect attrcol= locks the entire GUI and Windows XP taskbar until you type
exit
in the MSys rxvt terminal (which is still fully responsive).cleanup: killing the dbf.exe processes makes the cmd.exe ones go away too.
Hamish
still there in WinGRASS-6.4.SVN-r45671-1-Setup.exe
Helmut
follow-up: 4 comment:3 by , 13 years ago
is this problem fixed in the new version? or the last 6.4.1 still has this bug?
comment:4 by , 13 years ago
Milestone: | 6.4.1 → 6.4.2 |
---|
follow-ups: 6 7 comment:5 by , 13 years ago
Description: | modified (diff) |
---|
dbf.exe
s still piling up in the process manager with latest 6.4.svn native wingrass nightly build. what's more if you select disp=attr attrcol=label the wxGUI locks up with an endless hourglass. the "this program is not responding" dialog helps you kill it and get back to the working msys prompt where you can restart it with g.gui. (but the dbf.exe
s remain running)
Hamish
comment:6 by , 13 years ago
Keywords: | d.vect added |
---|
Replying to hamish:
what's more if you select disp=attr attrcol=label the wxGUI locks up with an endless hourglass. the "this program is not responding" dialog helps you kill it and get back to the working msys prompt where you can restart it with g.gui. (but the
dbf.exe
s remain running)
see also #1331
Hamish
follow-up: 8 comment:7 by , 13 years ago
Replying to hamish:
dbf.exe
s still piling up in the process manager with latest 6.4.svn native wingrass nightly build. what's more if you select disp=attr attrcol=label the wxGUI locks up with an endless hourglass. the "this program is not responding" dialog helps you kill it and get back to the working msys prompt where you can restart it with g.gui. (but thedbf.exe
s remain running)
Non-display commands that do very similar things to d.vect disp=shape,attr attrcol=col
run just fine through the wxGUI, finish successfully and do not leave stray dbf.exe
processes behind.
Display commands are run through gcmd.RunCommand() which in turn calls grass.script.core.start_command() which in turn calls grass.script.core.Popen(). Non-display commands invoked through wxGUI are run through gcmd.Popen().
The endless hourglass goes away if ps.communicate() is replaced with ps.wait() in gcmd.RunCommand(), d.vect finishes successfully and labels are drawn. But it leaves a stray dbf.exe
process behind.
Interestingly, the grass.script.core.*_command() functions and thus grass.script.core.Popen() are successfully used very often by the wxGUI, e.g. every time a column option field is populated. That does not leave stray dbf.exe
processes behind.
It seems that gcmd.RunCommand() is doing something that prevents dbf.exe
from finishing, or prevents G_wait() from properly waiting for dbf.exe
to finish, whereas gcmd.Popen() runs fine.
This affects all branches.
Markus M
comment:8 by , 13 years ago
Replying to mmetz:
Display commands are run through gcmd.RunCommand() which in turn calls grass.script.core.start_command() which in turn calls grass.script.core.Popen(). Non-display commands invoked through wxGUI are run through gcmd.Popen().
it's not a question of display or non-display commands. gcmd.!RunCommand()
is used when the GUI waits for command termination. In opposite gcmd.Popen()
is used through gcmd.CommandThread
which is basically reserved for the commands running on the background (eg. those launched from wxGUI command prompt).
follow-ups: 10 11 comment:9 by , 13 years ago
Cc: | added |
---|---|
Owner: | changed from | to
Status: | new → assigned |
The real problem was that db_close_database_shutdown_driver()
hasn't been called in display_attr()
when there was at least one feature to read. Hopefully fixed in r49171 (devbr6
). Testing highly welcomed.
comment:10 by , 13 years ago
comment:11 by , 13 years ago
comment:12 by , 13 years ago
Resolution: | → fixed |
---|---|
Status: | assigned → closed |
Tested with last winGRASS 6.4 build. Seems to work. Closing.
Hi,
I can reproduce this using a brand new nightly build of wingrass 6.4 and 6.5 with the wxGUI and spearfish dataset.
in 6.4 it just leaves orphaned processes behind, in 6.5svn it is worse, using d.vect attrcol= locks the entire GUI and Windows XP taskbar until you type
exit
in the MSys rxvt terminal (which is still fully responsive).cleanup: killing the dbf.exe processes makes the cmd.exe ones go away too.
Hamish