summaryrefslogtreecommitdiffstats
path: root/Doc/lib/liblogging.tex
diff options
context:
space:
mode:
authorFred Drake <fdrake@acm.org>2004-10-29 14:35:42 (GMT)
committerFred Drake <fdrake@acm.org>2004-10-29 14:35:42 (GMT)
commit048840c4850ffb0426d32347bfa7278484bfb049 (patch)
treebc34b3cad19c05c4ec5d92fb52511f63ac7c915c /Doc/lib/liblogging.tex
parent006483b00301d65291202ad88257e10e8fcfab9d (diff)
downloadcpython-048840c4850ffb0426d32347bfa7278484bfb049.zip
cpython-048840c4850ffb0426d32347bfa7278484bfb049.tar.gz
cpython-048840c4850ffb0426d32347bfa7278484bfb049.tar.bz2
style consistency:
- always include a space after the "#" that starts a comment - easier to read imports
Diffstat (limited to 'Doc/lib/liblogging.tex')
-rw-r--r--Doc/lib/liblogging.tex62
1 files changed, 32 insertions, 30 deletions
diff --git a/Doc/lib/liblogging.tex b/Doc/lib/liblogging.tex
index 854b58e..a4660a5 100644
--- a/Doc/lib/liblogging.tex
+++ b/Doc/lib/liblogging.tex
@@ -527,27 +527,27 @@ the console messages should not. Here's how you can achieve this:
\begin{verbatim}
import logging
-#set up logging to file - see previous section for more details
+# set up logging to file - see previous section for more details
logging.basicConfig(level=logging.DEBUG,
format='%(asctime)s %(name)-12s %(levelname)-8s %(message)s',
datefmt='%m-%d %H:%M',
filename='/temp/myapp.log',
filemode='w')
-#define a Handler which writes INFO messages or higher to the sys.stderr
+# define a Handler which writes INFO messages or higher to the sys.stderr
console = logging.StreamHandler()
console.setLevel(logging.INFO)
-#set a format which is simpler for console use
+# set a format which is simpler for console use
formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
-#tell the handler to use this format
+# tell the handler to use this format
console.setFormatter(formatter)
-#add the handler to the root logger
+# add the handler to the root logger
logging.getLogger('').addHandler(console)
-#Now, we can log to the root logger, or any other logger. First the root...
+# Now, we can log to the root logger, or any other logger. First the root...
logging.info('Jackdaws love my big sphinx of quartz.')
-#Now, define a couple of other loggers which might represent areas in your
-#application:
+# Now, define a couple of other loggers which might represent areas in your
+# application:
logger1 = logging.getLogger('myapp.area1')
logger2 = logging.getLogger('myapp.area2')
@@ -601,11 +601,11 @@ socketHandler = logging.handlers.SocketHandler('localhost',
# an unformatted pickle
rootLogger.addHandler(socketHandler)
-#Now, we can log to the root logger, or any other logger. First the root...
+# Now, we can log to the root logger, or any other logger. First the root...
logging.info('Jackdaws love my big sphinx of quartz.')
-#Now, define a couple of other loggers which might represent areas in your
-#application:
+# Now, define a couple of other loggers which might represent areas in your
+# application:
logger1 = logging.getLogger('myapp.area1')
logger2 = logging.getLogger('myapp.area2')
@@ -620,14 +620,18 @@ At the receiving end, you can set up a receiver using the
\module{SocketServer} module. Here is a basic working example:
\begin{verbatim}
-import struct, cPickle, logging, logging.handlers
+import cPickle
+import logging
+import logging.handlers
+import SocketServer
+import struct
-from SocketServer import ThreadingTCPServer, StreamRequestHandler
-class LogRecordStreamHandler(StreamRequestHandler):
- """
- Handler for a streaming logging request. It basically logs the record
- using whatever logging policy is configured locally.
+class LogRecordStreamHandler(SocketServer.StreamRequestHandler):
+ """Handler for a streaming logging request.
+
+ This basically logs the record using whatever logging policy is
+ configured locally.
"""
def handle(self):
@@ -652,31 +656,29 @@ class LogRecordStreamHandler(StreamRequestHandler):
return cPickle.loads(data)
def handleLogRecord(self, record):
- #if a name is specified, we use the named logger rather than the one
- #implied by the record.
+ # if a name is specified, we use the named logger rather than the one
+ # implied by the record.
if self.server.logname is not None:
name = self.server.logname
else:
name = record.name
logger = logging.getLogger(name)
- #N.B. EVERY record gets logged. This is because Logger.handle
- #is normally called AFTER logger-level filtering. If you want
- #to do filtering, do it at the client end to save wasting
- #cycles and network bandwidth!
+ # N.B. EVERY record gets logged. This is because Logger.handle
+ # is normally called AFTER logger-level filtering. If you want
+ # to do filtering, do it at the client end to save wasting
+ # cycles and network bandwidth!
logger.handle(record)
-class LogRecordSocketReceiver(ThreadingTCPServer):
- """
- A simple-minded TCP socket-based logging receiver suitable for test
- purposes.
+class LogRecordSocketReceiver(SocketServer.ThreadingTCPServer):
+ """simple TCP socket-based logging receiver suitable for testing.
"""
allow_reuse_address = 1
def __init__(self, host='localhost',
- port=logging.handlers.DEFAULT_TCP_LOGGING_PORT,
- handler=LogRecordStreamHandler):
- ThreadingTCPServer.__init__(self, (host, port), handler)
+ port=logging.handlers.DEFAULT_TCP_LOGGING_PORT,
+ handler=LogRecordStreamHandler):
+ SocketServer.ThreadingTCPServer.__init__(self, (host, port), handler)
self.abort = 0
self.timeout = 1
self.logname = None