Opened 13 years ago
Closed 12 years ago
#1310 closed defect (fixed)
Browse button in WxPython GUIs (for scripts) does not provide a correct file path for WinGRASS
Reported by: | katrineggert1980 | Owned by: | |
---|---|---|---|
Priority: | critical | Milestone: | 6.4.2 |
Component: | Shell Scripts | Version: | 6.4.1 RCs |
Keywords: | winGRASS | Cc: | |
CPU: | Unspecified | Platform: | MSWindows XP |
Description
Greetings
I'm running GRASS script function (e.g. r.out.xyz) and If I use Browse button to search/define for output file it produces a path in Windows style (e.g. C:\data\GRASS\) that is wrong since GRASS's pythons do not use '\'. So user need to change '\' by hand to '/'. THis happens to all GRASS Scripts that uses Browse and file paths. This does not happen in text mode if we use " " around the file path.
Change History (27)
follow-up: 3 comment:1 by , 13 years ago
follow-up: 9 comment:2 by , 13 years ago
Replying to katrineggert1980: [...]
maybe some hints from the ML (http://lists.osgeo.org/pipermail/grass-dev/2011-March/053942.html)
Just a preliminary note: This error is reported here: http://lists.osgeo.org/pipermail/grass-dev/2011-March/053774.html I saw that Glynn sugeste this a couple of months ago: http://lists.osgeo.org/pipermail/grass-dev/2010-October/052396.html Can this be an option to solve this problem? Can anyone give a few tips on this? (just to try and test it) Thanks Best Regards Kat
follow-up: 4 comment:3 by , 13 years ago
Replying to hellik:
tested with WinGRASS-6.4.SVN-r45749-1-Setup.exe
...
r.out.xyz input=elevation@PERMANENT output=C:\wd\exportgrass\routxyz.txt c:/Program Files/GRASS 6.4.SVN/scripts/r.out.xyz: line 61: C:wdexportgrassroutxyz.txt: Permission denied
Looking at the *script* r.out.xyz, we see that a redirection is used:
# if no output filename, output to stdout if [ -z "$GIS_OPT_OUTPUT" ] || [ "$GIS_OPT_OUTPUT" = "-" ]; then r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" else r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" > "$GIS_OPT_OUTPUT" fi
I suspect that this is causing problems on Windows.
follow-up: 5 comment:4 by , 13 years ago
Replying to neteler:
Looking at the *script* r.out.xyz, we see that a redirection is used:
# if no output filename, output to stdout if [ -z "$GIS_OPT_OUTPUT" ] || [ "$GIS_OPT_OUTPUT" = "-" ]; then r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" else r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" > "$GIS_OPT_OUTPUT" fiI suspect that this is causing problems on Windows.
I wonder why not simply using the "output=" parameter of r.stats:
output Name for output file (if omitted or "-" output to stdout)
Helmut, could you please test if adding output="$GIS_OPT_OUTPUT" helps?
follow-up: 6 comment:5 by , 13 years ago
Replying to neteler:
Helmut, could you please test if adding output="$GIS_OPT_OUTPUT" helps?
tried with following:
# if no output filename, output to stdout if [ -z "$GIS_OPT_OUTPUT" ] || [ "$GIS_OPT_OUTPUT" = "-" ]; then r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" else r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" > output="$GIS_OPT_OUTPUT" fi
now there isn't any error message
r.out.xyz input=elevation@PERMANENT output=C:\wd\test\routxyzp.xyz (Sat Mar 26 18:30:37 2011) Command finished (46 sec)
but the file doesn't seem to be written, the destination folder is empty.
follow-up: 7 comment:6 by , 13 years ago
Replying to hellik:
# if no output filename, output to stdout if [ -z "$GIS_OPT_OUTPUT" ] || [ "$GIS_OPT_OUTPUT" = "-" ]; then r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" else r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" > output="$GIS_OPT_OUTPUT" fi
but the file doesn't seem to be written, the destination folder is empty.
Yes, you forgot to take out ">". Try this code:
# if no output filename, output to stdout if [ -z "$GIS_OPT_OUTPUT" ] || [ "$GIS_OPT_OUTPUT" = "-" ]; then r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" output="-" else r.stats -1gn "$GIS_OPT_INPUT" fs="$GIS_OPT_FS" output="$GIS_OPT_OUTPUT" fi
follow-up: 8 comment:7 by , 13 years ago
Replying to neteler:
Yes, you forgot to take out ">". Try this code:
r.out.xyz input=elevation@PERMANENT output=C:\wd\test\test.xyz ERROR: Kann Datei <C:wdtesttest.xyz> nicht zum Schreiben öffnen. (Sat Mar 26 19:14:10 2011) Command finished (0 sec)
so no change regarding the path issue.
Helmut
comment:8 by , 13 years ago
Replying to hellik:
Replying to neteler:
Yes, you forgot to take out ">". Try this code:
r.out.xyz input=elevation@PERMANENT output=C:\wd\test\test.xyz ERROR: Kann Datei <C:wdtesttest.xyz> nicht zum Schreiben öffnen. (Sat Mar 26 19:14:10 2011) Command finished (0 sec)so no change regarding the path issue.
for the record with the original code:
if I copy the command from the wxgui to the wingrass-msys-shell
GRASS 6.4> r.out.xyz input=elevation@PERMANENT output=C:\wd\test\testroutxyz.txt c:/Program Files/GRASS 6.4.SVN/scripts/r.out.xyz: line 61: C:wdtesttestroutxyz.txt: Permission denied
and with a quoted path in the wingrass-msys-shell
GRASS 6.4> r.out.xyz input=elevation@PERMANENT output="C:\wd\test\testroutxyz.txt" 100% GRASS 6.4>
the original code is working in windows with a quoted path
follow-up: 11 comment:9 by , 13 years ago
Replying to hellik:
from the dev-ML (http://lists.osgeo.org/pipermail/grass-dev/2011-March/053954.html)
katrin eggert wrote: > Just a preliminary note: This error is reported here: > http://lists.osgeo.org/pipermail/grass-dev/2011-March/053774.html > > I saw that Glynn sugeste this a couple of months ago: > http://lists.osgeo.org/pipermail/grass-dev/2010-October/052396.html > > Can this be an option to solve this problem? Can anyone give a few tips on > this? (just to try and test it) Right. Currently, 6.5 has utils.split(), which handles Windows filenames, but much of the wx GUI is still using shlex.split() directly. Feel free to replace all occurrences of shlex.split() with utils.split() in your local copy. Also, open a bug report (if there isn't already one for this issue).
comment:10 by , 13 years ago
To change the code in automated way:
cd gui/wxpython/gui_modules/ for i in menuform.py gmodeler.py menu.py prompt.py goutput.py ; do mv $i tmp.py ; cat tmp.py | sed 's+shlex.split+utils.split+g' > $i ; rm -f tmp.py ; done for i in menuform.py gmodeler.py menu.py prompt.py goutput.py ; do mv $i tmp.py ; cat tmp.py | sed 's+import shlex+import utils+g' > $i ; rm -f tmp.py ; done
follow-up: 12 comment:11 by , 13 years ago
Replying to hellik:
> katrin eggert wrote: > > > Just a preliminary note: This error is reported here: > > http://lists.osgeo.org/pipermail/grass-dev/2011-March/053774.html > > > > I saw that Glynn sugeste this a couple of months ago: > > http://lists.osgeo.org/pipermail/grass-dev/2010-October/052396.html > > > > Can this be an option to solve this problem? Can anyone give a few tips on > > this? (just to try and test it) > > Right. Currently, 6.5 has utils.split(), which handles Windows > filenames, but much of the wx GUI is still using shlex.split() > directly. > > Feel free to replace all occurrences of shlex.split() with > utils.split() in your local copy. Also, open a bug report (if there > isn't already one for this issue).
done in r45770 (devbr6) and r45771 (trunk). Testing welcomed.
comment:12 by , 13 years ago
Replying to martinl:
done in r45770 (devbr6) and r45771 (trunk). Testing welcomed.
tested in a self compiled wingrass65 r45770
r.out.xyz --verbose input=elevation@PERMANENT output=C:\wd\test\wingrass65rout.xyz c:/osgeo4w/usr/src/grass6_devel/dist.i686-pc- mingw32/scripts/r.out.xyz: line 61: C:wdtestwingrass65rout.xyz: Permission denied
follow-up: 14 comment:13 by , 13 years ago
I have tested with the following:
- GRASS Inport/Export modules- Works on Windows
- GRASS Inport/Export bash scripts- Does not work
- GRASS Inport/Export Python scripts- Does not work
comment:14 by , 13 years ago
Replying to katrineggert1980:
I have tested with the following:
- GRASS Inport/Export modules- Works on Windows
- GRASS Inport/Export bash scripts- Does not work
- GRASS Inport/Export Python scripts- Does not work
Ups Sorry. This meant before these updates :)
comment:15 by , 13 years ago
I have installed WinGRASS6.4 night built from today (28th March 2011) and I tried: (Mon Mar 28 10:16:51 2011) r.out.xyz input=lsat5_1987_10@landsat output=C:\delete\tried\output01 fs= (Mon Mar 28 10:16:53 2011) Command finished (1 sec)
It didn't created the file in C:\delete\tried\output01. Again, it has ignored the bars... So it's still not working
follow-up: 17 comment:16 by , 13 years ago
Hi I have just tried Nightly built for GRASS6.5 and: (Mon Mar 28 10:31:48 2011) r.out.xyz input=lsat5_1987_10@landsat output=C:\delete\tried\output02 fs= path: C:deletetriedoutput02 Output written to C:deletetriedoutput02 Output written to C:deletetriedoutput02 (Mon Mar 28 10:31:50 2011) Command finished (1 sec)
And now it«s not even creating the file c:\deletetriedoutput02
I added, in the beggining of the code a print of $GIS_OPT_OUTPUT and it's printed as: C:deletetriedoutput02
So it's still not working
comment:17 by , 13 years ago
Replying to katrineggert1980:
I added, in the beggining of the code a print of $GIS_OPT_OUTPUT and it's printed as: C:deletetriedoutput02
So it's still not working
source of the problem are bat scripts, in this case $ARCH_DISTDIR\bin\r.out.xyz.bat
@"%GRASS_SH%" -c '"%GISBASE%/scripts/r.out.xyz" %*'
where '\` are escaped. To make Bash script working on Windows is generally speaking pain. The future are Python scripts in GRASS 7. I still think that Pythonized script could replace most of Bash scripts in GRASS 6.
Benefits:
- maintaining scripts only in one language
- Python scripts can run on Windows without any problems
Drawback:
- some new bugs can be introduced, anyway some Bash-related can be fixed by this conversion
- Python as requirement
I proposed that some time ago, but it was refused.
follow-up: 19 comment:18 by , 13 years ago
Ok it makes some sense. If I try to run anything on Msys the \ are ignored. So this can be a possible solution. But my question is, why C Modules accepts "\" and Scripts don't.
comment:19 by , 13 years ago
Replying to katrineggert1980:
Ok it makes some sense. If I try to run anything on Msys the \ are ignored. So this can be a possible solution. But my question is, why C Modules accepts "\" and Scripts don't.
Because C modules don't use Bash for parsing the arguments. I would say rather *Bash* scripts, Python scripts haven't such problem.
comment:20 by , 13 years ago
Component: | wxGUI → Bash |
---|
Changing compoment to Bash
.
Running from msys
r.out.xyz input=elevation out=C:\Temp\x.txt
create Tempx.txt
in C drive.
r.out.xyz input=elevation out="C:\Temp\x.txt"
works as expected.
follow-up: 22 comment:21 by , 13 years ago
Just an idea to fix this (for now and for Win users): is it possible to change wxGUI parsing values in order to automatically change "\" (windows paths) to "/" before it sends the options to Bash?
comment:22 by , 13 years ago
Replying to katrineggert1980:
Just an idea to fix this (for now and for Win users): is it possible to change wxGUI parsing values in order to automatically change "\" (windows paths) to "/" before it sends the options to Bash?
it's just a tricky workaround, let's find a better solution. Since we are still keeping Bash script sin GRASS 6 we need to find a solution... Any idea?
comment:23 by , 13 years ago
A file path that is inserted in WxGUI is first parsed in grass.parser() So I went to core.py to parser() and, if I print for instance print (sys.argv[2]) my file path is no longer with '\' So the options in sys.argv (line 422) are no longer with '\' So my question is, what function places data and information in sys.argv variable?
comment:24 by , 13 years ago
As far as I can see, the only solution seems to be in *.bat file. I mean, when the command is sent to GRASS_SH something should be processed before in order to switch the bars. Any idea? (I don't much about Bash Scripting)
follow-up: 26 comment:25 by , 13 years ago
Milestone: | 6.4.1 → 6.4.2 |
---|---|
Summary: | Browse button in WxPython GUIs (for scripts) does not provide a correct file path for WinGRAS → Browse button in WxPython GUIs (for scripts) does not provide a correct file path for WinGRASS |
follow-up: 27 comment:26 by , 12 years ago
Replying to hamish:
fixed by r48449? (duplicate of #1447?)
scripts/windows_launch.bat now reads:
@"%GRASS_SH%" "%GISBASE%/scripts/SCRIPT_NAME" %*(no more -c, 'single quotes' removed)
tested with
osgeo4w-wingrass6.4.3 r52715
r.out.xyz --verbose input=elevation@PERMANENT output=C:\tmp\elevoutwingrass643.txt (Sat Aug 18 15:22:48 2012) Befehl ausgeführt (10 sec)
osgeo4w-wingrass r52495
r.out.xyz --verbose input=elevation@PERMANENT output=C:\tmp\elevoutwingrass65.txt (Sat Aug 18 15:26:16 2012) Befehl ausgeführt (7 sec)
closing ticket?
Helmut
comment:27 by , 12 years ago
Resolution: | → fixed |
---|---|
Status: | new → closed |
tested with WinGRASS-6.4.SVN-r45749-1-Setup.exe
folder and file destination of the output files always definded by the Browse button of the wxgui
but very interesting also tested with other raster and vector export modules
are you able to test it on your side?
best regards Helmut