Spaces:
Runtime error
Runtime error
# Xlib.support.lock -- allocate a lock | |
# | |
# Copyright (C) 2000 Peter Liljenberg <petli@ctrl-c.liu.se> | |
# | |
# This library is free software; you can redistribute it and/or | |
# modify it under the terms of the GNU Lesser General Public License | |
# as published by the Free Software Foundation; either version 2.1 | |
# of the License, or (at your option) any later version. | |
# | |
# This library is distributed in the hope that it will be useful, | |
# but WITHOUT ANY WARRANTY; without even the implied warranty of | |
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. | |
# See the GNU Lesser General Public License for more details. | |
# | |
# You should have received a copy of the GNU Lesser General Public | |
# License along with this library; if not, write to the | |
# Free Software Foundation, Inc., | |
# 59 Temple Place, | |
# Suite 330, | |
# Boston, MA 02111-1307 USA | |
class _DummyLock(object): | |
def __init__(self): | |
# This might be nerdy, but by assigning methods like this | |
# instead of defining them all, we create a single bound | |
# method object once instead of one each time one of the | |
# methods is called. | |
# This gives some speed improvements which should reduce the | |
# impact of the threading infrastructure in the regular code, | |
# when not using threading. | |
self.acquire = self.release = self.locked = self.__noop | |
def __noop(self, *args): | |
return | |
# More optimisations: we use a single lock for all lock instances | |
_dummy_lock = _DummyLock() | |
def allocate_lock(): | |
return _dummy_lock | |