Browse Source

Switch to relative imports with abs2rel

Jelmer Vernooij 1 year ago
parent
commit
03df9d0737
73 changed files with 491 additions and 483 deletions
  1. 9 7
      dulwich/cli.py
  2. 23 25
      dulwich/client.py
  3. 2 2
      dulwich/config.py
  4. 1 1
      dulwich/contrib/release_robot.py
  5. 3 3
      dulwich/contrib/requests_vendor.py
  6. 12 13
      dulwich/contrib/swift.py
  7. 1 1
      dulwich/contrib/test_paramiko_vendor.py
  8. 3 2
      dulwich/contrib/test_release_robot.py
  9. 3 2
      dulwich/contrib/test_swift.py
  10. 1 1
      dulwich/credentials.py
  11. 1 1
      dulwich/diff_tree.py
  12. 3 3
      dulwich/fastexport.py
  13. 3 3
      dulwich/greenthreads.py
  14. 1 1
      dulwich/hooks.py
  15. 3 3
      dulwich/ignore.py
  16. 7 7
      dulwich/index.py
  17. 3 3
      dulwich/line_ending.py
  18. 14 17
      dulwich/object_store.py
  19. 7 16
      dulwich/objects.py
  20. 4 4
      dulwich/objectspec.py
  21. 6 7
      dulwich/pack.py
  22. 2 2
      dulwich/patch.py
  23. 33 33
      dulwich/porcelain.py
  24. 2 1
      dulwich/protocol.py
  25. 1 1
      dulwich/reflog.py
  26. 6 6
      dulwich/refs.py
  27. 37 39
      dulwich/repo.py
  28. 28 29
      dulwich/server.py
  29. 3 3
      dulwich/stash.py
  30. 6 6
      dulwich/tests/compat/server_utils.py
  31. 4 4
      dulwich/tests/compat/test_client.py
  32. 5 4
      dulwich/tests/compat/test_pack.py
  33. 3 2
      dulwich/tests/compat/test_patch.py
  34. 4 3
      dulwich/tests/compat/test_porcelain.py
  35. 4 4
      dulwich/tests/compat/test_repository.py
  36. 4 4
      dulwich/tests/compat/test_server.py
  37. 6 6
      dulwich/tests/compat/test_web.py
  38. 3 2
      dulwich/tests/compat/utils.py
  39. 5 4
      dulwich/tests/test_archive.py
  40. 2 1
      dulwich/tests/test_blackbox.py
  41. 3 2
      dulwich/tests/test_bundle.py
  42. 16 17
      dulwich/tests/test_client.py
  43. 7 6
      dulwich/tests/test_config.py
  44. 4 3
      dulwich/tests/test_credentials.py
  45. 11 11
      dulwich/tests/test_diff_tree.py
  46. 7 6
      dulwich/tests/test_fastexport.py
  47. 2 1
      dulwich/tests/test_file.py
  48. 4 4
      dulwich/tests/test_grafts.py
  49. 4 3
      dulwich/tests/test_graph.py
  50. 4 3
      dulwich/tests/test_greenthreads.py
  51. 2 2
      dulwich/tests/test_hooks.py
  52. 4 4
      dulwich/tests/test_ignore.py
  53. 10 10
      dulwich/tests/test_index.py
  54. 5 4
      dulwich/tests/test_line_ending.py
  55. 1 1
      dulwich/tests/test_mailmap.py
  56. 4 3
      dulwich/tests/test_missing_obj_finder.py
  57. 12 11
      dulwich/tests/test_object_store.py
  58. 9 10
      dulwich/tests/test_objects.py
  59. 7 6
      dulwich/tests/test_objectspec.py
  60. 13 13
      dulwich/tests/test_pack.py
  61. 5 5
      dulwich/tests/test_patch.py
  62. 9 8
      dulwich/tests/test_porcelain.py
  63. 6 6
      dulwich/tests/test_protocol.py
  64. 4 3
      dulwich/tests/test_reflog.py
  65. 9 9
      dulwich/tests/test_refs.py
  66. 8 8
      dulwich/tests/test_repository.py
  67. 14 14
      dulwich/tests/test_server.py
  68. 4 3
      dulwich/tests/test_utils.py
  69. 8 7
      dulwich/tests/test_walk.py
  70. 11 10
      dulwich/tests/test_web.py
  71. 7 6
      dulwich/tests/utils.py
  72. 4 4
      dulwich/walk.py
  73. 5 4
      dulwich/web.py

+ 9 - 7
dulwich/cli.py

@@ -37,12 +37,13 @@ from getopt import getopt
 from typing import Dict, Optional, Type
 from typing import Dict, Optional, Type
 
 
 from dulwich import porcelain
 from dulwich import porcelain
-from dulwich.client import GitProtocolError, get_transport_and_path
-from dulwich.errors import ApplyDeltaError
-from dulwich.index import Index
-from dulwich.objectspec import parse_commit
-from dulwich.pack import Pack, sha_to_hex
-from dulwich.repo import Repo
+
+from .client import GitProtocolError, get_transport_and_path
+from .errors import ApplyDeltaError
+from .index import Index
+from .objectspec import parse_commit
+from .pack import Pack, sha_to_hex
+from .repo import Repo
 
 
 
 
 def signal_int(signal, frame):
 def signal_int(signal, frame):
@@ -383,7 +384,8 @@ class cmd_reset(Command):
 class cmd_daemon(Command):
 class cmd_daemon(Command):
     def run(self, args):
     def run(self, args):
         from dulwich import log_utils
         from dulwich import log_utils
-        from dulwich.protocol import TCP_GIT_PORT
+
+        from .protocol import TCP_GIT_PORT
 
 
         parser = optparse.OptionParser()
         parser = optparse.OptionParser()
         parser.add_option(
         parser.add_option(

+ 23 - 25
dulwich/client.py

@@ -56,30 +56,28 @@ if TYPE_CHECKING:
     import urllib3
     import urllib3
 
 
 import dulwich
 import dulwich
-from dulwich.config import Config, apply_instead_of, get_xdg_config_home_path
-from dulwich.errors import GitProtocolError, NotGitRepository, SendPackError
-from dulwich.pack import (PACK_SPOOL_FILE_MAX_SIZE, PackChunkGenerator,
-                          UnpackedObject, write_pack_from_container)
-from dulwich.protocol import (_RBUFSIZE, CAPABILITIES_REF, CAPABILITY_AGENT,
-                              CAPABILITY_DELETE_REFS, CAPABILITY_INCLUDE_TAG,
-                              CAPABILITY_MULTI_ACK,
-                              CAPABILITY_MULTI_ACK_DETAILED,
-                              CAPABILITY_OFS_DELTA, CAPABILITY_QUIET,
-                              CAPABILITY_REPORT_STATUS, CAPABILITY_SHALLOW,
-                              CAPABILITY_SIDE_BAND_64K, CAPABILITY_SYMREF,
-                              CAPABILITY_THIN_PACK, COMMAND_DEEPEN,
-                              COMMAND_DONE, COMMAND_HAVE, COMMAND_SHALLOW,
-                              COMMAND_UNSHALLOW, COMMAND_WANT,
-                              KNOWN_RECEIVE_CAPABILITIES,
-                              KNOWN_UPLOAD_CAPABILITIES,
-                              SIDE_BAND_CHANNEL_DATA, SIDE_BAND_CHANNEL_FATAL,
-                              SIDE_BAND_CHANNEL_PROGRESS, TCP_GIT_PORT,
-                              ZERO_SHA, HangupException, PktLineParser,
-                              Protocol, agent_string, capability_agent,
-                              extract_capabilities, extract_capability_names,
-                              parse_capability, pkt_line)
-from dulwich.refs import PEELED_TAG_SUFFIX, _import_remote_refs, read_info_refs
-from dulwich.repo import Repo
+
+from .config import Config, apply_instead_of, get_xdg_config_home_path
+from .errors import GitProtocolError, NotGitRepository, SendPackError
+from .pack import (PACK_SPOOL_FILE_MAX_SIZE, PackChunkGenerator,
+                   UnpackedObject, write_pack_from_container)
+from .protocol import (_RBUFSIZE, CAPABILITIES_REF, CAPABILITY_AGENT,
+                       CAPABILITY_DELETE_REFS, CAPABILITY_INCLUDE_TAG,
+                       CAPABILITY_MULTI_ACK, CAPABILITY_MULTI_ACK_DETAILED,
+                       CAPABILITY_OFS_DELTA, CAPABILITY_QUIET,
+                       CAPABILITY_REPORT_STATUS, CAPABILITY_SHALLOW,
+                       CAPABILITY_SIDE_BAND_64K, CAPABILITY_SYMREF,
+                       CAPABILITY_THIN_PACK, COMMAND_DEEPEN, COMMAND_DONE,
+                       COMMAND_HAVE, COMMAND_SHALLOW, COMMAND_UNSHALLOW,
+                       COMMAND_WANT, KNOWN_RECEIVE_CAPABILITIES,
+                       KNOWN_UPLOAD_CAPABILITIES, SIDE_BAND_CHANNEL_DATA,
+                       SIDE_BAND_CHANNEL_FATAL, SIDE_BAND_CHANNEL_PROGRESS,
+                       TCP_GIT_PORT, ZERO_SHA, HangupException, PktLineParser,
+                       Protocol, agent_string, capability_agent,
+                       extract_capabilities, extract_capability_names,
+                       parse_capability, pkt_line)
+from .refs import PEELED_TAG_SUFFIX, _import_remote_refs, read_info_refs
+from .repo import Repo
 
 
 # url2pathname is lazily imported
 # url2pathname is lazily imported
 url2pathname = None
 url2pathname = None
@@ -1663,7 +1661,7 @@ def ParamikoSSHVendor(**kwargs):
         "ParamikoSSHVendor has been moved to dulwich.contrib.paramiko_vendor.",
         "ParamikoSSHVendor has been moved to dulwich.contrib.paramiko_vendor.",
         DeprecationWarning,
         DeprecationWarning,
     )
     )
-    from dulwich.contrib.paramiko_vendor import ParamikoSSHVendor
+    from .contrib.paramiko_vendor import ParamikoSSHVendor
 
 
     return ParamikoSSHVendor(**kwargs)
     return ParamikoSSHVendor(**kwargs)
 
 

+ 2 - 2
dulwich/config.py

@@ -26,13 +26,13 @@ TODO:
    subsections
    subsections
 """
 """
 
 
-from contextlib import suppress
 import os
 import os
 import sys
 import sys
+from contextlib import suppress
 from typing import (BinaryIO, Iterable, Iterator, KeysView, List,
 from typing import (BinaryIO, Iterable, Iterator, KeysView, List,
                     MutableMapping, Optional, Tuple, Union, overload)
                     MutableMapping, Optional, Tuple, Union, overload)
 
 
-from dulwich.file import GitFile
+from .file import GitFile
 
 
 SENTINEL = object()
 SENTINEL = object()
 
 

+ 1 - 1
dulwich/contrib/release_robot.py

@@ -49,7 +49,7 @@ import re
 import sys
 import sys
 import time
 import time
 
 
-from dulwich.repo import Repo
+from ..repo import Repo
 
 
 # CONSTANTS
 # CONSTANTS
 PROJDIR = "."
 PROJDIR = "."

+ 3 - 3
dulwich/contrib/requests_vendor.py

@@ -33,9 +33,9 @@ from io import BytesIO
 
 
 from requests import Session
 from requests import Session
 
 
-from dulwich.client import (AbstractHttpGitClient, HTTPProxyUnauthorized,
-                            HTTPUnauthorized, default_user_agent_string)
-from dulwich.errors import GitProtocolError, NotGitRepository
+from ..client import (AbstractHttpGitClient, HTTPProxyUnauthorized,
+                      HTTPUnauthorized, default_user_agent_string)
+from ..errors import GitProtocolError, NotGitRepository
 
 
 
 
 class RequestsHttpGitClient(AbstractHttpGitClient):
 class RequestsHttpGitClient(AbstractHttpGitClient):

+ 12 - 13
dulwich/contrib/swift.py

@@ -39,19 +39,18 @@ from io import BytesIO
 
 
 from geventhttpclient import HTTPClient
 from geventhttpclient import HTTPClient
 
 
-from dulwich.greenthreads import GreenThreadsMissingObjectFinder
-from dulwich.lru_cache import LRUSizeCache
-from dulwich.object_store import INFODIR, PACKDIR, PackBasedObjectStore
-from dulwich.objects import S_ISGITLINK, Blob, Commit, Tag, Tree
-from dulwich.pack import (Pack, PackData, PackIndexer, PackStreamCopier,
-                          _compute_object_size, compute_file_sha, iter_sha1,
-                          load_pack_index_file, read_pack_header,
-                          unpack_object, write_pack_header,
-                          write_pack_index_v2, write_pack_object)
-from dulwich.protocol import TCP_GIT_PORT
-from dulwich.refs import InfoRefsContainer, read_info_refs, write_info_refs
-from dulwich.repo import OBJECTDIR, BaseRepo
-from dulwich.server import Backend, TCPGitServer
+from ..greenthreads import GreenThreadsMissingObjectFinder
+from ..lru_cache import LRUSizeCache
+from ..object_store import INFODIR, PACKDIR, PackBasedObjectStore
+from ..objects import S_ISGITLINK, Blob, Commit, Tag, Tree
+from ..pack import (Pack, PackData, PackIndexer, PackStreamCopier,
+                    _compute_object_size, compute_file_sha, iter_sha1,
+                    load_pack_index_file, read_pack_header, unpack_object,
+                    write_pack_header, write_pack_index_v2, write_pack_object)
+from ..protocol import TCP_GIT_PORT
+from ..refs import InfoRefsContainer, read_info_refs, write_info_refs
+from ..repo import OBJECTDIR, BaseRepo
+from ..server import Backend, TCPGitServer
 
 
 """
 """
 # Configuration file sample
 # Configuration file sample

+ 1 - 1
dulwich/contrib/test_paramiko_vendor.py

@@ -32,7 +32,7 @@ except ImportError:
     has_paramiko = False
     has_paramiko = False
 else:
 else:
     has_paramiko = True
     has_paramiko = True
-    from dulwich.contrib.paramiko_vendor import ParamikoSSHVendor
+    from .paramiko_vendor import ParamikoSSHVendor
 
 
     class Server(paramiko.ServerInterface):
     class Server(paramiko.ServerInterface):
         """http://docs.paramiko.org/en/2.4/api/server.html"""
         """http://docs.paramiko.org/en/2.4/api/server.html"""

+ 3 - 2
dulwich/contrib/test_release_robot.py

@@ -28,8 +28,9 @@ import time
 import unittest
 import unittest
 
 
 from dulwich.contrib import release_robot
 from dulwich.contrib import release_robot
-from dulwich.repo import Repo
-from dulwich.tests.utils import make_commit, make_tag
+
+from ..repo import Repo
+from ..tests.utils import make_commit, make_tag
 
 
 BASEDIR = os.path.abspath(os.path.dirname(__file__))  # this directory
 BASEDIR = os.path.abspath(os.path.dirname(__file__))  # this directory
 
 

+ 3 - 2
dulwich/contrib/test_swift.py

@@ -28,9 +28,10 @@ from io import BytesIO, StringIO
 from time import time
 from time import time
 from unittest import skipIf
 from unittest import skipIf
 
 
-from dulwich.objects import Blob, Commit, Tag, Tree, parse_timezone
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.test_object_store import ObjectStoreTests
+
+from ..objects import Blob, Commit, Tag, Tree, parse_timezone
+from ..tests.test_object_store import ObjectStoreTests
 
 
 missing_libs = []
 missing_libs = []
 
 

+ 1 - 1
dulwich/credentials.py

@@ -28,7 +28,7 @@ import sys
 from typing import Iterator, Optional
 from typing import Iterator, Optional
 from urllib.parse import ParseResult, urlparse
 from urllib.parse import ParseResult, urlparse
 
 
-from dulwich.config import ConfigDict, SectionLike
+from .config import ConfigDict, SectionLike
 
 
 
 
 def match_urls(url: ParseResult, url_prefix: ParseResult) -> bool:
 def match_urls(url: ParseResult, url_prefix: ParseResult) -> bool:

+ 1 - 1
dulwich/diff_tree.py

@@ -26,7 +26,7 @@ from io import BytesIO
 from itertools import chain
 from itertools import chain
 from typing import Dict, List, Optional
 from typing import Dict, List, Optional
 
 
-from dulwich.objects import S_ISGITLINK, Tree, TreeEntry
+from .objects import S_ISGITLINK, Tree, TreeEntry
 
 
 # TreeChange type constants.
 # TreeChange type constants.
 CHANGE_ADD = "add"
 CHANGE_ADD = "add"

+ 3 - 3
dulwich/fastexport.py

@@ -27,9 +27,9 @@ from fastimport import commands
 from fastimport import errors as fastimport_errors
 from fastimport import errors as fastimport_errors
 from fastimport import parser, processor
 from fastimport import parser, processor
 
 
-from dulwich.index import commit_tree
-from dulwich.object_store import iter_tree_contents
-from dulwich.objects import ZERO_SHA, Blob, Commit, Tag
+from .index import commit_tree
+from .object_store import iter_tree_contents
+from .objects import ZERO_SHA, Blob, Commit, Tag
 
 
 
 
 def split_email(text):
 def split_email(text):

+ 3 - 3
dulwich/greenthreads.py

@@ -25,9 +25,9 @@
 import gevent
 import gevent
 from gevent import pool
 from gevent import pool
 
 
-from dulwich.object_store import (MissingObjectFinder, _collect_ancestors,
-                                  _collect_filetree_revs)
-from dulwich.objects import Commit, Tag
+from .object_store import (MissingObjectFinder, _collect_ancestors,
+                           _collect_filetree_revs)
+from .objects import Commit, Tag
 
 
 
 
 def _split_commits_and_tags(obj_store, lst, *, ignore_unknown=False, pool=None):
 def _split_commits_and_tags(obj_store, lst, *, ignore_unknown=False, pool=None):

+ 1 - 1
dulwich/hooks.py

@@ -23,7 +23,7 @@
 import os
 import os
 import subprocess
 import subprocess
 
 
-from dulwich.errors import HookError
+from .errors import HookError
 
 
 
 
 class Hook:
 class Hook:

+ 3 - 3
dulwich/ignore.py

@@ -22,16 +22,16 @@
 For details for the matching rules, see https://git-scm.com/docs/gitignore
 For details for the matching rules, see https://git-scm.com/docs/gitignore
 """
 """
 
 
-from contextlib import suppress
 import os.path
 import os.path
 import re
 import re
+from contextlib import suppress
 from typing import (TYPE_CHECKING, BinaryIO, Dict, Iterable, List, Optional,
 from typing import (TYPE_CHECKING, BinaryIO, Dict, Iterable, List, Optional,
                     Union)
                     Union)
 
 
 if TYPE_CHECKING:
 if TYPE_CHECKING:
-    from dulwich.repo import Repo
+    from .repo import Repo
 
 
-from dulwich.config import Config, get_xdg_config_home_path
+from .config import Config, get_xdg_config_home_path
 
 
 
 
 def _translate_segment(segment: bytes) -> bytes:
 def _translate_segment(segment: bytes) -> bytes:

+ 7 - 7
dulwich/index.py

@@ -28,11 +28,11 @@ import sys
 from typing import (Any, BinaryIO, Callable, Dict, Iterable, Iterator, List,
 from typing import (Any, BinaryIO, Callable, Dict, Iterable, Iterator, List,
                     Optional, Tuple, Union)
                     Optional, Tuple, Union)
 
 
-from dulwich.file import GitFile
-from dulwich.object_store import iter_tree_contents
-from dulwich.objects import (S_IFGITLINK, S_ISGITLINK, Blob, ObjectID, Tree,
-                             hex_to_sha, sha_to_hex)
-from dulwich.pack import ObjectContainer, SHA1Reader, SHA1Writer
+from .file import GitFile
+from .object_store import iter_tree_contents
+from .objects import (S_IFGITLINK, S_ISGITLINK, Blob, ObjectID, Tree,
+                      hex_to_sha, sha_to_hex)
+from .pack import ObjectContainer, SHA1Reader, SHA1Writer
 
 
 # TODO(jelmer): Switch to dataclass?
 # TODO(jelmer): Switch to dataclass?
 IndexEntry = collections.namedtuple(
 IndexEntry = collections.namedtuple(
@@ -774,8 +774,8 @@ def read_submodule_head(path: Union[str, bytes]) -> Optional[bytes]:
       path: path to the submodule
       path: path to the submodule
     Returns: HEAD sha, None if not a valid head/repository
     Returns: HEAD sha, None if not a valid head/repository
     """
     """
-    from dulwich.errors import NotGitRepository
-    from dulwich.repo import Repo
+    from .errors import NotGitRepository
+    from .repo import Repo
 
 
     # Repo currently expects a "str", so decode if necessary.
     # Repo currently expects a "str", so decode if necessary.
     # TODO(jelmer): Perhaps move this into Repo() ?
     # TODO(jelmer): Perhaps move this into Repo() ?

+ 3 - 3
dulwich/line_ending.py

@@ -136,9 +136,9 @@ Sources:
 - https://adaptivepatchwork.com/2012/03/01/mind-the-end-of-your-line/
 - https://adaptivepatchwork.com/2012/03/01/mind-the-end-of-your-line/
 """
 """
 
 
-from dulwich.object_store import iter_tree_contents
-from dulwich.objects import Blob
-from dulwich.patch import is_binary
+from .object_store import iter_tree_contents
+from .objects import Blob
+from .patch import is_binary
 
 
 CRLF = b"\r\n"
 CRLF = b"\r\n"
 LF = b"\n"
 LF = b"\n"

+ 14 - 17
dulwich/object_store.py

@@ -36,22 +36,19 @@ try:
 except ImportError:  # python << 3.8
 except ImportError:  # python << 3.8
     from typing_extensions import Protocol  # type: ignore
     from typing_extensions import Protocol  # type: ignore
 
 
-from dulwich.errors import NotTreeError
-from dulwich.file import GitFile
-from dulwich.objects import (S_ISGITLINK, ZERO_SHA, Blob, Commit, ObjectID,
-                             ShaFile, Tag, Tree, TreeEntry, hex_to_filename,
-                             hex_to_sha, object_class, sha_to_hex,
-                             valid_hexsha)
-from dulwich.pack import (PACK_SPOOL_FILE_MAX_SIZE, ObjectContainer, Pack,
-                          PackData, PackedObjectContainer, PackFileDisappeared,
-                          PackHint, PackIndexer, PackInflater,
-                          PackStreamCopier, UnpackedObject, extend_pack,
-                          full_unpacked_object, generate_unpacked_objects,
-                          iter_sha1, load_pack_index_file,
-                          pack_objects_to_data, write_pack_data,
-                          write_pack_index)
-from dulwich.protocol import DEPTH_INFINITE
-from dulwich.refs import PEELED_TAG_SUFFIX, Ref
+from .errors import NotTreeError
+from .file import GitFile
+from .objects import (S_ISGITLINK, ZERO_SHA, Blob, Commit, ObjectID, ShaFile,
+                      Tag, Tree, TreeEntry, hex_to_filename, hex_to_sha,
+                      object_class, sha_to_hex, valid_hexsha)
+from .pack import (PACK_SPOOL_FILE_MAX_SIZE, ObjectContainer, Pack, PackData,
+                   PackedObjectContainer, PackFileDisappeared, PackHint,
+                   PackIndexer, PackInflater, PackStreamCopier, UnpackedObject,
+                   extend_pack, full_unpacked_object,
+                   generate_unpacked_objects, iter_sha1, load_pack_index_file,
+                   pack_objects_to_data, write_pack_data, write_pack_index)
+from .protocol import DEPTH_INFINITE
+from .refs import PEELED_TAG_SUFFIX, Ref
 
 
 INFODIR = "info"
 INFODIR = "info"
 PACKDIR = "pack"
 PACKDIR = "pack"
@@ -161,7 +158,7 @@ class BaseObjectStore:
             (oldpath, newpath), (oldmode, newmode), (oldsha, newsha)
             (oldpath, newpath), (oldmode, newmode), (oldsha, newsha)
         """
         """
 
 
-        from dulwich.diff_tree import tree_changes
+        from .diff_tree import tree_changes
         for change in tree_changes(
         for change in tree_changes(
             self,
             self,
             source,
             source,

+ 7 - 16
dulwich/objects.py

@@ -25,29 +25,20 @@ import binascii
 import os
 import os
 import posixpath
 import posixpath
 import stat
 import stat
-from typing import (
-    Optional,
-    Dict,
-    Iterable,
-    Iterator,
-    List,
-    Tuple,
-    Type,
-    Union,
-    BinaryIO,
-)
+import warnings
 import zlib
 import zlib
 from collections import namedtuple
 from collections import namedtuple
 from hashlib import sha1
 from hashlib import sha1
 from io import BytesIO
 from io import BytesIO
-import warnings
+from typing import (BinaryIO, Dict, Iterable, Iterator, List, Optional, Tuple,
+                    Type, Union)
 
 
 from _hashlib import HASH
 from _hashlib import HASH
 
 
-from dulwich.errors import (ChecksumMismatch, FileFormatException,
-                            NotBlobError, NotCommitError, NotTagError,
-                            NotTreeError, ObjectFormatException)
-from dulwich.file import GitFile
+from .errors import (ChecksumMismatch, FileFormatException, NotBlobError,
+                     NotCommitError, NotTagError, NotTreeError,
+                     ObjectFormatException)
+from .file import GitFile
 
 
 ZERO_SHA = b"0" * 40
 ZERO_SHA = b"0" * 40
 
 

+ 4 - 4
dulwich/objectspec.py

@@ -20,12 +20,12 @@
 
 
 """Object specification."""
 """Object specification."""
 
 
-from typing import List, Tuple, Union, TYPE_CHECKING, Optional, Iterator
+from typing import TYPE_CHECKING, Iterator, List, Optional, Tuple, Union
 
 
 if TYPE_CHECKING:
 if TYPE_CHECKING:
-    from dulwich.objects import ShaFile, Commit, Tree
-    from dulwich.refs import RefsContainer, Ref
-    from dulwich.repo import Repo
+    from .objects import Commit, ShaFile, Tree
+    from .refs import Ref, RefsContainer
+    from .repo import Repo
 
 
 
 
 def to_bytes(text: Union[str, bytes]) -> bytes:
 def to_bytes(text: Union[str, bytes]) -> bytes:

+ 6 - 7
dulwich/pack.py

@@ -72,11 +72,10 @@ else:
 if sys.platform == "Plan9":
 if sys.platform == "Plan9":
     has_mmap = False
     has_mmap = False
 
 
-from dulwich.errors import ApplyDeltaError, ChecksumMismatch
-from dulwich.file import GitFile
-from dulwich.lru_cache import LRUSizeCache
-from dulwich.objects import (ObjectID, ShaFile, hex_to_sha, object_header,
-                             sha_to_hex)
+from .errors import ApplyDeltaError, ChecksumMismatch
+from .file import GitFile
+from .lru_cache import LRUSizeCache
+from .objects import ObjectID, ShaFile, hex_to_sha, object_header, sha_to_hex
 
 
 OFS_DELTA = 6
 OFS_DELTA = 6
 REF_DELTA = 7
 REF_DELTA = 7
@@ -2593,7 +2592,7 @@ def extend_pack(f: BinaryIO, object_ids: Set[ObjectID], get_raw, *, compression_
 
 
 
 
 try:
 try:
-    from dulwich._pack import (apply_delta,  # type: ignore # noqa: F811
-                               bisect_find_sha)
+    from dulwich._pack import apply_delta  # type: ignore # noqa: F811
+    from dulwich._pack import bisect_find_sha  # type: ignore # noqa: F811
 except ImportError:
 except ImportError:
     pass
     pass

+ 2 - 2
dulwich/patch.py

@@ -29,8 +29,8 @@ import time
 from difflib import SequenceMatcher
 from difflib import SequenceMatcher
 from typing import BinaryIO, Optional, TextIO, Union
 from typing import BinaryIO, Optional, TextIO, Union
 
 
-from dulwich.objects import S_ISGITLINK, Blob, Commit
-from dulwich.pack import ObjectContainer
+from .objects import S_ISGITLINK, Blob, Commit
+from .pack import ObjectContainer
 
 
 FIRST_FEW_BYTES = 8000
 FIRST_FEW_BYTES = 8000
 
 

+ 33 - 33
dulwich/porcelain.py

@@ -75,32 +75,32 @@ from io import BytesIO, RawIOBase
 from pathlib import Path
 from pathlib import Path
 from typing import Optional, Tuple, Union
 from typing import Optional, Tuple, Union
 
 
-from dulwich.archive import tar_stream
-from dulwich.client import get_transport_and_path
-from dulwich.config import Config, ConfigFile, StackedConfig, read_submodules
-from dulwich.diff_tree import (CHANGE_ADD, CHANGE_COPY, CHANGE_DELETE,
-                               CHANGE_MODIFY, CHANGE_RENAME,
-                               RENAME_CHANGE_TYPES)
-from dulwich.errors import SendPackError
-from dulwich.file import ensure_dir_exists
-from dulwich.graph import can_fast_forward
-from dulwich.ignore import IgnoreFilterManager
-from dulwich.index import (_fs_to_tree_path, blob_from_path_and_stat,
-                           build_file_from_blob, get_unstaged_changes, index_entry_from_stat)
-from dulwich.object_store import tree_lookup_path, iter_tree_contents
-from dulwich.objects import (Commit, Tag, format_timezone, parse_timezone,
-                             pretty_format_tree_entry)
-from dulwich.objectspec import (parse_commit, parse_object, parse_ref,
-                                parse_reftuples, parse_tree, to_bytes)
-from dulwich.pack import write_pack_from_container, write_pack_index
-from dulwich.patch import write_tree_diff
-from dulwich.protocol import ZERO_SHA, Protocol
-from dulwich.refs import (LOCAL_BRANCH_PREFIX, LOCAL_REMOTE_PREFIX,
-                          LOCAL_TAG_PREFIX, _import_remote_refs)
-from dulwich.repo import BaseRepo, Repo
-from dulwich.server import (FileSystemBackend, ReceivePackHandler,
-                            TCPGitServer, UploadPackHandler)
-from dulwich.server import update_server_info as server_update_server_info
+from .archive import tar_stream
+from .client import get_transport_and_path
+from .config import Config, ConfigFile, StackedConfig, read_submodules
+from .diff_tree import (CHANGE_ADD, CHANGE_COPY, CHANGE_DELETE, CHANGE_MODIFY,
+                        CHANGE_RENAME, RENAME_CHANGE_TYPES)
+from .errors import SendPackError
+from .file import ensure_dir_exists
+from .graph import can_fast_forward
+from .ignore import IgnoreFilterManager
+from .index import (_fs_to_tree_path, blob_from_path_and_stat,
+                    build_file_from_blob, get_unstaged_changes,
+                    index_entry_from_stat)
+from .object_store import iter_tree_contents, tree_lookup_path
+from .objects import (Commit, Tag, format_timezone, parse_timezone,
+                      pretty_format_tree_entry)
+from .objectspec import (parse_commit, parse_object, parse_ref,
+                         parse_reftuples, parse_tree, to_bytes)
+from .pack import write_pack_from_container, write_pack_index
+from .patch import write_tree_diff
+from .protocol import ZERO_SHA, Protocol
+from .refs import (LOCAL_BRANCH_PREFIX, LOCAL_REMOTE_PREFIX, LOCAL_TAG_PREFIX,
+                   _import_remote_refs)
+from .repo import BaseRepo, Repo
+from .server import (FileSystemBackend, ReceivePackHandler, TCPGitServer,
+                     UploadPackHandler)
+from .server import update_server_info as server_update_server_info
 
 
 # Module level tuple definition for status output
 # Module level tuple definition for status output
 GitStatus = namedtuple("GitStatus", "staged unstaged untracked")
 GitStatus = namedtuple("GitStatus", "staged unstaged untracked")
@@ -1461,8 +1461,8 @@ def web_daemon(path=".", address=None, port=None):
       address: Optional address to listen on (defaults to ::)
       address: Optional address to listen on (defaults to ::)
       port: Optional port to listen on (defaults to 80)
       port: Optional port to listen on (defaults to 80)
     """
     """
-    from dulwich.web import (WSGIRequestHandlerLogger, WSGIServerLogger,
-                             make_server, make_wsgi_chain)
+    from .web import (WSGIRequestHandlerLogger, WSGIServerLogger, make_server,
+                      make_wsgi_chain)
 
 
     backend = FileSystemBackend(path)
     backend = FileSystemBackend(path)
     app = make_wsgi_chain(backend)
     app = make_wsgi_chain(backend)
@@ -1974,7 +1974,7 @@ def check_mailmap(repo, contact):
     Returns: Canonical contact data
     Returns: Canonical contact data
     """
     """
     with open_repo_closing(repo) as r:
     with open_repo_closing(repo) as r:
-        from dulwich.mailmap import Mailmap
+        from .mailmap import Mailmap
 
 
         try:
         try:
             mailmap = Mailmap.from_path(os.path.join(r.path, ".mailmap"))
             mailmap = Mailmap.from_path(os.path.join(r.path, ".mailmap"))
@@ -2005,7 +2005,7 @@ def fsck(repo):
 def stash_list(repo):
 def stash_list(repo):
     """List all stashes in a repository."""
     """List all stashes in a repository."""
     with open_repo_closing(repo) as r:
     with open_repo_closing(repo) as r:
-        from dulwich.stash import Stash
+        from .stash import Stash
 
 
         stash = Stash.from_repo(r)
         stash = Stash.from_repo(r)
         return enumerate(list(stash.stashes()))
         return enumerate(list(stash.stashes()))
@@ -2014,7 +2014,7 @@ def stash_list(repo):
 def stash_push(repo):
 def stash_push(repo):
     """Push a new stash onto the stack."""
     """Push a new stash onto the stack."""
     with open_repo_closing(repo) as r:
     with open_repo_closing(repo) as r:
-        from dulwich.stash import Stash
+        from .stash import Stash
 
 
         stash = Stash.from_repo(r)
         stash = Stash.from_repo(r)
         stash.push()
         stash.push()
@@ -2023,7 +2023,7 @@ def stash_push(repo):
 def stash_pop(repo, index):
 def stash_pop(repo, index):
     """Pop a stash from the stack."""
     """Pop a stash from the stack."""
     with open_repo_closing(repo) as r:
     with open_repo_closing(repo) as r:
-        from dulwich.stash import Stash
+        from .stash import Stash
 
 
         stash = Stash.from_repo(r)
         stash = Stash.from_repo(r)
         stash.pop(index)
         stash.pop(index)
@@ -2032,7 +2032,7 @@ def stash_pop(repo, index):
 def stash_drop(repo, index):
 def stash_drop(repo, index):
     """Drop a stash from the stack."""
     """Drop a stash from the stack."""
     with open_repo_closing(repo) as r:
     with open_repo_closing(repo) as r:
-        from dulwich.stash import Stash
+        from .stash import Stash
 
 
         stash = Stash.from_repo(r)
         stash = Stash.from_repo(r)
         stash.drop(index)
         stash.drop(index)

+ 2 - 1
dulwich/protocol.py

@@ -25,7 +25,8 @@ from io import BytesIO
 from os import SEEK_END
 from os import SEEK_END
 
 
 import dulwich
 import dulwich
-from dulwich.errors import GitProtocolError, HangupException
+
+from .errors import GitProtocolError, HangupException
 
 
 TCP_GIT_PORT = 9418
 TCP_GIT_PORT = 9418
 
 

+ 1 - 1
dulwich/reflog.py

@@ -23,7 +23,7 @@
 
 
 import collections
 import collections
 
 
-from dulwich.objects import ZERO_SHA, format_timezone, parse_timezone
+from .objects import ZERO_SHA, format_timezone, parse_timezone
 
 
 Entry = collections.namedtuple(
 Entry = collections.namedtuple(
     "Entry",
     "Entry",

+ 6 - 6
dulwich/refs.py

@@ -27,10 +27,10 @@ import warnings
 from contextlib import suppress
 from contextlib import suppress
 from typing import Dict, Optional
 from typing import Dict, Optional
 
 
-from dulwich.errors import PackedRefsException, RefFormatError
-from dulwich.file import GitFile, ensure_dir_exists
-from dulwich.objects import ZERO_SHA, ObjectID, Tag, git_line, valid_hexsha
-from dulwich.pack import ObjectContainer
+from .errors import PackedRefsException, RefFormatError
+from .file import GitFile, ensure_dir_exists
+from .objects import ZERO_SHA, ObjectID, Tag, git_line, valid_hexsha
+from .pack import ObjectContainer
 
 
 Ref = bytes
 Ref = bytes
 
 
@@ -1145,7 +1145,7 @@ def read_info_refs(f):
 def write_info_refs(refs, store: ObjectContainer):
 def write_info_refs(refs, store: ObjectContainer):
     """Generate info refs."""
     """Generate info refs."""
     # TODO: Avoid recursive import :(
     # TODO: Avoid recursive import :(
-    from dulwich.object_store import peel_sha
+    from .object_store import peel_sha
     for name, sha in sorted(refs.items()):
     for name, sha in sorted(refs.items()):
         # get_refs() includes HEAD as a special case, but we don't want to
         # get_refs() includes HEAD as a special case, but we don't want to
         # advertise it
         # advertise it
@@ -1273,7 +1273,7 @@ def _import_remote_refs(
 
 
 def serialize_refs(store, refs):
 def serialize_refs(store, refs):
     # TODO: Avoid recursive import :(
     # TODO: Avoid recursive import :(
-    from dulwich.object_store import peel_sha
+    from .object_store import peel_sha
     ret = {}
     ret = {}
     for ref, sha in refs.items():
     for ref, sha in refs.items():
         try:
         try:

+ 37 - 39
dulwich/repo.py

@@ -41,30 +41,29 @@ if TYPE_CHECKING:
     # There are no circular imports here, but we try to defer imports as long
     # There are no circular imports here, but we try to defer imports as long
     # as possible to reduce start-up time for anything that doesn't need
     # as possible to reduce start-up time for anything that doesn't need
     # these imports.
     # these imports.
-    from dulwich.config import StackedConfig, ConfigFile
-    from dulwich.index import Index
-
-from dulwich.errors import (CommitError, HookError, NoIndexPresent,
-                            NotBlobError, NotCommitError, NotGitRepository,
-                            NotTagError, NotTreeError, RefFormatError)
-from dulwich.file import GitFile
-from dulwich.hooks import (CommitMsgShellHook, Hook, PostCommitShellHook,
-                           PostReceiveShellHook, PreCommitShellHook)
-from dulwich.line_ending import BlobNormalizer, TreeBlobNormalizer
-from dulwich.object_store import (DiskObjectStore, MemoryObjectStore,
-                                  MissingObjectFinder, ObjectStoreGraphWalker,
-                                  PackBasedObjectStore, peel_sha)
-from dulwich.objects import (Blob, Commit, ObjectID, ShaFile, Tag, Tree,
-                             check_hexsha, valid_hexsha)
-from dulwich.pack import generate_unpacked_objects
-from dulwich.refs import (ANNOTATED_TAG_SUFFIX,  # noqa: F401
-                          LOCAL_BRANCH_PREFIX, LOCAL_TAG_PREFIX, SYMREF,
-                          DictRefsContainer, DiskRefsContainer,
-                          InfoRefsContainer, Ref, RefsContainer,
-                          _set_default_branch, _set_head, _set_origin_head,
-                          check_ref_format, read_packed_refs,
-                          read_packed_refs_with_peeled, serialize_refs,
-                          write_packed_refs)
+    from .config import StackedConfig, ConfigFile
+    from .index import Index
+
+from .errors import (CommitError, HookError, NoIndexPresent, NotBlobError,
+                     NotCommitError, NotGitRepository, NotTagError,
+                     NotTreeError, RefFormatError)
+from .file import GitFile
+from .hooks import (CommitMsgShellHook, Hook, PostCommitShellHook,
+                    PostReceiveShellHook, PreCommitShellHook)
+from .line_ending import BlobNormalizer, TreeBlobNormalizer
+from .object_store import (DiskObjectStore, MemoryObjectStore,
+                           MissingObjectFinder, ObjectStoreGraphWalker,
+                           PackBasedObjectStore, peel_sha)
+from .objects import (Blob, Commit, ObjectID, ShaFile, Tag, Tree, check_hexsha,
+                      valid_hexsha)
+from .pack import generate_unpacked_objects
+from .refs import (ANNOTATED_TAG_SUFFIX, LOCAL_BRANCH_PREFIX,  # noqa: F401
+                   LOCAL_TAG_PREFIX, SYMREF,
+                   DictRefsContainer, DiskRefsContainer, InfoRefsContainer,
+                   Ref, RefsContainer, _set_default_branch, _set_head,
+                   _set_origin_head, check_ref_format, read_packed_refs,
+                   read_packed_refs_with_peeled, serialize_refs,
+                   write_packed_refs)
 
 
 CONTROLDIR = ".git"
 CONTROLDIR = ".git"
 OBJECTDIR = "objects"
 OBJECTDIR = "objects"
@@ -331,7 +330,7 @@ class BaseRepo:
 
 
     def _init_files(self, bare: bool) -> None:
     def _init_files(self, bare: bool) -> None:
         """Initialize a default set of named files."""
         """Initialize a default set of named files."""
-        from dulwich.config import ConfigFile
+        from .config import ConfigFile
 
 
         self._put_named_file("description", b"Unnamed repository")
         self._put_named_file("description", b"Unnamed repository")
         f = BytesIO()
         f = BytesIO()
@@ -659,7 +658,7 @@ class BaseRepo:
 
 
         Returns: `Config` instance for this repository
         Returns: `Config` instance for this repository
         """
         """
-        from dulwich.config import ConfigFile, StackedConfig
+        from .config import ConfigFile, StackedConfig
 
 
         local_config = self.get_config()
         local_config = self.get_config()
         backends: List[ConfigFile] = [local_config]
         backends: List[ConfigFile] = [local_config]
@@ -740,7 +739,7 @@ class BaseRepo:
             Walker.
             Walker.
         Returns: A `Walker` object
         Returns: A `Walker` object
         """
         """
-        from dulwich.walk import Walker
+        from .walk import Walker
 
 
         if include is None:
         if include is None:
             include = [self.head()]
             include = [self.head()]
@@ -1286,7 +1285,7 @@ class Repo(BaseRepo):
           NoIndexPresent: If no index is present
           NoIndexPresent: If no index is present
         Returns: The matching `Index`
         Returns: The matching `Index`
         """
         """
-        from dulwich.index import Index
+        from .index import Index
 
 
         if not self.has_index():
         if not self.has_index():
             raise NoIndexPresent()
             raise NoIndexPresent()
@@ -1311,9 +1310,8 @@ class Repo(BaseRepo):
             fs_paths = [fs_paths]
             fs_paths = [fs_paths]
         fs_paths = list(fs_paths)
         fs_paths = list(fs_paths)
 
 
-        from dulwich.index import (_fs_to_tree_path, blob_from_path_and_stat,
-                                   index_entry_from_directory,
-                                   index_entry_from_stat)
+        from .index import (_fs_to_tree_path, blob_from_path_and_stat,
+                            index_entry_from_directory, index_entry_from_stat)
 
 
         index = self.open_index()
         index = self.open_index()
         blob_normalizer = self.get_blob_normalizer()
         blob_normalizer = self.get_blob_normalizer()
@@ -1363,7 +1361,7 @@ class Repo(BaseRepo):
           fs_paths: a list of files to unstage,
           fs_paths: a list of files to unstage,
             relative to the repository path
             relative to the repository path
         """
         """
-        from dulwich.index import IndexEntry, _fs_to_tree_path
+        from .index import IndexEntry, _fs_to_tree_path
 
 
         index = self.open_index()
         index = self.open_index()
         try:
         try:
@@ -1514,9 +1512,9 @@ class Repo(BaseRepo):
         Args:
         Args:
           tree: Tree SHA to reset to, None for current HEAD tree.
           tree: Tree SHA to reset to, None for current HEAD tree.
         """
         """
-        from dulwich.index import (build_index_from_tree,
-                                   validate_path_element_default,
-                                   validate_path_element_ntfs)
+        from .index import (build_index_from_tree,
+                            validate_path_element_default,
+                            validate_path_element_ntfs)
 
 
         if tree is None:
         if tree is None:
             head = self[b"HEAD"]
             head = self[b"HEAD"]
@@ -1541,7 +1539,7 @@ class Repo(BaseRepo):
         )
         )
 
 
     def get_worktree_config(self) -> "ConfigFile":
     def get_worktree_config(self) -> "ConfigFile":
-        from dulwich.config import ConfigFile
+        from .config import ConfigFile
         path = os.path.join(self.commondir(), "config.worktree")
         path = os.path.join(self.commondir(), "config.worktree")
         try:
         try:
             return ConfigFile.from_path(path)
             return ConfigFile.from_path(path)
@@ -1555,7 +1553,7 @@ class Repo(BaseRepo):
 
 
         Returns: `ConfigFile` object for the ``.git/config`` file.
         Returns: `ConfigFile` object for the ``.git/config`` file.
         """
         """
-        from dulwich.config import ConfigFile
+        from .config import ConfigFile
 
 
         path = os.path.join(self._commondir, "config")
         path = os.path.join(self._commondir, "config")
         try:
         try:
@@ -1600,7 +1598,7 @@ class Repo(BaseRepo):
         ret = cls(path, bare=bare, object_store=object_store)
         ret = cls(path, bare=bare, object_store=object_store)
         if default_branch is None:
         if default_branch is None:
             if config is None:
             if config is None:
-                from dulwich.config import StackedConfig
+                from .config import StackedConfig
                 config = StackedConfig.default()
                 config = StackedConfig.default()
             try:
             try:
                 default_branch = config.get("init", "defaultBranch")
                 default_branch = config.get("init", "defaultBranch")
@@ -1717,7 +1715,7 @@ class MemoryRepo(BaseRepo):
     """
     """
 
 
     def __init__(self):
     def __init__(self):
-        from dulwich.config import ConfigFile
+        from .config import ConfigFile
 
 
         self._reflog = []
         self._reflog = []
         refs_container = DictRefsContainer({}, logger=self._append_reflog)
         refs_container = DictRefsContainer({}, logger=self._append_reflog)

+ 28 - 29
dulwich/server.py

@@ -59,35 +59,34 @@ import socketserver
 import zlib
 import zlib
 
 
 from dulwich import log_utils
 from dulwich import log_utils
-from dulwich.archive import tar_stream
-from dulwich.errors import (ApplyDeltaError, ChecksumMismatch,
-                            GitProtocolError, HookError, NotGitRepository,
-                            ObjectFormatException, UnexpectedCommandError)
-from dulwich.object_store import peel_sha
-from dulwich.objects import Commit, ObjectID, valid_hexsha
-from dulwich.pack import (ObjectContainer, PackedObjectContainer,
-                          write_pack_from_container)
-from dulwich.protocol import (CAPABILITIES_REF, CAPABILITY_AGENT,
-                              CAPABILITY_DELETE_REFS, CAPABILITY_INCLUDE_TAG,
-                              CAPABILITY_MULTI_ACK,
-                              CAPABILITY_MULTI_ACK_DETAILED,
-                              CAPABILITY_NO_DONE, CAPABILITY_NO_PROGRESS,
-                              CAPABILITY_OFS_DELTA, CAPABILITY_QUIET,
-                              CAPABILITY_REPORT_STATUS, CAPABILITY_SHALLOW,
-                              CAPABILITY_SIDE_BAND_64K, CAPABILITY_THIN_PACK,
-                              COMMAND_DEEPEN, COMMAND_DONE, COMMAND_HAVE,
-                              COMMAND_SHALLOW, COMMAND_UNSHALLOW, COMMAND_WANT,
-                              MULTI_ACK, MULTI_ACK_DETAILED, NAK_LINE,
-                              SIDE_BAND_CHANNEL_DATA, SIDE_BAND_CHANNEL_FATAL,
-                              SIDE_BAND_CHANNEL_PROGRESS, SINGLE_ACK,
-                              TCP_GIT_PORT, ZERO_SHA, BufferedPktLineWriter,
-                              Protocol, ReceivableProtocol, ack_type,
-                              capability_agent, extract_capabilities,
-                              extract_want_line_capabilities, format_ack_line,
-                              format_ref_line, format_shallow_line,
-                              format_unshallow_line, symref_capabilities)
-from dulwich.refs import PEELED_TAG_SUFFIX, RefsContainer, write_info_refs
-from dulwich.repo import BaseRepo, Repo
+
+from .archive import tar_stream
+from .errors import (ApplyDeltaError, ChecksumMismatch, GitProtocolError,
+                     HookError, NotGitRepository, ObjectFormatException,
+                     UnexpectedCommandError)
+from .object_store import peel_sha
+from .objects import Commit, ObjectID, valid_hexsha
+from .pack import (ObjectContainer, PackedObjectContainer,
+                   write_pack_from_container)
+from .protocol import (CAPABILITIES_REF, CAPABILITY_AGENT,
+                       CAPABILITY_DELETE_REFS, CAPABILITY_INCLUDE_TAG,
+                       CAPABILITY_MULTI_ACK, CAPABILITY_MULTI_ACK_DETAILED,
+                       CAPABILITY_NO_DONE, CAPABILITY_NO_PROGRESS,
+                       CAPABILITY_OFS_DELTA, CAPABILITY_QUIET,
+                       CAPABILITY_REPORT_STATUS, CAPABILITY_SHALLOW,
+                       CAPABILITY_SIDE_BAND_64K, CAPABILITY_THIN_PACK,
+                       COMMAND_DEEPEN, COMMAND_DONE, COMMAND_HAVE,
+                       COMMAND_SHALLOW, COMMAND_UNSHALLOW, COMMAND_WANT,
+                       MULTI_ACK, MULTI_ACK_DETAILED, NAK_LINE,
+                       SIDE_BAND_CHANNEL_DATA, SIDE_BAND_CHANNEL_FATAL,
+                       SIDE_BAND_CHANNEL_PROGRESS, SINGLE_ACK, TCP_GIT_PORT,
+                       ZERO_SHA, BufferedPktLineWriter, Protocol,
+                       ReceivableProtocol, ack_type, capability_agent,
+                       extract_capabilities, extract_want_line_capabilities,
+                       format_ack_line, format_ref_line, format_shallow_line,
+                       format_unshallow_line, symref_capabilities)
+from .refs import PEELED_TAG_SUFFIX, RefsContainer, write_info_refs
+from .repo import BaseRepo, Repo
 
 
 logger = log_utils.getLogger(__name__)
 logger = log_utils.getLogger(__name__)
 
 

+ 3 - 3
dulwich/stash.py

@@ -23,9 +23,9 @@
 
 
 import os
 import os
 
 
-from dulwich.file import GitFile
-from dulwich.index import commit_tree, iter_fresh_objects
-from dulwich.reflog import drop_reflog_entry, read_reflog
+from .file import GitFile
+from .index import commit_tree, iter_fresh_objects
+from .reflog import drop_reflog_entry, read_reflog
 
 
 DEFAULT_STASH_REF = b"refs/stash"
 DEFAULT_STASH_REF = b"refs/stash"
 
 

+ 6 - 6
dulwich/tests/compat/server_utils.py

@@ -26,12 +26,12 @@ import shutil
 import socket
 import socket
 import tempfile
 import tempfile
 
 
-from dulwich.objects import hex_to_sha
-from dulwich.protocol import CAPABILITY_SIDE_BAND_64K
-from dulwich.repo import Repo
-from dulwich.server import ReceivePackHandler
-from dulwich.tests.compat.utils import require_git_version, run_git_or_fail
-from dulwich.tests.utils import tear_down_repo
+from ...objects import hex_to_sha
+from ...protocol import CAPABILITY_SIDE_BAND_64K
+from ...repo import Repo
+from ...server import ReceivePackHandler
+from ..utils import tear_down_repo
+from .utils import require_git_version, run_git_or_fail
 
 
 
 
 class _StubRepo:
 class _StubRepo:

+ 4 - 4
dulwich/tests/compat/test_client.py

@@ -20,7 +20,6 @@
 
 
 """Compatibility tests between the Dulwich client and the cgit server."""
 """Compatibility tests between the Dulwich client and the cgit server."""
 
 
-from contextlib import suppress
 import copy
 import copy
 import http.server
 import http.server
 import os
 import os
@@ -32,14 +31,15 @@ import sys
 import tarfile
 import tarfile
 import tempfile
 import tempfile
 import threading
 import threading
+from contextlib import suppress
 from io import BytesIO
 from io import BytesIO
 from urllib.parse import unquote
 from urllib.parse import unquote
 
 
 from dulwich import client, file, index, objects, protocol, repo
 from dulwich import client, file, index, objects, protocol, repo
 from dulwich.tests import SkipTest, expectedFailure
 from dulwich.tests import SkipTest, expectedFailure
-from dulwich.tests.compat.utils import (_DEFAULT_GIT, CompatTestCase,
-                                        check_for_daemon, import_repo_to_dir,
-                                        rmtree_ro, run_git_or_fail)
+
+from .utils import (_DEFAULT_GIT, CompatTestCase, check_for_daemon,
+                    import_repo_to_dir, rmtree_ro, run_git_or_fail)
 
 
 if sys.platform == "win32":
 if sys.platform == "win32":
     import ctypes
     import ctypes

+ 5 - 4
dulwich/tests/compat/test_pack.py

@@ -27,11 +27,12 @@ import re
 import shutil
 import shutil
 import tempfile
 import tempfile
 
 
-from dulwich.objects import Blob
-from dulwich.pack import write_pack
 from dulwich.tests import SkipTest
 from dulwich.tests import SkipTest
-from dulwich.tests.compat.utils import require_git_version, run_git_or_fail
-from dulwich.tests.test_pack import PackTests, a_sha, pack1_sha
+
+from ...objects import Blob
+from ...pack import write_pack
+from ..test_pack import PackTests, a_sha, pack1_sha
+from .utils import require_git_version, run_git_or_fail
 
 
 _NON_DELTA_RE = re.compile(b"non delta: (?P<non_delta>\\d+) objects")
 _NON_DELTA_RE = re.compile(b"non delta: (?P<non_delta>\\d+) objects")
 
 

+ 3 - 2
dulwich/tests/compat/test_patch.py

@@ -25,8 +25,9 @@ import tempfile
 from io import BytesIO
 from io import BytesIO
 
 
 from dulwich import porcelain
 from dulwich import porcelain
-from dulwich.repo import Repo
-from dulwich.tests.compat.utils import CompatTestCase, run_git_or_fail
+
+from ...repo import Repo
+from .utils import CompatTestCase, run_git_or_fail
 
 
 
 
 class CompatPatchTestCase(CompatTestCase):
 class CompatPatchTestCase(CompatTestCase):

+ 4 - 3
dulwich/tests/compat/test_porcelain.py

@@ -26,9 +26,10 @@ import sys
 from unittest import skipIf
 from unittest import skipIf
 
 
 from dulwich import porcelain
 from dulwich import porcelain
-from dulwich.tests.compat.utils import CompatTestCase, run_git_or_fail
-from dulwich.tests.test_porcelain import PorcelainGpgTestCase
-from dulwich.tests.utils import build_commit_graph
+
+from ..test_porcelain import PorcelainGpgTestCase
+from ..utils import build_commit_graph
+from .utils import CompatTestCase, run_git_or_fail
 
 
 
 
 @skipIf(platform.python_implementation() == "PyPy" or sys.platform == "win32", "gpgme not easily available or supported on Windows and PyPy")
 @skipIf(platform.python_implementation() == "PyPy" or sys.platform == "win32", "gpgme not easily available or supported on Windows and PyPy")

+ 4 - 4
dulwich/tests/compat/test_repository.py

@@ -26,10 +26,10 @@ import tempfile
 from io import BytesIO
 from io import BytesIO
 from itertools import chain
 from itertools import chain
 
 
-from dulwich.objects import hex_to_sha
-from dulwich.repo import Repo, check_ref_format
-from dulwich.tests.compat.utils import (CompatTestCase, require_git_version,
-                                        rmtree_ro, run_git_or_fail)
+from ...objects import hex_to_sha
+from ...repo import Repo, check_ref_format
+from .utils import (CompatTestCase, require_git_version, rmtree_ro,
+                    run_git_or_fail)
 
 
 
 
 class ObjectStoreTestCase(CompatTestCase):
 class ObjectStoreTestCase(CompatTestCase):

+ 4 - 4
dulwich/tests/compat/test_server.py

@@ -29,11 +29,11 @@ import os
 import sys
 import sys
 import threading
 import threading
 
 
-from dulwich.server import DictBackend, TCPGitServer
 from dulwich.tests import skipIf
 from dulwich.tests import skipIf
-from dulwich.tests.compat.server_utils import (NoSideBand64kReceivePackHandler,
-                                               ServerTests)
-from dulwich.tests.compat.utils import CompatTestCase, require_git_version
+
+from ...server import DictBackend, TCPGitServer
+from .server_utils import NoSideBand64kReceivePackHandler, ServerTests
+from .utils import CompatTestCase, require_git_version
 
 
 
 
 @skipIf(sys.platform == "win32", "Broken on windows, with very long fail time.")
 @skipIf(sys.platform == "win32", "Broken on windows, with very long fail time.")

+ 6 - 6
dulwich/tests/compat/test_web.py

@@ -30,13 +30,13 @@ import threading
 from typing import Tuple
 from typing import Tuple
 from wsgiref import simple_server
 from wsgiref import simple_server
 
 
-from dulwich.server import DictBackend, ReceivePackHandler, UploadPackHandler
 from dulwich.tests import SkipTest, skipIf
 from dulwich.tests import SkipTest, skipIf
-from dulwich.tests.compat.server_utils import (NoSideBand64kReceivePackHandler,
-                                               ServerTests)
-from dulwich.tests.compat.utils import CompatTestCase
-from dulwich.web import (HTTPGitApplication, WSGIRequestHandlerLogger,
-                         WSGIServerLogger, make_wsgi_chain)
+
+from ...server import DictBackend, ReceivePackHandler, UploadPackHandler
+from ...web import (HTTPGitApplication, WSGIRequestHandlerLogger,
+                    WSGIServerLogger, make_wsgi_chain)
+from .server_utils import NoSideBand64kReceivePackHandler, ServerTests
+from .utils import CompatTestCase
 
 
 
 
 @skipIf(sys.platform == "win32", "Broken on windows, with very long fail time.")
 @skipIf(sys.platform == "win32", "Broken on windows, with very long fail time.")

+ 3 - 2
dulwich/tests/compat/utils.py

@@ -32,10 +32,11 @@ import tempfile
 import time
 import time
 from typing import Tuple
 from typing import Tuple
 
 
-from dulwich.protocol import TCP_GIT_PORT
-from dulwich.repo import Repo
 from dulwich.tests import SkipTest, TestCase
 from dulwich.tests import SkipTest, TestCase
 
 
+from ...protocol import TCP_GIT_PORT
+from ...repo import Repo
+
 _DEFAULT_GIT = "git"
 _DEFAULT_GIT = "git"
 _VERSION_LEN = 4
 _VERSION_LEN = 4
 _REPOS_DATA_DIR = os.path.abspath(
 _REPOS_DATA_DIR = os.path.abspath(

+ 5 - 4
dulwich/tests/test_archive.py

@@ -25,11 +25,12 @@ import tarfile
 from io import BytesIO
 from io import BytesIO
 from unittest import skipUnless
 from unittest import skipUnless
 
 
-from dulwich.archive import tar_stream
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import Blob, Tree
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import build_commit_graph
+
+from ..archive import tar_stream
+from ..object_store import MemoryObjectStore
+from ..objects import Blob, Tree
+from .utils import build_commit_graph
 
 
 try:
 try:
     from unittest.mock import patch
     from unittest.mock import patch

+ 2 - 1
dulwich/tests/test_blackbox.py

@@ -23,9 +23,10 @@
 import shutil
 import shutil
 import tempfile
 import tempfile
 
 
-from dulwich.repo import Repo
 from dulwich.tests import BlackboxTestCase
 from dulwich.tests import BlackboxTestCase
 
 
+from ..repo import Repo
+
 
 
 class GitReceivePackTests(BlackboxTestCase):
 class GitReceivePackTests(BlackboxTestCase):
     """Blackbox tests for dul-receive-pack."""
     """Blackbox tests for dul-receive-pack."""

+ 3 - 2
dulwich/tests/test_bundle.py

@@ -24,10 +24,11 @@ import os
 import tempfile
 import tempfile
 from io import BytesIO
 from io import BytesIO
 
 
-from dulwich.bundle import Bundle, read_bundle, write_bundle
-from dulwich.pack import PackData, write_pack_objects
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
 
 
+from ..bundle import Bundle, read_bundle, write_bundle
+from ..pack import PackData, write_pack_objects
+
 
 
 class BundleTests(TestCase):
 class BundleTests(TestCase):
     def test_roundtrip_bundle(self):
     def test_roundtrip_bundle(self):

+ 16 - 17
dulwich/tests/test_client.py

@@ -31,24 +31,23 @@ from urllib.parse import urlparse
 
 
 import dulwich
 import dulwich
 from dulwich import client
 from dulwich import client
-from dulwich.client import (FetchPackResult, GitProtocolError, HangupException,
-                            HttpGitClient, InvalidWants, LocalGitClient,
-                            PLinkSSHVendor, ReportStatusParser, SendPackError,
-                            SSHGitClient, StrangeHostname, SubprocessSSHVendor,
-                            TCPGitClient, TraditionalGitClient,
-                            _remote_error_from_stderr, check_wants,
-                            default_urllib3_manager,
-                            get_credentials_from_store, get_transport_and_path,
-                            get_transport_and_path_from_url, parse_rsync_url)
-from dulwich.config import ConfigDict
-from dulwich.objects import Commit, Tree
-from dulwich.pack import (pack_objects_to_data, write_pack_data,
-                          write_pack_objects)
-from dulwich.protocol import TCP_GIT_PORT, Protocol
-from dulwich.repo import MemoryRepo, Repo
 from dulwich.tests import TestCase, skipIf
 from dulwich.tests import TestCase, skipIf
-from dulwich.tests.utils import (open_repo, setup_warning_catcher,
-                                 tear_down_repo)
+
+from ..client import (FetchPackResult, GitProtocolError, HangupException,
+                      HttpGitClient, InvalidWants, LocalGitClient,
+                      PLinkSSHVendor, ReportStatusParser, SendPackError,
+                      SSHGitClient, StrangeHostname, SubprocessSSHVendor,
+                      TCPGitClient, TraditionalGitClient,
+                      _remote_error_from_stderr, check_wants,
+                      default_urllib3_manager, get_credentials_from_store,
+                      get_transport_and_path, get_transport_and_path_from_url,
+                      parse_rsync_url)
+from ..config import ConfigDict
+from ..objects import Commit, Tree
+from ..pack import pack_objects_to_data, write_pack_data, write_pack_objects
+from ..protocol import TCP_GIT_PORT, Protocol
+from ..repo import MemoryRepo, Repo
+from .utils import open_repo, setup_warning_catcher, tear_down_repo
 
 
 
 
 class DummyClient(TraditionalGitClient):
 class DummyClient(TraditionalGitClient):

+ 7 - 6
dulwich/tests/test_config.py

@@ -26,12 +26,13 @@ from io import BytesIO
 from unittest import skipIf
 from unittest import skipIf
 from unittest.mock import patch
 from unittest.mock import patch
 
 
-from dulwich.config import (ConfigDict, ConfigFile, StackedConfig,
-                            _check_section_name, _check_variable_name,
-                            _escape_value, _format_string, _parse_string,
-                            apply_instead_of, parse_submodules)
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
 
 
+from ..config import (ConfigDict, ConfigFile, StackedConfig,
+                      _check_section_name, _check_variable_name, _escape_value,
+                      _format_string, _parse_string, apply_instead_of,
+                      parse_submodules)
+
 
 
 class ConfigFileTests(TestCase):
 class ConfigFileTests(TestCase):
     def from_file(self, text):
     def from_file(self, text):
@@ -302,7 +303,7 @@ class StackedConfigTests(TestCase):
 
 
     @skipIf(sys.platform != "win32", "Windows specific config location.")
     @skipIf(sys.platform != "win32", "Windows specific config location.")
     def test_windows_config_from_path(self):
     def test_windows_config_from_path(self):
-        from dulwich.config import get_win_system_paths
+        from ..config import get_win_system_paths
 
 
         install_dir = os.path.join("C:", "foo", "Git")
         install_dir = os.path.join("C:", "foo", "Git")
         self.overrideEnv("PATH", os.path.join(install_dir, "cmd"))
         self.overrideEnv("PATH", os.path.join(install_dir, "cmd"))
@@ -320,7 +321,7 @@ class StackedConfigTests(TestCase):
     def test_windows_config_from_reg(self):
     def test_windows_config_from_reg(self):
         import winreg
         import winreg
 
 
-        from dulwich.config import get_win_system_paths
+        from ..config import get_win_system_paths
 
 
         self.overrideEnv("PATH", None)
         self.overrideEnv("PATH", None)
         install_dir = os.path.join("C:", "foo", "Git")
         install_dir = os.path.join("C:", "foo", "Git")

+ 4 - 3
dulwich/tests/test_credentials.py

@@ -21,11 +21,12 @@
 
 
 from urllib.parse import urlparse
 from urllib.parse import urlparse
 
 
-from dulwich.config import ConfigDict
-from dulwich.credentials import (match_partial_url, match_urls,
-                                 urlmatch_credential_sections)
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
 
 
+from ..config import ConfigDict
+from ..credentials import (match_partial_url, match_urls,
+                           urlmatch_credential_sections)
+
 
 
 class TestCredentialHelpersUtils(TestCase):
 class TestCredentialHelpersUtils(TestCase):
 
 

+ 11 - 11
dulwich/tests/test_diff_tree.py

@@ -22,18 +22,18 @@
 
 
 from itertools import permutations
 from itertools import permutations
 
 
-from dulwich.diff_tree import (CHANGE_COPY, CHANGE_MODIFY, CHANGE_RENAME,
-                               CHANGE_UNCHANGED, RenameDetector, TreeChange,
-                               _count_blocks, _count_blocks_py, _is_tree,
-                               _is_tree_py, _merge_entries, _merge_entries_py,
-                               _similarity_score, _tree_change_key,
-                               tree_changes, tree_changes_for_merge)
-from dulwich.index import commit_tree
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import Blob, ShaFile, Tree, TreeEntry
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import (F, ext_functest_builder, functest_builder,
-                                 make_object)
+
+from ..diff_tree import (CHANGE_COPY, CHANGE_MODIFY, CHANGE_RENAME,
+                         CHANGE_UNCHANGED, RenameDetector, TreeChange,
+                         _count_blocks, _count_blocks_py, _is_tree,
+                         _is_tree_py, _merge_entries, _merge_entries_py,
+                         _similarity_score, _tree_change_key, tree_changes,
+                         tree_changes_for_merge)
+from ..index import commit_tree
+from ..object_store import MemoryObjectStore
+from ..objects import Blob, ShaFile, Tree, TreeEntry
+from .utils import F, ext_functest_builder, functest_builder, make_object
 
 
 
 
 class DiffTestCase(TestCase):
 class DiffTestCase(TestCase):

+ 7 - 6
dulwich/tests/test_fastexport.py

@@ -21,11 +21,12 @@
 import stat
 import stat
 from io import BytesIO
 from io import BytesIO
 
 
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import ZERO_SHA, Blob, Commit, Tree
-from dulwich.repo import MemoryRepo
 from dulwich.tests import SkipTest, TestCase
 from dulwich.tests import SkipTest, TestCase
-from dulwich.tests.utils import build_commit_graph
+
+from ..object_store import MemoryObjectStore
+from ..objects import ZERO_SHA, Blob, Commit, Tree
+from ..repo import MemoryRepo
+from .utils import build_commit_graph
 
 
 
 
 class GitFastExporterTests(TestCase):
 class GitFastExporterTests(TestCase):
@@ -36,7 +37,7 @@ class GitFastExporterTests(TestCase):
         self.store = MemoryObjectStore()
         self.store = MemoryObjectStore()
         self.stream = BytesIO()
         self.stream = BytesIO()
         try:
         try:
-            from dulwich.fastexport import GitFastExporter
+            from ..fastexport import GitFastExporter
         except ImportError as exc:
         except ImportError as exc:
             raise SkipTest("python-fastimport not available") from exc
             raise SkipTest("python-fastimport not available") from exc
         self.fastexporter = GitFastExporter(self.stream, self.store)
         self.fastexporter = GitFastExporter(self.stream, self.store)
@@ -84,7 +85,7 @@ class GitImportProcessorTests(TestCase):
         super().setUp()
         super().setUp()
         self.repo = MemoryRepo()
         self.repo = MemoryRepo()
         try:
         try:
-            from dulwich.fastexport import GitImportProcessor
+            from ..fastexport import GitImportProcessor
         except ImportError as exc:
         except ImportError as exc:
             raise SkipTest("python-fastimport not available") from exc
             raise SkipTest("python-fastimport not available") from exc
         self.processor = GitImportProcessor(self.repo)
         self.processor = GitImportProcessor(self.repo)

+ 2 - 1
dulwich/tests/test_file.py

@@ -24,9 +24,10 @@ import shutil
 import sys
 import sys
 import tempfile
 import tempfile
 
 
-from dulwich.file import FileLocked, GitFile, _fancy_rename
 from dulwich.tests import SkipTest, TestCase
 from dulwich.tests import SkipTest, TestCase
 
 
+from ..file import FileLocked, GitFile, _fancy_rename
+
 
 
 class FancyRenameTests(TestCase):
 class FancyRenameTests(TestCase):
     def setUp(self):
     def setUp(self):

+ 4 - 4
dulwich/tests/test_grafts.py

@@ -23,12 +23,12 @@ import os
 import shutil
 import shutil
 import tempfile
 import tempfile
 
 
-from dulwich.errors import ObjectFormatException
-from dulwich.objects import Tree
-from dulwich.repo import (MemoryRepo, Repo, parse_graftpoints,
-                          serialize_graftpoints)
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
 
 
+from ..errors import ObjectFormatException
+from ..objects import Tree
+from ..repo import MemoryRepo, Repo, parse_graftpoints, serialize_graftpoints
+
 
 
 def makesha(digit):
 def makesha(digit):
     return (str(digit).encode("ascii") * 40)[:40]
     return (str(digit).encode("ascii") * 40)[:40]

+ 4 - 3
dulwich/tests/test_graph.py

@@ -20,10 +20,11 @@
 
 
 """Tests for dulwich.graph."""
 """Tests for dulwich.graph."""
 
 
-from dulwich.graph import _find_lcas, can_fast_forward
-from dulwich.repo import MemoryRepo
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import make_commit
+
+from ..graph import _find_lcas, can_fast_forward
+from ..repo import MemoryRepo
+from .utils import make_commit
 
 
 
 
 class FindMergeBaseTests(TestCase):
 class FindMergeBaseTests(TestCase):

+ 4 - 3
dulwich/tests/test_greenthreads.py

@@ -22,10 +22,11 @@
 
 
 import time
 import time
 
 
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import Blob, Commit, Tree, parse_timezone
 from dulwich.tests import TestCase, skipIf
 from dulwich.tests import TestCase, skipIf
 
 
+from ..object_store import MemoryObjectStore
+from ..objects import Blob, Commit, Tree, parse_timezone
+
 try:
 try:
     import gevent  # noqa: F401
     import gevent  # noqa: F401
 
 
@@ -34,7 +35,7 @@ except ImportError:
     gevent_support = False
     gevent_support = False
 
 
 if gevent_support:
 if gevent_support:
-    from dulwich.greenthreads import GreenThreadsMissingObjectFinder
+    from ..greenthreads import GreenThreadsMissingObjectFinder
 
 
 skipmsg = "Gevent library is not installed"
 skipmsg = "Gevent library is not installed"
 
 

+ 2 - 2
dulwich/tests/test_hooks.py

@@ -26,10 +26,10 @@ import sys
 import tempfile
 import tempfile
 
 
 from dulwich import errors
 from dulwich import errors
-from dulwich.hooks import (CommitMsgShellHook, PostCommitShellHook,
-                           PreCommitShellHook)
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
 
 
+from ..hooks import CommitMsgShellHook, PostCommitShellHook, PreCommitShellHook
+
 
 
 class ShellHookTests(TestCase):
 class ShellHookTests(TestCase):
     def setUp(self):
     def setUp(self):

+ 4 - 4
dulwich/tests/test_ignore.py

@@ -26,12 +26,12 @@ import shutil
 import tempfile
 import tempfile
 from io import BytesIO
 from io import BytesIO
 
 
-from dulwich.ignore import (IgnoreFilter, IgnoreFilterManager,
-                            IgnoreFilterStack, Pattern, match_pattern,
-                            read_ignore_patterns, translate)
-from dulwich.repo import Repo
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
 
 
+from ..ignore import (IgnoreFilter, IgnoreFilterManager, IgnoreFilterStack,
+                      Pattern, match_pattern, read_ignore_patterns, translate)
+from ..repo import Repo
+
 POSITIVE_MATCH_TESTS = [
 POSITIVE_MATCH_TESTS = [
     (b"foo.c", b"*.c"),
     (b"foo.c", b"*.c"),
     (b".c", b"*.c"),
     (b".c", b"*.c"),

+ 10 - 10
dulwich/tests/test_index.py

@@ -30,18 +30,18 @@ import sys
 import tempfile
 import tempfile
 from io import BytesIO
 from io import BytesIO
 
 
-from dulwich.index import (Index, IndexEntry, _fs_to_tree_path,
-                           _tree_to_fs_path, build_index_from_tree,
-                           cleanup_mode, commit_tree, get_unstaged_changes,
-                           index_entry_from_stat, read_index, read_index_dict,
-                           validate_path_element_default,
-                           validate_path_element_ntfs, write_cache_time,
-                           write_index, write_index_dict)
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import S_IFGITLINK, Blob, Commit, Tree
-from dulwich.repo import Repo
 from dulwich.tests import TestCase, skipIf
 from dulwich.tests import TestCase, skipIf
 
 
+from ..index import (Index, IndexEntry, _fs_to_tree_path, _tree_to_fs_path,
+                     build_index_from_tree, cleanup_mode, commit_tree,
+                     get_unstaged_changes, index_entry_from_stat, read_index,
+                     read_index_dict, validate_path_element_default,
+                     validate_path_element_ntfs, write_cache_time, write_index,
+                     write_index_dict)
+from ..object_store import MemoryObjectStore
+from ..objects import S_IFGITLINK, Blob, Commit, Tree
+from ..repo import Repo
+
 
 
 def can_symlink():
 def can_symlink():
     """Return whether running process can create symlinks."""
     """Return whether running process can create symlinks."""

+ 5 - 4
dulwich/tests/test_line_ending.py

@@ -21,12 +21,13 @@
 
 
 """Tests for the line ending conversion."""
 """Tests for the line ending conversion."""
 
 
-from dulwich.line_ending import (convert_crlf_to_lf, convert_lf_to_crlf,
-                                 get_checkin_filter_autocrlf,
-                                 get_checkout_filter_autocrlf, normalize_blob)
-from dulwich.objects import Blob
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
 
 
+from ..line_ending import (convert_crlf_to_lf, convert_lf_to_crlf,
+                           get_checkin_filter_autocrlf,
+                           get_checkout_filter_autocrlf, normalize_blob)
+from ..objects import Blob
+
 
 
 class LineEndingConversion(TestCase):
 class LineEndingConversion(TestCase):
     """Test the line ending conversion functions in various cases"""
     """Test the line ending conversion functions in various cases"""

+ 1 - 1
dulwich/tests/test_mailmap.py

@@ -23,7 +23,7 @@
 from io import BytesIO
 from io import BytesIO
 from unittest import TestCase
 from unittest import TestCase
 
 
-from dulwich.mailmap import Mailmap, read_mailmap
+from ..mailmap import Mailmap, read_mailmap
 
 
 
 
 class ReadMailmapTests(TestCase):
 class ReadMailmapTests(TestCase):

+ 4 - 3
dulwich/tests/test_missing_obj_finder.py

@@ -18,10 +18,11 @@
 # License, Version 2.0.
 # License, Version 2.0.
 #
 #
 
 
-from dulwich.object_store import MemoryObjectStore, MissingObjectFinder
-from dulwich.objects import Blob
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import build_commit_graph, make_object, make_tag
+
+from ..object_store import MemoryObjectStore, MissingObjectFinder
+from ..objects import Blob
+from .utils import build_commit_graph, make_object, make_tag
 
 
 
 
 class MissingObjectFinderTest(TestCase):
 class MissingObjectFinderTest(TestCase):

+ 12 - 11
dulwich/tests/test_object_store.py

@@ -30,18 +30,19 @@ from contextlib import closing
 from io import BytesIO
 from io import BytesIO
 from unittest import skipUnless
 from unittest import skipUnless
 
 
-from dulwich.errors import NotTreeError
-from dulwich.index import commit_tree
-from dulwich.object_store import (DiskObjectStore, MemoryObjectStore,
-                                  ObjectStoreGraphWalker, OverlayObjectStore,
-                                  commit_tree_changes, iter_tree_contents,
-                                  peel_sha, read_packs_file, tree_lookup_path)
-from dulwich.objects import (S_IFGITLINK, Blob, EmptyFileException,
-                             SubmoduleEncountered, Tree, TreeEntry, sha_to_hex)
-from dulwich.pack import REF_DELTA, write_pack_objects
-from dulwich.protocol import DEPTH_INFINITE
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import build_pack, make_object, make_tag
+
+from ..errors import NotTreeError
+from ..index import commit_tree
+from ..object_store import (DiskObjectStore, MemoryObjectStore,
+                            ObjectStoreGraphWalker, OverlayObjectStore,
+                            commit_tree_changes, iter_tree_contents, peel_sha,
+                            read_packs_file, tree_lookup_path)
+from ..objects import (S_IFGITLINK, Blob, EmptyFileException,
+                       SubmoduleEncountered, Tree, TreeEntry, sha_to_hex)
+from ..pack import REF_DELTA, write_pack_objects
+from ..protocol import DEPTH_INFINITE
+from .utils import build_pack, make_object, make_tag
 
 
 try:
 try:
     from unittest.mock import patch
     from unittest.mock import patch

+ 9 - 10
dulwich/tests/test_objects.py

@@ -30,17 +30,16 @@ from contextlib import contextmanager
 from io import BytesIO
 from io import BytesIO
 from itertools import permutations
 from itertools import permutations
 
 
-from dulwich.errors import ObjectFormatException
-from dulwich.objects import (MAX_TIME, Blob, Commit, ShaFile, Tag, Tree,
-                             TreeEntry, _parse_tree_py, _sorted_tree_items_py,
-                             check_hexsha, check_identity, format_timezone,
-                             hex_to_filename, hex_to_sha, object_class,
-                             parse_timezone, parse_tree,
-                             pretty_format_tree_entry, sha_to_hex,
-                             sorted_tree_items)
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import (ext_functest_builder, functest_builder,
-                                 make_commit, make_object)
+
+from ..errors import ObjectFormatException
+from ..objects import (MAX_TIME, Blob, Commit, ShaFile, Tag, Tree, TreeEntry,
+                       _parse_tree_py, _sorted_tree_items_py, check_hexsha,
+                       check_identity, format_timezone, hex_to_filename,
+                       hex_to_sha, object_class, parse_timezone, parse_tree,
+                       pretty_format_tree_entry, sha_to_hex, sorted_tree_items)
+from .utils import (ext_functest_builder, functest_builder, make_commit,
+                    make_object)
 
 
 a_sha = b"6f670c0fb53f9463760b7295fbb814e965fb20c8"
 a_sha = b"6f670c0fb53f9463760b7295fbb814e965fb20c8"
 b_sha = b"2969be3e8ee1c0222396a5611407e4769f14e54b"
 b_sha = b"2969be3e8ee1c0222396a5611407e4769f14e54b"

+ 7 - 6
dulwich/tests/test_objectspec.py

@@ -23,13 +23,14 @@
 # TODO: Round-trip parse-serialize-parse and serialize-parse-serialize tests.
 # TODO: Round-trip parse-serialize-parse and serialize-parse-serialize tests.
 
 
 
 
-from dulwich.objects import Blob
-from dulwich.objectspec import (parse_commit, parse_commit_range, parse_object,
-                                parse_ref, parse_refs, parse_reftuple,
-                                parse_reftuples, parse_tree)
-from dulwich.repo import MemoryRepo
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import build_commit_graph
+
+from ..objects import Blob
+from ..objectspec import (parse_commit, parse_commit_range, parse_object,
+                          parse_ref, parse_refs, parse_reftuple,
+                          parse_reftuples, parse_tree)
+from ..repo import MemoryRepo
+from .utils import build_commit_graph
 
 
 
 
 class ParseObjectTests(TestCase):
 class ParseObjectTests(TestCase):

+ 13 - 13
dulwich/tests/test_pack.py

@@ -30,20 +30,20 @@ import zlib
 from hashlib import sha1
 from hashlib import sha1
 from io import BytesIO
 from io import BytesIO
 
 
-from dulwich.errors import ApplyDeltaError, ChecksumMismatch
-from dulwich.file import GitFile
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import Blob, Commit, Tree, hex_to_sha, sha_to_hex
-from dulwich.pack import (OFS_DELTA, REF_DELTA, DeltaChainIterator,
-                          MemoryPackIndex, Pack, PackData, PackStreamReader,
-                          UnpackedObject, _delta_encode_size,
-                          _encode_copy_operation, apply_delta,
-                          compute_file_sha, create_delta, deltify_pack_objects,
-                          load_pack_index, read_zlib_chunks, unpack_object,
-                          write_pack, write_pack_header, write_pack_index_v1,
-                          write_pack_index_v2, write_pack_object)
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import build_pack, make_object
+
+from ..errors import ApplyDeltaError, ChecksumMismatch
+from ..file import GitFile
+from ..object_store import MemoryObjectStore
+from ..objects import Blob, Commit, Tree, hex_to_sha, sha_to_hex
+from ..pack import (OFS_DELTA, REF_DELTA, DeltaChainIterator, MemoryPackIndex,
+                    Pack, PackData, PackStreamReader, UnpackedObject,
+                    _delta_encode_size, _encode_copy_operation, apply_delta,
+                    compute_file_sha, create_delta, deltify_pack_objects,
+                    load_pack_index, read_zlib_chunks, unpack_object,
+                    write_pack, write_pack_header, write_pack_index_v1,
+                    write_pack_index_v2, write_pack_object)
+from .utils import build_pack, make_object
 
 
 pack1_sha = b"bc63ddad95e7321ee734ea11a7a62d314e0d7481"
 pack1_sha = b"bc63ddad95e7321ee734ea11a7a62d314e0d7481"
 
 

+ 5 - 5
dulwich/tests/test_patch.py

@@ -22,13 +22,13 @@
 
 
 from io import BytesIO, StringIO
 from io import BytesIO, StringIO
 
 
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import S_IFGITLINK, Blob, Commit, Tree
-from dulwich.patch import (get_summary, git_am_patch_split, write_blob_diff,
-                           write_commit_patch, write_object_diff,
-                           write_tree_diff)
 from dulwich.tests import SkipTest, TestCase
 from dulwich.tests import SkipTest, TestCase
 
 
+from ..object_store import MemoryObjectStore
+from ..objects import S_IFGITLINK, Blob, Commit, Tree
+from ..patch import (get_summary, git_am_patch_split, write_blob_diff,
+                     write_commit_patch, write_object_diff, write_tree_diff)
+
 
 
 class WriteCommitPatchTests(TestCase):
 class WriteCommitPatchTests(TestCase):
     def test_simple_bytesio(self):
     def test_simple_bytesio(self):

+ 9 - 8
dulwich/tests/test_porcelain.py

@@ -36,15 +36,16 @@ from io import BytesIO, StringIO
 from unittest import skipIf
 from unittest import skipIf
 
 
 from dulwich import porcelain
 from dulwich import porcelain
-from dulwich.diff_tree import tree_changes
-from dulwich.errors import CommitError
-from dulwich.objects import ZERO_SHA, Blob, Tag, Tree
-from dulwich.porcelain import CheckoutError
-from dulwich.repo import NoIndexPresent, Repo
-from dulwich.server import DictBackend
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import build_commit_graph, make_commit, make_object
-from dulwich.web import make_server, make_wsgi_chain
+
+from ..diff_tree import tree_changes
+from ..errors import CommitError
+from ..objects import ZERO_SHA, Blob, Tag, Tree
+from ..porcelain import CheckoutError
+from ..repo import NoIndexPresent, Repo
+from ..server import DictBackend
+from ..web import make_server, make_wsgi_chain
+from .utils import build_commit_graph, make_commit, make_object
 
 
 try:
 try:
     import gpg
     import gpg

+ 6 - 6
dulwich/tests/test_protocol.py

@@ -23,14 +23,14 @@
 
 
 from io import BytesIO
 from io import BytesIO
 
 
-from dulwich.errors import HangupException
-from dulwich.protocol import (MULTI_ACK, MULTI_ACK_DETAILED, SINGLE_ACK,
-                              BufferedPktLineWriter, GitProtocolError,
-                              PktLineParser, Protocol, ReceivableProtocol,
-                              ack_type, extract_capabilities,
-                              extract_want_line_capabilities)
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
 
 
+from ..errors import HangupException
+from ..protocol import (MULTI_ACK, MULTI_ACK_DETAILED, SINGLE_ACK,
+                        BufferedPktLineWriter, GitProtocolError, PktLineParser,
+                        Protocol, ReceivableProtocol, ack_type,
+                        extract_capabilities, extract_want_line_capabilities)
+
 
 
 class BaseProtocolTests:
 class BaseProtocolTests:
     def test_write_pkt_line_none(self):
     def test_write_pkt_line_none(self):

+ 4 - 3
dulwich/tests/test_reflog.py

@@ -22,11 +22,12 @@
 
 
 from io import BytesIO
 from io import BytesIO
 
 
-from dulwich.objects import ZERO_SHA
-from dulwich.reflog import (drop_reflog_entry, format_reflog_line,
-                            parse_reflog_line, read_reflog)
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
 
 
+from ..objects import ZERO_SHA
+from ..reflog import (drop_reflog_entry, format_reflog_line, parse_reflog_line,
+                      read_reflog)
+
 
 
 class ReflogLineTests(TestCase):
 class ReflogLineTests(TestCase):
     def test_format(self):
     def test_format(self):

+ 9 - 9
dulwich/tests/test_refs.py

@@ -26,16 +26,16 @@ import tempfile
 from io import BytesIO
 from io import BytesIO
 
 
 from dulwich import errors
 from dulwich import errors
-from dulwich.file import GitFile
-from dulwich.objects import ZERO_SHA
-from dulwich.refs import (DictRefsContainer, InfoRefsContainer, SymrefLoop,
-                          _split_ref_line, check_ref_format,
-                          parse_symref_value, read_packed_refs,
-                          read_packed_refs_with_peeled, strip_peeled_refs,
-                          write_packed_refs)
-from dulwich.repo import Repo
 from dulwich.tests import SkipTest, TestCase
 from dulwich.tests import SkipTest, TestCase
-from dulwich.tests.utils import open_repo, tear_down_repo
+
+from ..file import GitFile
+from ..objects import ZERO_SHA
+from ..refs import (DictRefsContainer, InfoRefsContainer, SymrefLoop,
+                    _split_ref_line, check_ref_format, parse_symref_value,
+                    read_packed_refs, read_packed_refs_with_peeled,
+                    strip_peeled_refs, write_packed_refs)
+from ..repo import Repo
+from .utils import open_repo, tear_down_repo
 
 
 
 
 class CheckRefFormatTests(TestCase):
 class CheckRefFormatTests(TestCase):

+ 8 - 8
dulwich/tests/test_repository.py

@@ -30,15 +30,15 @@ import tempfile
 import warnings
 import warnings
 
 
 from dulwich import errors, objects, porcelain
 from dulwich import errors, objects, porcelain
-from dulwich.config import Config
-from dulwich.errors import NotGitRepository
-from dulwich.object_store import tree_lookup_path
-from dulwich.repo import (InvalidUserIdentity, MemoryRepo, Repo,
-                          UnsupportedExtension, UnsupportedVersion,
-                          check_user_identity)
 from dulwich.tests import TestCase, skipIf
 from dulwich.tests import TestCase, skipIf
-from dulwich.tests.utils import (open_repo, setup_warning_catcher,
-                                 tear_down_repo)
+
+from ..config import Config
+from ..errors import NotGitRepository
+from ..object_store import tree_lookup_path
+from ..repo import (InvalidUserIdentity, MemoryRepo, Repo,
+                    UnsupportedExtension, UnsupportedVersion,
+                    check_user_identity)
+from .utils import open_repo, setup_warning_catcher, tear_down_repo
 
 
 missing_sha = b"b91fa4d900e17e99b433218e988c4eb4a3e9a097"
 missing_sha = b"b91fa4d900e17e99b433218e988c4eb4a3e9a097"
 
 

+ 14 - 14
dulwich/tests/test_server.py

@@ -26,21 +26,21 @@ import sys
 import tempfile
 import tempfile
 from io import BytesIO
 from io import BytesIO
 
 
-from dulwich.errors import (GitProtocolError, HangupException,
-                            NotGitRepository, UnexpectedCommandError)
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import Tree
-from dulwich.protocol import ZERO_SHA, format_capability_line
-from dulwich.repo import MemoryRepo, Repo
-from dulwich.server import (Backend, DictBackend, FileSystemBackend,
-                            MultiAckDetailedGraphWalkerImpl,
-                            MultiAckGraphWalkerImpl, PackHandler,
-                            ReceivePackHandler, SingleAckGraphWalkerImpl,
-                            UploadPackHandler, _find_shallow,
-                            _ProtocolGraphWalker, _split_proto_line,
-                            serve_command, update_server_info)
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import make_commit, make_tag
+
+from ..errors import (GitProtocolError, HangupException, NotGitRepository,
+                      UnexpectedCommandError)
+from ..object_store import MemoryObjectStore
+from ..objects import Tree
+from ..protocol import ZERO_SHA, format_capability_line
+from ..repo import MemoryRepo, Repo
+from ..server import (Backend, DictBackend, FileSystemBackend,
+                      MultiAckDetailedGraphWalkerImpl, MultiAckGraphWalkerImpl,
+                      PackHandler, ReceivePackHandler,
+                      SingleAckGraphWalkerImpl, UploadPackHandler,
+                      _find_shallow, _ProtocolGraphWalker, _split_proto_line,
+                      serve_command, update_server_info)
+from .utils import make_commit, make_tag
 
 
 ONE = b"1" * 40
 ONE = b"1" * 40
 TWO = b"2" * 40
 TWO = b"2" * 40

+ 4 - 3
dulwich/tests/test_utils.py

@@ -20,10 +20,11 @@
 
 
 """Tests for git test utilities."""
 """Tests for git test utilities."""
 
 
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import Blob
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import build_commit_graph, make_object
+
+from ..object_store import MemoryObjectStore
+from ..objects import Blob
+from .utils import build_commit_graph, make_object
 
 
 
 
 class BuildCommitGraphTest(TestCase):
 class BuildCommitGraphTest(TestCase):

+ 8 - 7
dulwich/tests/test_walk.py

@@ -23,14 +23,15 @@
 from itertools import permutations
 from itertools import permutations
 from unittest import expectedFailure
 from unittest import expectedFailure
 
 
-from dulwich.diff_tree import (CHANGE_MODIFY, CHANGE_RENAME, RenameDetector,
-                               TreeChange)
-from dulwich.errors import MissingCommitError
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import Blob, Commit
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import F, build_commit_graph, make_object, make_tag
-from dulwich.walk import ORDER_TOPO, WalkEntry, Walker, _topo_reorder
+
+from ..diff_tree import (CHANGE_MODIFY, CHANGE_RENAME, RenameDetector,
+                         TreeChange)
+from ..errors import MissingCommitError
+from ..object_store import MemoryObjectStore
+from ..objects import Blob, Commit
+from ..walk import ORDER_TOPO, WalkEntry, Walker, _topo_reorder
+from .utils import F, build_commit_graph, make_object, make_tag
 
 
 
 
 class TestWalkEntry:
 class TestWalkEntry:

+ 11 - 10
dulwich/tests/test_web.py

@@ -26,17 +26,18 @@ import re
 from io import BytesIO
 from io import BytesIO
 from typing import Type
 from typing import Type
 
 
-from dulwich.object_store import MemoryObjectStore
-from dulwich.objects import Blob
-from dulwich.repo import BaseRepo, MemoryRepo
-from dulwich.server import DictBackend
 from dulwich.tests import TestCase
 from dulwich.tests import TestCase
-from dulwich.tests.utils import make_object, make_tag
-from dulwich.web import (HTTP_ERROR, HTTP_FORBIDDEN, HTTP_NOT_FOUND, HTTP_OK,
-                         GunzipFilter, HTTPGitApplication, HTTPGitRequest,
-                         _LengthLimitedFile, get_idx_file, get_info_packs,
-                         get_info_refs, get_loose_object, get_pack_file,
-                         get_text_file, handle_service_request, send_file)
+
+from ..object_store import MemoryObjectStore
+from ..objects import Blob
+from ..repo import BaseRepo, MemoryRepo
+from ..server import DictBackend
+from ..web import (HTTP_ERROR, HTTP_FORBIDDEN, HTTP_NOT_FOUND, HTTP_OK,
+                   GunzipFilter, HTTPGitApplication, HTTPGitRequest,
+                   _LengthLimitedFile, get_idx_file, get_info_packs,
+                   get_info_refs, get_loose_object, get_pack_file,
+                   get_text_file, handle_service_request, send_file)
+from .utils import make_object, make_tag
 
 
 
 
 class MinimalistWSGIInputStream:
 class MinimalistWSGIInputStream:

+ 7 - 6
dulwich/tests/utils.py

@@ -29,14 +29,15 @@ import time
 import types
 import types
 import warnings
 import warnings
 
 
-from dulwich.index import commit_tree
-from dulwich.objects import Commit, FixedSha, Tag, object_class
-from dulwich.pack import (DELTA_TYPES, OFS_DELTA, REF_DELTA, SHA1Writer,
-                          create_delta, obj_sha, write_pack_header,
-                          write_pack_object)
-from dulwich.repo import Repo
 from dulwich.tests import SkipTest, skipIf  # noqa: F401
 from dulwich.tests import SkipTest, skipIf  # noqa: F401
 
 
+from ..index import commit_tree
+from ..objects import Commit, FixedSha, Tag, object_class
+from ..pack import (DELTA_TYPES, OFS_DELTA, REF_DELTA, SHA1Writer,
+                    create_delta, obj_sha, write_pack_header,
+                    write_pack_object)
+from ..repo import Repo
+
 # Plain files are very frequently used in tests, so let the mode be very short.
 # Plain files are very frequently used in tests, so let the mode be very short.
 F = 0o100644  # Shorthand mode for Files.
 F = 0o100644  # Shorthand mode for Files.
 
 

+ 4 - 4
dulwich/walk.py

@@ -26,10 +26,10 @@ import heapq
 from itertools import chain
 from itertools import chain
 from typing import Deque, List, Optional, Set, Tuple
 from typing import Deque, List, Optional, Set, Tuple
 
 
-from dulwich.diff_tree import (RENAME_CHANGE_TYPES, RenameDetector,
-                               tree_changes, tree_changes_for_merge)
-from dulwich.errors import MissingCommitError
-from dulwich.objects import Commit, ObjectID, Tag
+from .diff_tree import (RENAME_CHANGE_TYPES, RenameDetector, tree_changes,
+                        tree_changes_for_merge)
+from .errors import MissingCommitError
+from .objects import Commit, ObjectID, Tag
 
 
 ORDER_DATE = "date"
 ORDER_DATE = "date"
 ORDER_TOPO = "topo"
 ORDER_TOPO = "topo"

+ 5 - 4
dulwich/web.py

@@ -32,10 +32,11 @@ from wsgiref.simple_server import (ServerHandler, WSGIRequestHandler,
                                    WSGIServer, make_server)
                                    WSGIServer, make_server)
 
 
 from dulwich import log_utils
 from dulwich import log_utils
-from dulwich.protocol import ReceivableProtocol
-from dulwich.repo import BaseRepo, NotGitRepository, Repo
-from dulwich.server import (DEFAULT_HANDLERS, DictBackend, generate_info_refs,
-                            generate_objects_info_packs)
+
+from .protocol import ReceivableProtocol
+from .repo import BaseRepo, NotGitRepository, Repo
+from .server import (DEFAULT_HANDLERS, DictBackend, generate_info_refs,
+                     generate_objects_info_packs)
 
 
 logger = log_utils.getLogger(__name__)
 logger = log_utils.getLogger(__name__)