Change relative imports to absolute
authordavid-sarah <david-sarah@jacaranda.org>
Fri, 26 Feb 2010 08:14:33 +0000 (01:14 -0700)
committerdavid-sarah <david-sarah@jacaranda.org>
Fri, 26 Feb 2010 08:14:33 +0000 (01:14 -0700)
39 files changed:
src/allmydata/__init__.py
src/allmydata/frontends/ftpd.py
src/allmydata/frontends/sftpd.py
src/allmydata/gui/confwiz.py
src/allmydata/gui/macapp.py
src/allmydata/introducer/__init__.py
src/allmydata/mutable/checker.py
src/allmydata/mutable/filenode.py
src/allmydata/mutable/layout.py
src/allmydata/mutable/publish.py
src/allmydata/mutable/retrieve.py
src/allmydata/mutable/servermap.py
src/allmydata/scripts/debug.py
src/allmydata/scripts/runner.py
src/allmydata/storage/expirer.py
src/allmydata/storage/shares.py
src/allmydata/test/common.py
src/allmydata/test/test_checker.py
src/allmydata/test/test_client.py
src/allmydata/test/test_crawler.py
src/allmydata/test/test_dirnode.py
src/allmydata/test/test_encode.py
src/allmydata/test/test_introducer.py
src/allmydata/test/test_iputil.py
src/allmydata/test/test_mutable.py
src/allmydata/test/test_node.py
src/allmydata/test/test_repairer.py
src/allmydata/test/test_stats.py
src/allmydata/test/test_upload.py
src/allmydata/test/test_web.py
src/allmydata/util/assertutil.py
src/allmydata/util/base32.py
src/allmydata/util/dictutil.py
src/allmydata/util/iputil.py
src/allmydata/util/log.py
src/allmydata/util/nummedobj.py
src/allmydata/util/repeatable_random.py
src/allmydata/util/statistics.py
src/allmydata/web/introweb.py

index 8bc32cc9afa069a93b5832689f9c4770b826d390..e098e0ebdfe5b5071a1751d6e0af51a5ae8245c7 100644 (file)
@@ -39,7 +39,7 @@ finally:
 
 __version__ = "unknown"
 try:
-    from _version import __version__
+    from allmydata._version import __version__
 except ImportError:
     # We're running in a tree that hasn't run "./setup.py darcsver", and didn't
     # come with a _version.py, so we don't know what our version is. This should
@@ -48,7 +48,7 @@ except ImportError:
 
 __appname__ = "unknown"
 try:
-    from _appname import __appname__
+    from allmydata._appname import __appname__
 except ImportError:
     # We're running in a tree that hasn't run "./setup.py".  This shouldn't happen.
     pass
@@ -58,7 +58,7 @@ except ImportError:
 # http://allmydata.org/trac/tahoe/wiki/Versioning
 __full_version__ = __appname__ + '/' + str(__version__)
 
-import _auto_deps
+from allmydata import _auto_deps
 _auto_deps.require_auto_deps()
 
 import os, platform, re, subprocess, sys
index 3caf385e52896cbf11ccd2d4266e85ad48012542..8e66e43738dff7f3244aec7ebc1aa103f89fd782 100644 (file)
@@ -265,7 +265,7 @@ class Handler:
         d.addCallback(_got_parent)
         return d
 
-from auth import AccountURLChecker, AccountFileChecker, NeedRootcapLookupScheme
+from allmydata.frontends.auth import AccountURLChecker, AccountFileChecker, NeedRootcapLookupScheme
 
 
 class Dispatcher:
index 4a866eec07a162aba9f6a7452f4b6be9866ae691..fa52df528ea85f00c3e05d1083d0790f1e4366c2 100644 (file)
@@ -402,7 +402,7 @@ class SFTPHandler:
 # then you get SFTPHandler(user)
 components.registerAdapter(SFTPHandler, SFTPUser, ISFTPServer)
 
-from auth import AccountURLChecker, AccountFileChecker, NeedRootcapLookupScheme
+from allmydata.frontends.auth import AccountURLChecker, AccountFileChecker, NeedRootcapLookupScheme
 
 class Dispatcher:
     implements(portal.IRealm)
index 3f47fb058cca9a9b5e2522f6da4a5dbd2767e17e..48af9b34271d553541549116933795e091261e40 100644 (file)
@@ -24,9 +24,7 @@ from allmydata.util.assertutil import precondition
 from allmydata.util import hashutil, base32
 from allmydata import uri
 import allmydata
-
-#import amdicon
-import amdlogo
+from allmydata.gui import amdlogo
 
 from foolscap.api import Tub
 from twisted.python import usage
index 96061129c38155e1e21bfb9a2884253b4a1b20a3..d8fa2342740adb9d235cd083ba611d90bb32a0f1 100644 (file)
@@ -18,8 +18,7 @@ import allmydata
 from allmydata import client
 from allmydata.gui.confwiz import ConfWizApp, ACCOUNT_PAGE, DEFAULT_SERVER_URL
 from allmydata.scripts.common import get_aliases
-import amdicon
-import amdlogo
+from allmydata.gui import amdicon, amdlogo
 
 DEFAULT_FUSE_TIMEOUT = 300
 
index a9cab7e6f72c599d8fc1b2adfa9cce0aecc78eea..6a877edddf108010590b7201d49e82fdba6252e5 100644 (file)
@@ -2,7 +2,7 @@
 # This is for compatibilty with old .tac files, which reference
 # allmydata.introducer.IntroducerNode
 
-from server import IntroducerNode
+from allmydata.introducer.server import IntroducerNode
 
 # hush pyflakes
 _unused = [IntroducerNode]
index 92ed05d8c440023d3dcf3eeab52e9834718ac647..e5d3c3012fa268147f33830d210309f97c56d548 100644 (file)
@@ -6,9 +6,9 @@ from allmydata.uri import from_string
 from allmydata.util import hashutil, base32, idlib, log
 from allmydata.check_results import CheckAndRepairResults, CheckResults
 
-from common import MODE_CHECK, CorruptShareError
-from servermap import ServerMap, ServermapUpdater
-from layout import unpack_share, SIGNED_PREFIX_LENGTH
+from allmydata.mutable.common import MODE_CHECK, CorruptShareError
+from allmydata.mutable.servermap import ServerMap, ServermapUpdater
+from allmydata.mutable.layout import unpack_share, SIGNED_PREFIX_LENGTH
 
 class MutableChecker:
 
index be5ca5c211c1a89cb70402ae918e8eb1de6f5d55..d9cd9274806df3ee249c7b1d6655deff93ffdd0d 100644 (file)
@@ -12,13 +12,13 @@ from allmydata.uri import WriteableSSKFileURI, ReadonlySSKFileURI
 from allmydata.monitor import Monitor
 from pycryptopp.cipher.aes import AES
 
-from publish import Publish
-from common import MODE_READ, MODE_WRITE, UnrecoverableFileError, \
+from allmydata.mutable.publish import Publish
+from allmydata.mutable.common import MODE_READ, MODE_WRITE, UnrecoverableFileError, \
      ResponseCache, UncoordinatedWriteError
-from servermap import ServerMap, ServermapUpdater
-from retrieve import Retrieve
-from checker import MutableChecker, MutableCheckAndRepairer
-from repairer import Repairer
+from allmydata.mutable.servermap import ServerMap, ServermapUpdater
+from allmydata.mutable.retrieve import Retrieve
+from allmydata.mutable.checker import MutableChecker, MutableCheckAndRepairer
+from allmydata.mutable.repairer import Repairer
 
 
 class BackoffAgent:
index 40c7174a9ad0a0ef3364ef807638c775678efe0e..9565843f60ec013c304e06bf6fa3a0e238eef747 100644 (file)
@@ -1,6 +1,6 @@
 
 import struct
-from common import NeedMoreDataError, UnknownVersionError
+from allmydata.mutable.common import NeedMoreDataError, UnknownVersionError
 
 PREFIX = ">BQ32s16s" # each version has a different prefix
 SIGNED_PREFIX = ">BQ32s16s BBQQ" # this is covered by the signature
index 7ff4350dae05e2aa0f91f56660a991daf7943e17..1b7e050a016a7ab4d12b9ee17e4302de723c1e46 100644 (file)
@@ -12,10 +12,10 @@ from allmydata.storage.server import si_b2a
 from pycryptopp.cipher.aes import AES
 from foolscap.api import eventually, fireEventually
 
-from common import MODE_WRITE, MODE_CHECK, DictOfSets, \
+from allmydata.mutable.common import MODE_WRITE, MODE_CHECK, DictOfSets, \
      UncoordinatedWriteError, NotEnoughServersError
-from servermap import ServerMap
-from layout import pack_prefix, pack_share, unpack_header, pack_checkstring, \
+from allmydata.mutable.servermap import ServerMap
+from allmydata.mutable.layout import pack_prefix, pack_share, unpack_header, pack_checkstring, \
      unpack_checkstring, SIGNED_PREFIX
 
 class PublishStatus:
index 9165ebd1a9ee5d2d9431bad2c517135eca84d1cd..b4fa1c22bcf54d113a34ca7c5b2ed07507b6b653 100644 (file)
@@ -12,8 +12,8 @@ from allmydata.storage.server import si_b2a
 from pycryptopp.cipher.aes import AES
 from pycryptopp.publickey import rsa
 
-from common import DictOfSets, CorruptShareError, UncoordinatedWriteError
-from layout import SIGNED_PREFIX, unpack_share_data
+from allmydata.mutable.common import DictOfSets, CorruptShareError, UncoordinatedWriteError
+from allmydata.mutable.layout import SIGNED_PREFIX, unpack_share_data
 
 class RetrieveStatus:
     implements(IRetrieveStatus)
index f47deaef3838e5f5b361dbdf183e15a14ab7dff7..3dfb36f229504ea0a14bf6296a048346cf84d181 100644 (file)
@@ -10,9 +10,9 @@ from allmydata.storage.server import si_b2a
 from allmydata.interfaces import IServermapUpdaterStatus
 from pycryptopp.publickey import rsa
 
-from common import MODE_CHECK, MODE_ANYTHING, MODE_WRITE, MODE_READ, \
+from allmydata.mutable.common import MODE_CHECK, MODE_ANYTHING, MODE_WRITE, MODE_READ, \
      DictOfSets, CorruptShareError, NeedMoreDataError
-from layout import unpack_prefix_and_signature, unpack_header, unpack_share, \
+from allmydata.mutable.layout import unpack_prefix_and_signature, unpack_header, unpack_share, \
      SIGNED_PREFIX_LENGTH
 
 class UpdateStatus:
index 6be2cd3d9e342baa63a4e4da7671001e2562fb40..d18d3cb13de460051746e672809f07745c2fac13 100644 (file)
@@ -771,7 +771,8 @@ class ConsolidateOptions(VDriveOptions):
         self.where = where
 
 def consolidate(options):
-    from consolidate import main; return main(options)
+    from allmydata.scripts.consolidate import main
+    return main(options)
 
 
 class DebugCommand(usage.Options):
index ee8415d5914ba2fac5ec60672f6114e8513b5b32..9db7d05ef7fc2b1bb8f87a125680c2003eff1853 100644 (file)
@@ -8,7 +8,7 @@ from twisted.python import usage
 
 pkg_resources.require('allmydata-tahoe')
 from allmydata.scripts.common import BaseOptions
-import debug, create_node, startstop_node, cli, keygen, stats_gatherer
+from allmydata.scripts import debug, create_node, startstop_node, cli, keygen, stats_gatherer
 
 def GROUP(s):
     # Usage.parseOptions compares argv[1] against command[0], so it will
index bb94e11b019c391adb99c4e80226d15218b7f135..41823e7e4285f163b6e6119157e0fc8992e19f3c 100644 (file)
@@ -1,7 +1,7 @@
 import time, os, pickle, struct
-from crawler import ShareCrawler
-from shares import get_share_file
-from common import UnknownMutableContainerVersionError, \
+from allmydata.storage.crawler import ShareCrawler
+from allmydata.storage.shares import get_share_file
+from allmydata.storage.common import UnknownMutableContainerVersionError, \
      UnknownImmutableContainerVersionError
 from twisted.python import log as twlog
 
index c433cfbb61946a001d9dcabe011e54595daee256..558bddc197714d8fc53a30a00a86e80bae04375c 100644 (file)
@@ -1,7 +1,7 @@
 #! /usr/bin/python
 
-from mutable import MutableShareFile
-from immutable import ShareFile
+from allmydata.storage.mutable import MutableShareFile
+from allmydata.storage.immutable import ShareFile
 
 def get_share_file(filename):
     f = open(filename, "rb")
index 054c0fd15af270b78273e4758b572e09b4733796..b3784cb3552442a7fe6b56dd6cee4b4432f1a5f3 100644 (file)
@@ -21,7 +21,7 @@ from allmydata.util.assertutil import precondition
 from allmydata.util.consumer import download_to_data
 from allmydata.stats import StatsGathererService
 from allmydata.key_generator import KeyGeneratorService
-import common_util as testutil
+import allmydata.test.common_util as testutil
 from allmydata import immutable
 
 
index 67e745dd4c8c433075a3f976190165959b9919ea..7548d7cc8142f43d797498591d106e4e6e80c4db 100644 (file)
@@ -7,7 +7,7 @@ from allmydata.storage_client import StorageFarmBroker, NativeStorageClientDescr
 from allmydata.monitor import Monitor
 from allmydata.test.no_network import GridTestMixin
 from allmydata.immutable.upload import Data
-from common_web import WebRenderingMixin
+from allmydata.test.common_web import WebRenderingMixin
 
 class FakeClient:
     def get_storage_broker(self):
index 61f1e53fe6473d181ae976bcf8bfcbb73c17b432..c7ff84c506f6374bc6c4151aed55e63953c7266b 100644 (file)
@@ -12,7 +12,7 @@ from allmydata.util import base32, fileutil
 from allmydata.interfaces import IFilesystemNode, IFileNode, \
      IImmutableFileNode, IMutableFileNode, IDirectoryNode
 from foolscap.api import flushEventualQueue
-import common_util as testutil
+import allmydata.test.common_util as testutil
 
 class FakeIntroducerClient(IntroducerClient):
     def __init__(self):
index 1c57e134a0be8b3b7cbe85f3121393f3f6c50e4e..c4aa9914247d9408932e04702836baf7e63bfd96 100644 (file)
@@ -10,8 +10,8 @@ from allmydata.util import fileutil, hashutil, pollmixin
 from allmydata.storage.server import StorageServer, si_b2a
 from allmydata.storage.crawler import ShareCrawler, TimeSliceExceeded
 
-from test_storage import FakeCanary
-from common_util import StallMixin
+from allmydata.test.test_storage import FakeCanary
+from allmydata.test.common_util import StallMixin
 
 class BucketEnumeratingCrawler(ShareCrawler):
     cpu_slice = 500 # make sure it can complete in a single slice
index e6aaf7750bad0675c9844629b483d235a97f4467..5cbc0ac92904c0bf9228107a9a90e7e53a10dbf0 100644 (file)
@@ -22,7 +22,7 @@ from allmydata.test.no_network import GridTestMixin
 from allmydata.unknown import UnknownNode, strip_prefix_for_ro
 from allmydata.nodemaker import NodeMaker
 from base64 import b32decode
-import common_util as testutil
+import allmydata.test.common_util as testutil
 
 class MemAccum:
     implements(IConsumer)
index 36a854ea9008651736b2ab2be9f5d501335debc1..1108e187615fc2752ea71c42d956a6785f8226d6 100644 (file)
@@ -11,7 +11,7 @@ from allmydata.util.consumer import MemoryConsumer
 from allmydata.interfaces import IStorageBucketWriter, IStorageBucketReader, \
      NotEnoughSharesError, IStorageBroker, UploadUnhappinessError
 from allmydata.monitor import Monitor
-import common_util as testutil
+import allmydata.test.common_util as testutil
 
 class LostPeerError(Exception):
     pass
index 8da06d3a238ebdf601067e91fd789bbf0eb6ee6c..9d0f50eb92fa8b3b3184cdf46457433473356697 100644 (file)
@@ -14,7 +14,7 @@ from allmydata.introducer.server import IntroducerService
 # test compatibility with old introducer .tac files
 from allmydata.introducer import IntroducerNode
 from allmydata.util import pollmixin
-import common_util as testutil
+import allmydata.test.common_util as testutil
 
 class LoggingMultiService(service.MultiService):
     def log(self, msg, **kw):
index 21550893044c67f4357037d89f32d2c2fc6b34b3..88da7baae35378f0a352c160348a62cf0e36709d 100644 (file)
@@ -2,7 +2,7 @@
 import re
 from twisted.trial import unittest
 from allmydata.util import iputil
-import common_util as testutil
+import allmydata.test.common_util as testutil
 
 DOTTED_QUAD_RE=re.compile("^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$")
 
index fa29d34299c5c8feee1c19287662d9027e50e725..30d10834bf68329a96444ef4bb2a0829e04ea506 100644 (file)
@@ -28,7 +28,7 @@ from allmydata.mutable.servermap import ServerMap, ServermapUpdater
 from allmydata.mutable.layout import unpack_header, unpack_share
 from allmydata.mutable.repairer import MustForceRepairError
 
-import common_util as testutil
+import allmydata.test.common_util as testutil
 
 # this "FakeStorage" exists to put the share data in RAM and avoid using real
 # network connections, both to speed up the tests and to reduce the amount of
index 3fa72a0baa0344d7935da44bf97842001d1af92b..24ec5714799d354c833cf03099231a55ab8dc88a 100644 (file)
@@ -8,7 +8,7 @@ from foolscap.api import flushEventualQueue
 from twisted.application import service
 from allmydata.node import Node, formatTimeTahoeStyle
 from allmydata.util import fileutil
-import common_util as testutil
+import allmydata.test.common_util as testutil
 
 class LoggingMultiService(service.MultiService):
     def log(self, msg, **kw):
index 91ab704d2bda3db1ab7efc1db49d30fcd00aa6af..a4ccf2c376bc4b70601fdb59765b2fba35deb995 100644 (file)
@@ -8,7 +8,7 @@ from allmydata.util.consumer import download_to_data
 from twisted.internet import defer
 from twisted.trial import unittest
 import random
-from no_network import GridTestMixin
+from allmydata.test.no_network import GridTestMixin
 
 # We'll allow you to pass this test even if you trigger eighteen times as
 # many disk reads and block fetches as would be optimal.
index c2ff496b57438dd0d4d5f6a334b3e968f57ebb30..3ee49592723b9cbfb1845aba4f112d6ddc806c4d 100644 (file)
@@ -3,7 +3,7 @@ from twisted.trial import unittest
 from twisted.application import service
 from allmydata.stats import CPUUsageMonitor
 from allmydata.util import pollmixin
-import common_util as testutil
+import allmydata.test.common_util as testutil
 
 class FasterMonitor(CPUUsageMonitor):
     POLL_INTERVAL = 0.1
index 7366e8d8f24032e21869018db0a726bcd350e46b..6f4ff374c38de323e4c997457376db37c5b8ea48 100644 (file)
@@ -13,8 +13,6 @@ from allmydata.immutable import upload, encode
 from allmydata.interfaces import FileTooLargeError, UploadUnhappinessError
 from allmydata.util.assertutil import precondition
 from allmydata.util.deferredutil import DeferredListShouldSucceed
-from allmydata.util.happinessutil import servers_of_happiness, \
-                                         shares_by_server, merge_peers
 from no_network import GridTestMixin
 from common_util import ShouldFailMixin
 from allmydata.storage_client import StorageFarmBroker
index 0df0bbed3105677bf24622cf37727e60620bffbe..8fabca343ff8752c242ec98d42f1ffd7fce2c46c 100644 (file)
@@ -24,7 +24,7 @@ from allmydata.test.common import FakeCHKFileNode, FakeMutableFileNode, \
      create_chk_filenode, WebErrorMixin, ShouldFailMixin, make_mutable_file_uri
 from allmydata.interfaces import IMutableFileNode
 from allmydata.mutable import servermap, publish, retrieve
-import common_util as testutil
+import allmydata.test.common_util as testutil
 from allmydata.test.no_network import GridTestMixin
 from allmydata.test.common_web import HTTPClientGETFactory, \
      HTTPClientHEADFactory
index f3dfb85bb066c63e456e9465195baec097caabb1..735f534cdf8f16132a04fb4e1eabd517b5fcd571 100644 (file)
@@ -2,7 +2,7 @@
 Tests useful in assertion checking, prints out nicely formated messages too.
 """
 
-from humanreadable import hr
+from allmydata.util.humanreadable import hr
 
 def _assert(___cond=False, *___args, **___kwargs):
     if ___cond:
index 00424af52f548c803c94234327321c90215df46d..fb8cb63524542011d4755fe454aec0df566c1fb2 100644 (file)
@@ -1,7 +1,7 @@
 # from the Python Standard Library
 import string
 
-from assertutil import precondition
+from allmydata.util.assertutil import precondition
 
 z_base_32_alphabet = "ybndrfg8ejkmcpqxot1uwisza345h769" # Zooko's choice, rationale in "DESIGN" doc
 rfc3548_alphabet = "abcdefghijklmnopqrstuvwxyz234567" # RFC3548 standard used by Gnutella, Content-Addressable Web, THEX, Bitzi, Web-Calculus...
index 3dc815b3ef1505c0a2fe014baa270924502fb1f4..8de136f28ebdf1ff029b666f4b64f5fcf65512e0 100644 (file)
@@ -5,7 +5,7 @@ Tools to mess with dicts.
 import copy, operator
 from bisect import bisect_left, insort_left
 
-from assertutil import _assert, precondition
+from allmydata.util.assertutil import _assert, precondition
 
 def move(k, d1, d2, strict=False):
     """
index f4b3e3a4211f4963ae04bdfdd5af237cece11ded..e24066c364b03c4df3bf9f7d16ca644d489a8384 100644 (file)
@@ -9,8 +9,7 @@ from twisted.internet.utils import getProcessOutput
 from twisted.python.procutils import which
 from twisted.python import log
 
-# from allmydata.util
-import observer
+from allmydata.util import observer
 
 try:
     import resource
index e1487debb47f6ef3287dcb5e01f641d8360bd600..199318c3c0f35c43aa7e116e752507fb2befc1cf 100644 (file)
@@ -1,4 +1,4 @@
-import nummedobj
+from allmydata.util import nummedobj
 
 from foolscap.logging import log
 from twisted.python import log as tw_log
index 97d37066c3e216f4e6aeb35c58ef031181f220e9..de3c57d0eae645874f85d958a97e71d91e11e788 100644 (file)
@@ -1,4 +1,4 @@
-import dictutil
+from allmydata.util import dictutil
 
 class NummedObj(object):
     """
index 0fa78e3d7cd7779a23a91f1e4fd2b2895f0ee9ae..a64445efccaf9c23e01b32e73727a13790f1cf00 100644 (file)
@@ -35,7 +35,7 @@ def force_repeatability():
     time.faketime = faketime
     time.time = faketime
 
-    from idlib import i2b
+    from allmydata.util.idlib import i2b
     def fakeurandom(n):
         if n > 20:
             z = i2b(random.getrandbits(20*8))
index 71547031d37b3b26e021db632f23bbb73a8629a4..b1e56ef748e4d12ae949f5d253afdaa2b7b6e651 100644 (file)
@@ -6,7 +6,7 @@
 # Transitive Grace Period Public License, version 1 or later.
 
 from __future__ import division
-from mathutil import round_sigfigs
+from allmydata.util.mathutil import round_sigfigs
 import math
 import sys
 
index c405cfd04ad93d64641157807dfab43374499cde..28273bd7eb343b3e1dca730c71284297e17bb26b 100644 (file)
@@ -7,7 +7,7 @@ import allmydata
 import simplejson
 from allmydata import get_package_versions_string
 from allmydata.util import idlib
-from common import getxmlfile, get_arg
+from allmydata.web.common import getxmlfile, get_arg
 
 class IntroducerRoot(rend.Page):