mirror of
				https://git.rtems.org/rtems-source-builder
				synced 2024-10-09 07:15:10 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			112 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			Python
		
	
	
		
			Executable File
		
	
	
	
	
| #
 | |
| # RTEMS Tools Project (http://www.rtems.org/)
 | |
| # Copyright 2010-2012 Chris Johns (chrisj@rtems.org)
 | |
| # All rights reserved.
 | |
| #
 | |
| # This file is part of the RTEMS Tools package in 'rtems-testing'.
 | |
| #
 | |
| # Permission to use, copy, modify, and/or distribute this software for any
 | |
| # purpose with or without fee is hereby granted, provided that the above
 | |
| # copyright notice and this permission notice appear in all copies.
 | |
| #
 | |
| # THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
 | |
| # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
 | |
| # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
 | |
| # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
 | |
| # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
 | |
| # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
 | |
| # OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
 | |
| 
 | |
| #
 | |
| # Log output to stdout and/or a file.
 | |
| #
 | |
| 
 | |
| import os
 | |
| import sys
 | |
| 
 | |
| import error
 | |
| 
 | |
| #
 | |
| # A global log.
 | |
| #
 | |
| default = None
 | |
| 
 | |
| def set_default_once(log):
 | |
|     if default is None:
 | |
|         default = log
 | |
| 
 | |
| def output(text = os.linesep, log = None):
 | |
|     """Output the text to a log if provided else send it to stdout."""
 | |
|     if text is None:
 | |
|         text = os.linesep
 | |
|     if type(text) is list:
 | |
|         _text = ''
 | |
|         for l in text:
 | |
|             _text += l + os.linesep
 | |
|         text = _text
 | |
|     if log:
 | |
|         log.output(text)
 | |
|     elif default is not None:
 | |
|         default.output(text)
 | |
|     else:
 | |
|         for l in text.replace(chr(13), '').splitlines():
 | |
|             print l
 | |
| 
 | |
| def flush(log = None):
 | |
|     if log:
 | |
|         log.flush()
 | |
|     elif default is not None:
 | |
|         default.flush()
 | |
| 
 | |
| class log:
 | |
|     """Log output to stdout or a file."""
 | |
|     def __init__(self, streams = None):
 | |
|         self.fhs = [None, None]
 | |
|         if streams:
 | |
|             for s in streams:
 | |
|                 if s == 'stdout':
 | |
|                     self.fhs[0] = sys.stdout
 | |
|                 elif s == 'stderr':
 | |
|                     self.fhs[1] = sys.stderr
 | |
|                 else:
 | |
|                     try:
 | |
|                         self.fhs.append(file(s, 'w'))
 | |
|                     except IOError, ioe:
 | |
|                          raise error.general("creating log file '" + s + \
 | |
|                                              "': " + str(ioe))
 | |
| 
 | |
|     def __del__(self):
 | |
|         for f in range(2, len(self.fhs)):
 | |
|             self.fhs[f].close()
 | |
| 
 | |
|     def has_stdout(self):
 | |
|         return self.fhs[0] is not None
 | |
| 
 | |
|     def has_stderr(self):
 | |
|         return self.fhs[1] is not None
 | |
| 
 | |
|     def output(self, text):
 | |
|         """Output the text message to all the logs."""
 | |
|         # Reformat the text to have local line types.
 | |
|         out = ''
 | |
|         for l in text.replace(chr(13), '').splitlines():
 | |
|             out += l + os.linesep
 | |
|         for f in range(0, len(self.fhs)):
 | |
|             if self.fhs[f] is not None:
 | |
|                 self.fhs[f].write(out)
 | |
| 
 | |
|     def flush(self):
 | |
|         """Flush the output."""
 | |
|         for f in range(0, len(self.fhs)):
 | |
|             if self.fhs[f] is not None:
 | |
|                 self.fhs[f].flush()
 | |
| 
 | |
| if __name__ == "__main__":
 | |
|     l = log(['stdout', 'log.txt'])
 | |
|     for i in range(0, 10):
 | |
|         l.output('hello world: %d\n' % (i))
 | |
|     l.output('hello world CRLF\r\n')
 | |
|     l.output('hello world NONE')
 | |
|     l.flush()
 | |
|     del l
 | 
