in reply to Cleaning %PATH% with WinBatch
> To make this even more idiot proof .. I'd like to purge all older entries from PATH
I dont see the point: if you prepend your desired perl to PATH (as portableshell.bat does) there is almost no risk of collision: only a call to a make flavour not present in the first distribution can lead to problems. I mean: if you cast perl5.34 and this does not contains nmake (just as example) but this executable is present in perl5.10 just few entry onward in PATH ..so this can be a problem. It seems to me a very advanced usage so probably not your (collegues) case.
If you are already using portableshell.bat you can simply hardcode your desired PATH modifying the line..
set PATH=%~dp0perl\site\bin;%~dp0perl\bin;%~dp0c\bin;%PATH% # ...to something like set PATH=%~dp0perl\site\bin;%~dp0perl\bin;%~dp0c\bin;c:\Windows;C: +\Windows\System32;
The above is generally enough.
In more customized scenarios you can reuse other ENV entries to build up your final PATH for example:
HOMEDRIVE=C: ProgramFiles=C:\Program Files ProgramFiles(x86)=C:\Program Files (x86) ProgramW6432=C:\Program Files windir=C:\WINDOWS
PS more on this:
> off course I could spawn a perl one-liner, but the basic idea of BAT is to keep the delay minimal
Perl is already here and used, so if you prefere perl over batch (;) you can use it to change $ENV{PATH} you only need to modify the perl oneliner aimed to print nice stuff on screen:
# line 24 of portableshell.bat perl -MConfig -e "printf("""Perl executable: %%s\nPerl version : %%v +d / $Config{archname}\n\n""", $^X, $^V)" 2>nul
I hope File::Spec can handle weird windows names correctly using path separtor and the idiom @PATH = File::Spec->path();
L*
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^2: Cleaning %PATH% with WinBatch
by LanX (Saint) on May 23, 2022 at 08:34 UTC | |
by Discipulus (Canon) on May 23, 2022 at 09:07 UTC | |
by Anonymous Monk on May 23, 2022 at 09:46 UTC | |
by Discipulus (Canon) on May 23, 2022 at 09:57 UTC | |
by Anonymous Monk on May 23, 2022 at 23:59 UTC | |
by Anonymous Monk on May 23, 2022 at 09:01 UTC | |
by LanX (Saint) on May 23, 2022 at 11:47 UTC |