Monday, 19 May 2008

Using CON... or not

Hi folks. I am back from the wilderness of, well, my inner-self I guess.
And here with another tip: using CON or not.

When you are programming a batch file, it's usually pretty useful to get the output to show on screen. Why? Well, simply because it saves you the trouble of finding and opening a potential log file just to read some silly message about a file not being found, or some syntax error for instance.

So, let's start from the top.

1. How do I redirect output from the console to a logfile?
Here are perhaps the more useful redirection techniques.

@echo off
echo Hello World > hello.txt
echo Press any key to quit...
pause > NUL

This will redirect the command echo Hello World to the hello.txt file (which is created in the directory where the batch file is located).
You can immediately see the way to turn this into a logging functionality:

@echo off
echo Something happened > my_log.log
echo Press any key to quit...
pause > NUL

The poor thing about this is, if you run the batch twice consecutively you will loose the first output. The > is in effect making sure the file is rewritten completely. If you want to append to a file, simply use >>.

@echo off
echo Something else happened >> my_log.log
echo Press any key to quit...
pause > NUL

Great! Now we are actually adding to the log as we go along. The beauty in this is that if the file doesn't already exist it's automatically created (in the same way as when you use the simple > redirect).

So, all is cool here except echo is a pretty boring command. So let's liven things up a little. First we will copy hello.txt to hello1.txt, then we will remove directory hello.txt (of course, we will assume there is no hello.txt directory on your system, at least please make sure you check for this! - this will fail hello.txt not being a directory).

With these more "complex" commands you can distinguish standard output (numbered 1) from error output (numbered 2). So you can actually redirect standard output to one file, and error output to the console for instance.

@echo off
echo Before copy >> my_log.log
copy hello.txt hello1.txt >> my_log.log 2>&1
echo Before rmdir 1 >> my_log.log
rmdir hello.txt >> my_log.log
echo Before rmdir 2 >> my_log.log
rmdir hello.txt >> my_log.log 2>&1
echo Press any key to quit...
pause > NUL

Using this example you can see how adding 2>&1 after the redirect will make sure both standard and error output are redirected to file. Otherwise error output will show on screen (first rmdir).


2. Dynamically choosing where to redirect to

Now, let's say in certain cases you want to redirect output to screen but in other cases (say your batch is being called from within another script) you would rather use a file.

You can do this using CON.

@echo off

:init_vars
set out=CON
if not "%1"=="" set out="%1"
goto do_stuff

:do_stuff
echo Copying hello.txt >> %out%
copy hello.txt hello1.txt >> %out% 2>&1
echo Removing directory hello.txt >> %out%
rmdir hello.txt >> %out% 2>&1
goto eof

:eof
if not "%out%"=="CON" goto blackhole
echo Press any key to quit...
pause > NUL
goto blackhole

:blackhole

If you just launch the batch file, all the output will show up on console (because no %1 argument has been provided).

If you launch the batch via a call as follows, however:

@echo off
redirect5 my_second_log.log

The output will get sent to my_second_log.log. Note that on top of that we can avoid pausing the process 'for nothing' by using the if not "%out%"=="CON" goto blackhole condition in :eof. Neat, don't you think?

I have never actually seen a redirection based on anything else but a "on-a-command" basis i.e. how to redirect output for the whole current process. Have you? If so, drop me a line, I would love to know how to do this, if possible!

Another post will be coming up shortly. Just a few thoughts I would like to share.

No comments:

Online Marketing
Add blog to our blog directory blog search directory Blog Directory Blogarama - The Blog Directory