diff piecrust/data/debug.py @ 440:32c7c2d219d2

performance: Refactor how data is managed to reduce copying. * Make use of `collections.abc.Mapping` to better identify things that are supposed to look like dictionaries. * Instead of handling "overlay" of data in a dict tree in each different data object, make all objects `Mapping`s and handle merging at a higher level with the new `MergedMapping` object. * Since this new object is read-only, remove the need for deep-copying of app and page configurations. * Split data classes into separate modules.
author Ludovic Chabant <ludovic@chabant.com>
date Sun, 28 Jun 2015 08:22:39 -0700
parents bd56d9acd6ef
children 93b656f0af54
line wrap: on
line diff
--- a/piecrust/data/debug.py	Sat Jun 27 22:28:32 2015 -0700
+++ b/piecrust/data/debug.py	Sun Jun 28 08:22:39 2015 -0700
@@ -3,6 +3,7 @@
 import html
 import logging
 import collections
+import collections.abc
 from piecrust import APP_VERSION, PIECRUST_URL
 from piecrust.page import FLAG_RAW_CACHE_VALID
 
@@ -162,7 +163,7 @@
             self._write('&lt;null&gt;')
             return
 
-        if isinstance(data, dict):
+        if isinstance(data, (dict, collections.abc.Mapping)):
             self._renderCollapsableValueStart(path)
             with IndentScope(self):
                 self._renderDict(data, path)