Skip to content

danielt3/mtee

 
 

Repository files navigation

Table of Contents

Synopsis

Mtee is a Win32 console application that sends any data it receives to stdout and to any number of files. Useful if you want to watch and record the output from a batch file or program. It can also prefix each line of output with a timestamp.

Mtee is a 45kb standalone executable. It does not create any temporary files or write to the registry. There is no installation procedure, just run it. To remove all traces of Mtee from your system, just delete it.

Mtee is simple to use and only has several options. To list them, type:-

mtee /?

Usage

  MTEE [/A | /U] [/C] [/D] [/T] [/E] [[/+] file] [...]

  /A    Convert output to ANSI. Default output is same as input.
  /C    Continue if errors occur opening/writing to file (advanced users only).
  /D    Prefix each line of output with local date in YYYY-MM-DD format.
  /T    Prefix each line of output with local time in HH:MM:SS.MSS format.
  /U    Convert output to UNICODE. Default output is same as input.
  /E    Exit with exit code of piped process.
  /ET   Calculate and display elapsed time.
  /CPU  Calculate and display average CPU load during execution.  
  /+    Append to existing file. If omitted, existing file is overwritten.
  file  File to receive the output. File is overwritten if /+ not specified.
  ...   Any number of additional files. Use /+ before each file to append.

  Example usage:-

  1) script.cmd | mtee result.txt
  2) ftp -n -s:ftp.scr | mtee local.log /+ \\server\logs$\remote.log
  3) update.cmd 2>&1 | mtee/d/t/+ log.txt

  1) Sends the output of script.cmd to the console and to result.log. If
     result.txt already exists, it will be overwritten.
  2) Sends output of automated ftp session to the console and two log files,
     local.log is overwritten if it already exists, remote.log is appended to.
  3) Redirects stdout and stderr from update.cmd to console and appends to
     log.txt. Each line is prefixed with local date and time.

Examples

View Mtee help screen:-

mtee/?

Send the output of script.cmd to the console and to RESULT.LOG. If RESULT.LOG already exists, it will be overwritten:-

script.cmd | mtee result.log

Send the output of the automated ftp session to the console and to two log files, LOCAL.LOG is overwritten if it already exists. REMOTE.LOG is appended to if it exists, otherwise it is created:-

ftp -n -s:ftp.scr | mtee local.log /+ \\server\logs\remote.log

Make two copies of LOG whilst viewing LOG on the screen. If NEW1 and NEW2 already exist, they are overwritten:-

mtee < log new1 new2

Redirect stdout and stderr from UPDATE.CMD to the console and appends to LOG.TXT. Each line is prefixed with local date and time:-

update.cmd 2>&1 | mtee/d/t/+ log.txt

Send the output from BACKUP.CMD to the console and two remote log files. If there is an error opening any of the log files (server offline for instance) MTEE will continue. If the destination files already exist, they are appended to:-

backup.cmd | mtee /c/+ \\svr1\log$\bu.log /+ \\svr2\logs$\bu.log

Make multiple carbon copies of patch.exe:-

type patch.exe|mtee \\pc1\c$\patch.exe \\pc2\c$\patch.exe \\pc3\c$\patch.exe

Make a unicode log of HFNETCHK:-

hfnetchk|mtee/u log

Display stdout on the console, and stderr on the console and also to a log file with each line of stderr prefixed with local date and time:-

batch.cmd 2>&1 1>&3 3>&1 |mtee/t/d log

FAQs

How can I determine the exit code of the process piped into Mtee?

Update Mtee to at least version v2.21 and use the /E option.

Screenshots

Screenshot of Mtee

CPU Load

The CPU load calculations are based in the information from the GetSystemTimes Windows API. For reference, please check: https://docs.microsoft.com/en-us/windows/desktop/api/processthreadsapi/nf-processthreadsapi-getsystemtimes

The algorithm works by reading the idle, kernel and user times of the system (the time the system spent executing in each of these modes). Then, we define load time as the kernel time plus the user time and total time as kernel time plus user time plus idle time. Finally, the cpu load is calculated as the quotient between load time and total time. The mindset here is that everything that is not idle means loading the CPU.

This is a rough estimate and subject to criticsm. I'm willing to listen and implement better approaches.

Revisions

Revision Date Changes
2.6 2019-04-29 Improved processes list detection; don't open process handle if not needed.
2.5 2019-04-14 Added /CPU option (calculate and display average CPU load).
2.4 2018-08-16 Fixed elapsed time display (added a newline at the end).
2.3 2018-06-21 Added /ET option (calculate and display elapsed time).
2.21 2016-08-07 Added /E option (exit with exit code of process piped into Mtee). Cleaned up code - Mtee compiles without errors or warnings using a default install of the CodeBlocks IDE.
2.2 2016-06-10 Credit to Jari Kulmala for implementing workaround to avoid possible bug in Windows 10 where program takes 30 seconds to exit.
2.1 2013-03-01 Mtee is now open source software released under the MIT License. Credit to Jari Kulmala for addressing the following:-
  • mtee is now Windows 8 compatible
  • mtee assumed all files < 4GB
  • echo "t013|mtee /u con" entered a continuous loop
  • "echo x x x x | mtee" caused mtee to guess input was unicode
  • redirection to console and con device as output file was not supported
2.0 2003-08-27 The following features are new to Mtee v2.0:-
  • Read and output unicode
  • Convert ANSI to unicode (and vice-versa)
  • Reads text and binary data without performing any character translations
  • Support for unicode filenames of ~32,000 characters
  • Smaller than ever. Mtee is now just 11kb (and no, it's not compressed!)

Copyright and License

Code and documentation copyright 2001-2016 Ritchie Lawrence. Code released under MIT License