view roundup/cgi/MultiMapping.py @ 4587:a2eb4fb3e6d8

New Chameleon templating engine, engine is now configurable. We now have two configurable templating engines, the old Zope TAL templates (called zopetal in the config) and the new Chameleon (called chameleon in the config). A new config-option "template_engine" under [main] can take these config-options, the default is zopetal. Thanks to Cheer Xiao for the idea of making this configurable *and* for the actual implementation! Cheer Xiao commit log: - The original TAL engine ported from Zope is thereafter referred to as "zopetal", in speech and in code - A new option "template_engine" under [main] introduced - Zopetal-specific code stripped from cgi/templating.py to form the new cgi/engine_zopetal.py - Interface to Chameleon in cgi/engine_chameleon.py - Engines are supposed to provide a Templates class that mimics the behavior of the old cgi.templating.Templates. The Templates class is preferably subclassed from cgi.templating.TemplatesBase. - New function cgi.templating.get_templates to get the appropriate engine's Templates instance according to the engine name
author Ralf Schlatterbeck <rsc@runtux.com>
date Thu, 23 Feb 2012 18:10:03 +0100
parents 53c600091f17
children
line wrap: on
line source

class MultiMapping:
    def __init__(self, *stores):
        self.stores = list(stores)
        self.stores.reverse()

    def __getitem__(self, key):
        for store in self.stores:
            if store.has_key(key):
                return store[key]
        raise KeyError, key

    def __setitem__(self, key, val):
        self.stores[0][key] = val

    _marker = []

    def get(self, key, default=_marker):
        for store in self.stores:
            if store.has_key(key):
                return store[key]
        if default is self._marker:
            raise KeyError, key
        return default

    def __len__(self):
        return len(self.items())

    def has_key(self, key):
        for store in self.stores:
            if store.has_key(key):
                return 1
        return 0

    def push(self, store):
        self.stores = [store] + self.stores

    def pop(self):
        if not len(self.stores):
            return None
        store, self.stores = self.stores[0], self.stores[1:]
        return store

    def keys(self):
        return [ _[0] for _ in self.items() ]

    def values(self):
        return [ _[1] for _ in self.items() ]

    def copy(self):
       copy = MultiMapping()
       copy.stores = [_.copy() for _ in self.stores]
       return copy

    def items(self):
        l = []
        seen = {}
        for store in self.stores:
            for k, v in store.items():
                if not seen.has_key(k):
                    l.append((k, v))
                    seen[k] = 1
        return l


Roundup Issue Tracker: http://roundup-tracker.org/