No arquivo .BAT a seguir, o teste 2 demonstra o bug de cor dentro de um bloco de código entre parênteses, o teste 3 demonstra o bug dentro de um loop FOR e o teste 4 mostra como o bug pode ser mitigado chamando uma sub-rotina do-nothing ( call : resetANSI ). Minhas perguntas são:
Qual é a natureza do bug... por que os códigos de cores embutidos falham após a canalização para FINDSTR dentro de um bloco de código entre parênteses? Esse bug é específico do FINDSTR ou mais geral? (FINDSTR tem alguns bugs conhecidos, mas não vi este listado entre eles.)
Chamar a sub-rotina não fazer nada é a melhor maneira de mitigar esse bug?
Abaixo do código está uma captura de tela da saída de exibição, que mostra que o código de cores falhou nos testes 2 e 3 nas linhas que deveriam ser exibidas em magenta.
Desde já agradeço a quem tentar ajudar!
[EDIT 26/03/2020: Como o fórum não exibiu o caractere Esc nas definições de código de cores no código .bat, editei o código .bat para que ele gere o caractere Esc em tempo de execução.]
@echo off
goto :main
:resetANSI
EXIT /B
:main
setlocal EnableDelayedExpansion
for /F "delims=#" %%E in ('"prompt #$E# & for %%E in (1) do rem"') do set "ESCchar=%%E"
set "green=%ESCchar%[92m"
set "yellow=%ESCchar%[93m"
set "magenta=%ESCchar%[95m"
set "cyan=%ESCchar%[96m"
set "white=%ESCchar%[97m"
echo %white%Test 1 is NOT in a FOR loop nor within parentheses.
echo %yellow%[Test 1] %green%This is Green, %magenta%this is Magenta, and %yellow%this is Yellow.
echo %Next, the string 'success' will be piped to FINDSTR...
echo success | findstr /R success
echo %magenta%This is supposed to be magenta, and FINDSTR found and displayed 'success'.%yellow%
echo %cyan%Test 1 completed.
echo %white%Test 2 is within parentheses.
( echo %yellow%[Test 2] %green%This is Green, %magenta%this is Magenta, and %yellow%this is Yellow.
echo %Next, the string 'success' will be piped to FINDSTR...
echo success | findstr /R success
echo %magenta%This is supposed to be magenta, and FINDSTR found and displayed 'success'.%yellow%
)
echo %cyan%Test 2 completed.
echo %white%Test 3 is within a FOR loop.
for /L %%G in (3,1,3) do (
echo %yellow%[Test %%G] %green%This is Green, %magenta%this is Magenta, and %yellow%this is Yellow.
echo %Next, the string 'success' will be piped to FINDSTR...
echo success | findstr /R success
echo %magenta%This is supposed to be magenta, and FINDSTR found and displayed 'success'.%yellow%
)
echo %cyan%Test 3 completed.%white%
echo %white%Test 4 is within a FOR loop and includes a call/return after the pipe to FINDSTR.
for /L %%G in (4,1,4) do (
echo %yellow%[Test %%G] %green%This is Green, %magenta%this is Magenta, and %yellow%this is Yellow.
echo %Next, the string 'success' will be piped to FINDSTR...
echo success | findstr /R success
call :resetANSI
echo %magenta%This is supposed to be magenta, and FINDSTR found and displayed 'success'.%yellow%
)
echo %cyan%Test 4 completed.%white%
exit /B
Com base em uma tentativa do usuário vssher de responder à pergunta (vssher excluiu sua tentativa depois que descobriu que não funcionava direito), acho que encontrei a melhor solução: coloque o comando FINDSTR entre parênteses aninhados. A solução é demonstrada nos testes 3 e 4 do código .bat a seguir, e uma captura de tela da saída de exibição é mostrada abaixo do código .bat: