Attached is an example that does what you are describing. Also demonstrates using vbscript, subroutines and overrides (the subroutine name in the Execute appropriate subroutine step).
Note that Visual Build Professional provides much of the requested capability (logging success/failure, failure steps), so some of this seems a bit redundant...
|