##// END OF EJS Templates
fixes #555 issues when comparing non-related repositories on pull requests or compare view
fixes #555 issues when comparing non-related repositories on pull requests or compare view

File last commit:

r1203:6832ef66 beta
r2810:4a5c56da beta
Show More
keyedinstance.py
36 lines | 1.1 KiB | text/x-python | PythonLexer
added dbmigrate package, added model changes...
r833 #!/usr/bin/env python
# -*- coding: utf-8 -*-
class KeyedInstance(object):
"""A class whose instances have a unique identifier of some sort
No two instances with the same unique ID should exist - if we try to create
source code cleanup: remove trailing white space, normalize file endings
r1203 a second instance, the first should be returned.
added dbmigrate package, added model changes...
r833 """
_instances = dict()
def __new__(cls, *p, **k):
instances = cls._instances
clskey = str(cls)
if clskey not in instances:
instances[clskey] = dict()
instances = instances[clskey]
key = cls._key(*p, **k)
if key not in instances:
instances[key] = super(KeyedInstance, cls).__new__(cls)
return instances[key]
@classmethod
def _key(cls, *p, **k):
"""Given a unique identifier, return a dictionary key
source code cleanup: remove trailing white space, normalize file endings
r1203 This should be overridden by child classes, to specify which parameters
added dbmigrate package, added model changes...
r833 should determine an object's uniqueness
"""
raise NotImplementedError()
@classmethod
def clear(cls):
# Allow cls.clear() as well as uniqueInstance.clear(cls)
if str(cls) in cls._instances:
del cls._instances[str(cls)]