annotate mercurial/demandload.py @ 809:d0fb9efa2b2d
Fix performance regression in addremove command.
When I rewrote addremove, I lazily put a call to repo.changes in,
which was unnecessary and slow. This is a new rewrite, preserving the
file name behaviour, but replacing the call to repo.changes with a walk,
which is much cheaper, and avoids calls to os.stat on all but files that
have probably been deleted.
author |
Bryan O'Sullivan <bos@serpentine.com> |
date |
Fri, 29 Jul 2005 08:42:28 -0800 |
parents |
3db700146536 |
children |
f3abe0bdccdd |
rev |
line source |
262
|
1 def demandload(scope, modules):
|
|
2 class d:
|
|
3 def __getattr__(self, name):
|
|
4 mod = self.__dict__["mod"]
|
|
5 scope = self.__dict__["scope"]
|
|
6 scope[mod] = __import__(mod, scope, scope, [])
|
|
7 return getattr(scope[mod], name)
|
|
8
|
|
9 for m in modules.split():
|
|
10 dl = d()
|
|
11 dl.mod = m
|
|
12 dl.scope = scope
|
|
13 scope[m] = dl
|
|
14
|
|
15
|