[Zope-Checkins] CVS: ZODB3/zLOG - EventLogger.py:1.7 component.xml:1.7 datatypes.py:1.9

Guido van Rossum guido@python.org
Thu, 23 Jan 2003 14:59:10 -0500


Update of /cvs-repository/ZODB3/zLOG
In directory cvs.zope.org:/tmp/cvs-serv4347/zLOG

Modified Files:
	EventLogger.py component.xml datatypes.py 
Log Message:
Several changes to the zLOG/logging/ZConfig connection:

(1) Change the mapping from zLOG levels to logging levels to use
    custom intermediary levels 15 and 5 for BLATHER and TRACE, rather
    than using a confusing skewed mapping.

(2) In the ZConfig datatype definition for a logging level, added
    'blather' and 'trace' to the level names, added 'warning' as an
    alias for 'warn', change 'all' to mean 1, and add 'notset' to mean
    0.  The semantics of NOTSET are very different than those of 1;
    setting a logger's level to NOTSET searches for a parent logger
    with a nonzero level.  The root of all loggers is initialized with
    WARN as its level, so setting the level to NOTSET effectively sets
    it to WARN rather than to the most inclusive level!

(3) In the schema, change the default level for handlers to notset, so
    they use their logger's level; the default level for the logger is
    set to info, corresponding to the old default for
    STUPID_LOG_SEVERITY.



=== ZODB3/zLOG/EventLogger.py 1.6 => 1.7 ===
--- ZODB3/zLOG/EventLogger.py:1.6	Mon Jan 13 10:17:30 2003
+++ ZODB3/zLOG/EventLogger.py	Thu Jan 23 14:58:36 2003
@@ -25,6 +25,12 @@
 from LogHandlers import FileHandler, NullHandler, SysLogHandler
 from logging import StreamHandler, Formatter
 
+# Custom logging levels
+CUSTOM_BLATHER = 15 # Mapping for zLOG.BLATHER
+CUSTOM_TRACE = 5 # Mapping for zLOG.TRACE
+logging.addLevelName("BLATHER", CUSTOM_BLATHER)
+logging.addLevelName("TRACE", CUSTOM_TRACE)
+
 class EventLogger(BaseLogger):
 
     # Get our logger object:
@@ -82,23 +88,30 @@
 
     zLOG severity                      PEP282 severity
     -------------                      ---------------
-    PANIC (300)                        critical (50)
-    ERROR (200), PROBLEM (100)         error (40)
-    INFO (0)                           warn (30)
-    BLATHER (-100)                     info (20)
-    DEBUG (-200), TRACE (-300)         debug (10)
+    PANIC (300)                        FATAL, CRITICAL (50)
+    ERROR (200)                        ERROR (40)
+    WARNING, PROBLEM (100)             WARN (30)
+    INFO (0)                           INFO (20)
+    BLATHER (-100)                     BLATHER (15) [*]
+    DEBUG (-200)                       DEBUG (10)
+    TRACE (-300)                       TRACE (5) [*]
+
+    [*] BLATHER and TRACE are custom logging levels.
     """
     sev = zlog_severity
     if sev >= 300:
-        return logging.CRITICAL
-    if sev >= 100:
+        return logging.FATAL
+    if sev >= 200:
         return logging.ERROR
-    if sev >= 0:
+    if sev >= 100:
         return logging.WARN
-    if sev >= -100:
+    if sev >= 0:
         return logging.INFO
-    else:
+    if sev >= -100:
+        return CUSTOM_BLATHER
+    if sev >= -200:
         return logging.DEBUG
+    return CUSTOM_TRACE
 
 zlog_to_pep282_severity_cache = {}
 for _sev in range(-300, 301, 100):
@@ -158,7 +171,8 @@
 def initialize_from_environment():
     """ Reinitialize the event logger from the environment """
     # clear the current handlers from the event logger
-    event_logger.logger.handlers = []
+    for h in event_logger.logger.handlers[:]:
+        event_logger.logger.removeHandler(h)
 
     handlers = []
 


=== ZODB3/zLOG/component.xml 1.6 => 1.7 ===
--- ZODB3/zLOG/component.xml:1.6	Thu Jan 23 13:03:05 2003
+++ ZODB3/zLOG/component.xml	Thu Jan 23 14:58:36 2003
@@ -9,7 +9,7 @@
       abstract section type.
     </description>
     <key name="dateformat" default="%Y-%m-%dT%H:%M:%S"/>
-    <key name="level" default="info" datatype=".logging_level"/>
+    <key name="level" default="notset" datatype=".logging_level"/>
   </sectiontype>
 
   <sectiontype name="logfile" datatype=".FileHandlerFactory"
@@ -54,7 +54,7 @@
 
 
   <sectiontype name="eventlog" datatype=".EventLogFactory">
-     <key name="level" datatype=".logging_level" default="all"/>
+     <key name="level" datatype=".logging_level" default="info"/>
      <multisection type="loghandler" attribute="handlers" name="*"/>
   </sectiontype>
 


=== ZODB3/zLOG/datatypes.py 1.8 => 1.9 ===
--- ZODB3/zLOG/datatypes.py:1.8	Thu Jan 23 13:03:05 2003
+++ ZODB3/zLOG/datatypes.py	Thu Jan 23 14:58:36 2003
@@ -25,9 +25,13 @@
     "fatal": 50,
     "error": 40,
     "warn": 30,
+    "warning": 30,
     "info": 20,
+    "blather": 15,
     "debug": 10,
-    "all": 0,
+    "trace": 5,
+    "all": 1,
+    "notset": 0,
     }
 
 def logging_level(value):