Это полностью выполнимо и требует пары небольших взломов ... ух ты!
Проблема, с которой я столкнулся, заключается в том, что get_repository считывает значение репозитория svn из файла trac.ini. Это указывало на E: /, а не на Y: /. Простое исправление включает проверку, чтобы определить, находится ли репозиторий на repository_dir , а если нет, то проверьте новую переменную remote_repository_dir . Вторая часть исправления включает удаление сообщения об ошибке из cache.py, который проверяет, совпадает ли текущий адрес хранилища с передаваемым.
Как всегда, используйте это на свой страх и риск и сделайте резервную копию всего заранее !!!
Сначала откройте файл trac.ini и добавьте новую переменную 'remote_repository_dir' под переменной 'repository_dir'. Удаленный репозиторий dir будет указывать на подключенный диск на вашем локальном компьютере. Теперь оно должно выглядеть примерно так:
repository_dir = E:/Projects/svn/InfoProj
remote_repository_dir = Y:/Projects/svn/InfoProj
Затем мы изменим файл api.py, чтобы проверить наличие новой переменной, если он не может найти хранилище в каталоге repository_dir . Вокруг: 71 у вас должно быть что-то вроде этого:
repository_dir = Option('trac', 'repository_dir', '',
"""Path to local repository. This can also be a relative path
(''since 0.11'').""")
Под этой строкой добавьте:
remote_repository_dir = Option('trac', 'remote_repository_dir', '',
"""Path to remote repository.""")
Следующая рядом: 156 у вас будет это:
rtype, rdir = self.repository_type, self.repository_dir
if not os.path.isabs(rdir):
rdir = os.path.join(self.env.path, rdir)
Измените это на:
rtype, rdir = self.repository_type, self.repository_dir
if not os.path.isdir(rdir):
rdir = self.remote_repository_dir
if not os.path.isabs(rdir):
rdir = os.path.join(self.env.path, rdir)
Наконец, вам нужно удалить предупреждение в файле cache.py (обратите внимание, что это не лучший способ сделать это, вы должны иметь возможность включить удаленную переменную как часть проверки, но пока она работает) .
В cache.py вблизи: 97 это должно выглядеть так:
if repository_dir:
# directory part of the repo name can vary on case insensitive fs
if os.path.normcase(repository_dir) != os.path.normcase(self.name):
self.log.info("'repository_dir' has changed from %r to %r"
% (repository_dir, self.name))
raise TracError(_("The 'repository_dir' has changed, a "
"'trac-admin resync' operation is needed."))
elif repository_dir is None: #
self.log.info('Storing initial "repository_dir": %s' % self.name)
cursor.execute("INSERT INTO system (name,value) VALUES (%s,%s)",
(CACHE_REPOSITORY_DIR, self.name,))
else: # 'repository_dir' cleared by a resync
self.log.info('Resetting "repository_dir": %s' % self.name)
cursor.execute("UPDATE system SET value=%s WHERE name=%s",
(self.name, CACHE_REPOSITORY_DIR))
Мы собираемся удалить первую часть оператора if, поэтому теперь она должна выглядеть следующим образом:
if repository_dir is None: #
self.log.info('Storing initial "repository_dir": %s' % self.name)
cursor.execute("INSERT INTO system (name,value) VALUES (%s,%s)",
(CACHE_REPOSITORY_DIR, self.name,))
else: # 'repository_dir' cleared by a resync
self.log.info('Resetting "repository_dir": %s' % self.name)
cursor.execute("UPDATE system SET value=%s WHERE name=%s",
(self.name, CACHE_REPOSITORY_DIR))
Внимание! Это будет означать, что больше не выдает ошибку, если ваш каталог изменился и вам требуется повторная синхронизация.
Надеюсь, это кому-нибудь поможет.