kodit 0.2.7__tar.gz → 0.2.9__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of kodit might be problematic. Click here for more details.

Files changed (219) hide show
  1. kodit-0.2.9/.cursor/rules/style.mdc +11 -0
  2. {kodit-0.2.7 → kodit-0.2.9}/PKG-INFO +1 -1
  3. kodit-0.2.9/docs/reference/mcp/index.md +217 -0
  4. {kodit-0.2.7 → kodit-0.2.9}/pyproject.toml +0 -1
  5. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/_version.py +2 -2
  6. kodit-0.2.9/src/kodit/application/factories/__init__.py +1 -0
  7. kodit-0.2.9/src/kodit/application/factories/code_indexing_factory.py +119 -0
  8. kodit-0.2.7/src/kodit/application/services/indexing_application_service.py → kodit-0.2.9/src/kodit/application/services/code_indexing_application_service.py +159 -198
  9. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/cli.py +199 -62
  10. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/entities.py +7 -5
  11. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/repositories.py +33 -0
  12. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/services/bm25_service.py +14 -17
  13. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/services/embedding_service.py +10 -14
  14. kodit-0.2.9/src/kodit/domain/services/snippet_service.py +198 -0
  15. kodit-0.2.9/src/kodit/domain/value_objects.py +495 -0
  16. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/bm25/local_bm25_repository.py +20 -12
  17. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/bm25/vectorchord_bm25_repository.py +31 -11
  18. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/cloning/git/working_copy.py +5 -2
  19. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/cloning/metadata.py +1 -0
  20. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/embedding/embedding_providers/hash_embedding_provider.py +14 -25
  21. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/embedding/local_vector_search_repository.py +26 -38
  22. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/embedding/vectorchord_vector_search_repository.py +50 -35
  23. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/enrichment/enrichment_factory.py +1 -1
  24. kodit-0.2.9/src/kodit/infrastructure/indexing/indexing_factory.py +30 -0
  25. kodit-0.2.9/src/kodit/infrastructure/indexing/snippet_domain_service_factory.py +37 -0
  26. kodit-0.2.9/src/kodit/infrastructure/snippet_extraction/languages/java.scm +12 -0
  27. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/snippet_extraction_factory.py +3 -31
  28. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/sqlalchemy/embedding_repository.py +14 -3
  29. kodit-0.2.9/src/kodit/infrastructure/sqlalchemy/snippet_repository.py +251 -0
  30. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/mcp.py +61 -49
  31. {kodit-0.2.7 → kodit-0.2.9}/tests/conftest.py +4 -15
  32. kodit-0.2.9/tests/experiments/__init__.py +1 -0
  33. kodit-0.2.9/tests/experiments/cline_prompt_tests/__init__.py +1 -0
  34. {kodit-0.2.7/tests/experiments/cline-prompt-regression-tests → kodit-0.2.9/tests/experiments/cline_prompt_tests}/cline_prompt_test.py +38 -24
  35. kodit-0.2.9/tests/kodit/application/test_code_indexing_application_service.py +499 -0
  36. kodit-0.2.9/tests/kodit/cli_test.py +555 -0
  37. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/domain/bm25_domain_service_test.py +50 -91
  38. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/domain/enrichment_domain_service_test.py +29 -25
  39. kodit-0.2.9/tests/kodit/domain/snippet_domain_service_test.py +266 -0
  40. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/domain/snippet_extraction_domain_service_test.py +7 -5
  41. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/domain/test_embedding_service.py +70 -54
  42. kodit-0.2.9/tests/kodit/domain/test_language_mapping.py +181 -0
  43. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/e2e.py +5 -12
  44. kodit-0.2.9/tests/kodit/infrastructure/cloning/git_cloning/__init__.py +1 -0
  45. {kodit-0.2.7/tests/kodit/infrastructure/cloning/git → kodit-0.2.9/tests/kodit/infrastructure/cloning/git_cloning}/factory_test.py +58 -62
  46. {kodit-0.2.7/tests/kodit/infrastructure/cloning/git → kodit-0.2.9/tests/kodit/infrastructure/cloning/git_cloning}/working_copy_test.py +68 -35
  47. kodit-0.2.9/tests/kodit/infrastructure/embedding/__init__.py +1 -0
  48. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/embedding/embedding_factory_test.py +5 -2
  49. kodit-0.2.9/tests/kodit/infrastructure/embedding/embedding_provider/__init__.py +1 -0
  50. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/embedding/embedding_provider/test_hash_embedding_provider.py +26 -25
  51. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/embedding/embedding_provider/test_local_embedding_provider.py +21 -97
  52. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/embedding/embedding_provider/test_openai_embedding_provider.py +16 -15
  53. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/embedding/test_batching.py +3 -4
  54. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/embedding/test_embedding_integration.py +99 -86
  55. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/embedding/test_local_vector_search_repository.py +198 -52
  56. kodit-0.2.9/tests/kodit/infrastructure/embedding/test_vectorchord_vector_search_repository.py +677 -0
  57. kodit-0.2.9/tests/kodit/infrastructure/enrichment/__init__.py +1 -0
  58. kodit-0.2.9/tests/kodit/infrastructure/enrichment/enrichment_provider/__init__.py +1 -0
  59. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/enrichment/enrichment_provider/test_local_enrichment_provider.py +26 -35
  60. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/enrichment/enrichment_provider/test_null_enrichment_provider.py +12 -22
  61. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/enrichment/enrichment_provider/test_openai_enrichment_provider.py +38 -49
  62. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/enrichment/test_enrichment_factory.py +30 -23
  63. kodit-0.2.9/tests/kodit/infrastructure/git/__init__.py +1 -0
  64. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/git/test_git_utils.py +14 -14
  65. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/indexing/indexing_repository_test.py +18 -3
  66. kodit-0.2.7/tests/kodit/infrastructure/snippets/knock-knock-server.py → kodit-0.2.9/tests/kodit/infrastructure/snippets/knock_knock_server.py +11 -4
  67. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/source/source_service_test.py +6 -11
  68. kodit-0.2.9/tests/kodit/infrastructure/sqlalchemy/__init__.py +1 -0
  69. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/sqlalchemy/test_embedding_repository.py +144 -19
  70. kodit-0.2.9/tests/kodit/infrastructure/sqlalchemy/test_snippet_repository.py +354 -0
  71. kodit-0.2.9/tests/kodit/infrastructure/test_vectorchord_bm25_repository.py +540 -0
  72. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/log_test.py +3 -1
  73. kodit-0.2.9/tests/performance/__init__.py +1 -0
  74. {kodit-0.2.7 → kodit-0.2.9}/tests/performance/similarity.py +49 -30
  75. {kodit-0.2.7 → kodit-0.2.9}/tests/smoke.sh +9 -0
  76. kodit-0.2.7/src/kodit/application/commands/__init__.py +0 -1
  77. kodit-0.2.7/src/kodit/application/commands/snippet_commands.py +0 -22
  78. kodit-0.2.7/src/kodit/application/services/snippet_application_service.py +0 -149
  79. kodit-0.2.7/src/kodit/domain/value_objects.py +0 -215
  80. kodit-0.2.7/src/kodit/infrastructure/enrichment/legacy_enrichment_models.py +0 -42
  81. kodit-0.2.7/src/kodit/infrastructure/indexing/indexing_factory.py +0 -113
  82. kodit-0.2.7/src/kodit/infrastructure/sqlalchemy/snippet_repository.py +0 -79
  83. kodit-0.2.7/tests/experiments/embedding.py +0 -89
  84. kodit-0.2.7/tests/experiments/similarity_test.py +0 -73
  85. kodit-0.2.7/tests/kodit/application/indexing_application_service_test.py +0 -416
  86. kodit-0.2.7/tests/kodit/application/snippet_application_service_test.py +0 -161
  87. kodit-0.2.7/tests/kodit/cli_test.py +0 -69
  88. kodit-0.2.7/tests/kodit/domain/test_models.py +0 -160
  89. kodit-0.2.7/tests/kodit/infrastructure/embedding/__init__.py +0 -0
  90. kodit-0.2.7/tests/kodit/infrastructure/embedding/test_vectorchord_vector_search_repository.py +0 -443
  91. kodit-0.2.7/tests/kodit/infrastructure/enrichment/__init__.py +0 -0
  92. kodit-0.2.7/tests/kodit/infrastructure/enrichment/enrichment_provider/__init__.py +0 -0
  93. kodit-0.2.7/tests/kodit/infrastructure/enrichment/test_enrichment_integration.py +0 -239
  94. {kodit-0.2.7 → kodit-0.2.9}/.cursor/rules/kodit.mdc +0 -0
  95. {kodit-0.2.7 → kodit-0.2.9}/.dockerignore +0 -0
  96. {kodit-0.2.7 → kodit-0.2.9}/.github/CODE_OF_CONDUCT.md +0 -0
  97. {kodit-0.2.7 → kodit-0.2.9}/.github/CONTRIBUTING.md +0 -0
  98. {kodit-0.2.7 → kodit-0.2.9}/.github/ISSUE_TEMPLATE/bug_report.md +0 -0
  99. {kodit-0.2.7 → kodit-0.2.9}/.github/ISSUE_TEMPLATE/feature_request.md +0 -0
  100. {kodit-0.2.7 → kodit-0.2.9}/.github/PULL_REQUEST_TEMPLATE.md +0 -0
  101. {kodit-0.2.7 → kodit-0.2.9}/.github/dependabot.yml +0 -0
  102. {kodit-0.2.7 → kodit-0.2.9}/.github/workflows/docker.yaml +0 -0
  103. {kodit-0.2.7 → kodit-0.2.9}/.github/workflows/docs.yaml +0 -0
  104. {kodit-0.2.7 → kodit-0.2.9}/.github/workflows/pull_request.yaml +0 -0
  105. {kodit-0.2.7 → kodit-0.2.9}/.github/workflows/pypi-test.yaml +0 -0
  106. {kodit-0.2.7 → kodit-0.2.9}/.github/workflows/pypi.yaml +0 -0
  107. {kodit-0.2.7 → kodit-0.2.9}/.github/workflows/test.yaml +0 -0
  108. {kodit-0.2.7 → kodit-0.2.9}/.gitignore +0 -0
  109. {kodit-0.2.7 → kodit-0.2.9}/.python-version +0 -0
  110. {kodit-0.2.7 → kodit-0.2.9}/.vscode/launch.json +0 -0
  111. {kodit-0.2.7 → kodit-0.2.9}/.vscode/settings.json +0 -0
  112. {kodit-0.2.7 → kodit-0.2.9}/Dockerfile +0 -0
  113. {kodit-0.2.7 → kodit-0.2.9}/LICENSE +0 -0
  114. {kodit-0.2.7 → kodit-0.2.9}/README.md +0 -0
  115. {kodit-0.2.7 → kodit-0.2.9}/alembic.ini +0 -0
  116. {kodit-0.2.7 → kodit-0.2.9}/docs/_index.md +0 -0
  117. {kodit-0.2.7 → kodit-0.2.9}/docs/demos/_index.md +0 -0
  118. {kodit-0.2.7 → kodit-0.2.9}/docs/demos/go-simple-microservice/index.md +0 -0
  119. {kodit-0.2.7 → kodit-0.2.9}/docs/demos/knock-knock-auth/index.md +0 -0
  120. {kodit-0.2.7 → kodit-0.2.9}/docs/developer/index.md +0 -0
  121. {kodit-0.2.7 → kodit-0.2.9}/docs/getting-started/_index.md +0 -0
  122. {kodit-0.2.7 → kodit-0.2.9}/docs/getting-started/installation/index.md +0 -0
  123. {kodit-0.2.7 → kodit-0.2.9}/docs/getting-started/integration/index.md +0 -0
  124. {kodit-0.2.7 → kodit-0.2.9}/docs/getting-started/quick-start/index.md +0 -0
  125. {kodit-0.2.7 → kodit-0.2.9}/docs/reference/_index.md +0 -0
  126. {kodit-0.2.7 → kodit-0.2.9}/docs/reference/configuration/index.md +0 -0
  127. {kodit-0.2.7 → kodit-0.2.9}/docs/reference/deployment/docker-compose.yaml +0 -0
  128. {kodit-0.2.7 → kodit-0.2.9}/docs/reference/deployment/index.md +0 -0
  129. {kodit-0.2.7 → kodit-0.2.9}/docs/reference/deployment/kubernetes.yaml +0 -0
  130. {kodit-0.2.7 → kodit-0.2.9}/docs/reference/indexing/index.md +0 -0
  131. {kodit-0.2.7 → kodit-0.2.9}/docs/reference/telemetry/index.md +0 -0
  132. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/.gitignore +0 -0
  133. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/__init__.py +0 -0
  134. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/app.py +0 -0
  135. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/application/__init__.py +0 -0
  136. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/application/services/__init__.py +0 -0
  137. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/config.py +0 -0
  138. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/database.py +0 -0
  139. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/__init__.py +0 -0
  140. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/enums.py +0 -0
  141. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/errors.py +0 -0
  142. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/interfaces.py +0 -0
  143. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/services/__init__.py +0 -0
  144. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/services/enrichment_service.py +0 -0
  145. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/services/ignore_service.py +0 -0
  146. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/services/indexing_service.py +0 -0
  147. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/services/snippet_extraction_service.py +0 -0
  148. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/domain/services/source_service.py +0 -0
  149. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/__init__.py +0 -0
  150. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/bm25/__init__.py +0 -0
  151. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/bm25/bm25_factory.py +0 -0
  152. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/cloning/__init__.py +0 -0
  153. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/cloning/folder/__init__.py +0 -0
  154. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/cloning/folder/factory.py +0 -0
  155. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/cloning/folder/working_copy.py +0 -0
  156. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/cloning/git/__init__.py +0 -0
  157. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/cloning/git/factory.py +0 -0
  158. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/embedding/__init__.py +0 -0
  159. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/embedding/embedding_factory.py +0 -0
  160. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/embedding/embedding_providers/__init__.py +0 -0
  161. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/embedding/embedding_providers/batching.py +0 -0
  162. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/embedding/embedding_providers/local_embedding_provider.py +0 -0
  163. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/embedding/embedding_providers/openai_embedding_provider.py +0 -0
  164. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/enrichment/__init__.py +0 -0
  165. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/enrichment/local_enrichment_provider.py +0 -0
  166. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/enrichment/null_enrichment_provider.py +0 -0
  167. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/enrichment/openai_enrichment_provider.py +0 -0
  168. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/git/__init__.py +0 -0
  169. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/git/git_utils.py +0 -0
  170. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/ignore/__init__.py +0 -0
  171. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/ignore/ignore_pattern_provider.py +0 -0
  172. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/indexing/__init__.py +0 -0
  173. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/indexing/fusion_service.py +0 -0
  174. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/indexing/index_repository.py +0 -0
  175. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/__init__.py +0 -0
  176. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/language_detection_service.py +0 -0
  177. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/languages/csharp.scm +0 -0
  178. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/languages/go.scm +0 -0
  179. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/languages/javascript.scm +0 -0
  180. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/languages/python.scm +0 -0
  181. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/languages/typescript.scm +0 -0
  182. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/snippet_query_provider.py +0 -0
  183. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/snippet_extraction/tree_sitter_snippet_extractor.py +0 -0
  184. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/sqlalchemy/__init__.py +0 -0
  185. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/sqlalchemy/file_repository.py +0 -0
  186. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/sqlalchemy/repository.py +0 -0
  187. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/ui/__init__.py +0 -0
  188. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/ui/progress.py +0 -0
  189. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/infrastructure/ui/spinner.py +0 -0
  190. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/log.py +0 -0
  191. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/middleware.py +0 -0
  192. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/migrations/README +0 -0
  193. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/migrations/__init__.py +0 -0
  194. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/migrations/env.py +0 -0
  195. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/migrations/script.py.mako +0 -0
  196. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/migrations/versions/7c3bbc2ab32b_add_embeddings_table.py +0 -0
  197. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/migrations/versions/85155663351e_initial.py +0 -0
  198. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/migrations/versions/9e53ea8bb3b0_add_authors.py +0 -0
  199. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/migrations/versions/__init__.py +0 -0
  200. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/migrations/versions/c3f5137d30f5_index_all_the_things.py +0 -0
  201. {kodit-0.2.7 → kodit-0.2.9}/src/kodit/reporting.py +0 -0
  202. {kodit-0.2.7 → kodit-0.2.9}/tests/__init__.py +0 -0
  203. {kodit-0.2.7 → kodit-0.2.9}/tests/docker-smoke.sh +0 -0
  204. {kodit-0.2.7/tests/experiments/cline-prompt-regression-tests → kodit-0.2.9/tests/experiments/cline_prompt_tests}/cline_prompt.txt +0 -0
  205. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/__init__.py +0 -0
  206. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/application/__init__.py +0 -0
  207. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/domain/__init__.py +0 -0
  208. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/__init__.py +0 -0
  209. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/indexing/__init__.py +0 -0
  210. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/snippets/__init__.py +0 -0
  211. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/snippets/csharp.cs +0 -0
  212. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/snippets/golang.go +0 -0
  213. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/snippets/javascript.js +0 -0
  214. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/snippets/python.py +0 -0
  215. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/snippets/typescript.tsx +0 -0
  216. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/infrastructure/source/__init__.py +0 -0
  217. {kodit-0.2.7 → kodit-0.2.9}/tests/kodit/mcp_test.py +0 -0
  218. {kodit-0.2.7 → kodit-0.2.9}/tests/vectorchord-smoke.sh +0 -0
  219. {kodit-0.2.7 → kodit-0.2.9}/uv.lock +0 -0
@@ -0,0 +1,11 @@
1
+ ---
2
+ description:
3
+ globs:
4
+ alwaysApply: true
5
+ ---
6
+ Please maintain the following coding standards while developing code:
7
+
8
+ 1. This project uses a domain-driven design approach. Please consider in which layer
9
+ your code belongs.
10
+ 2. Run `uv run ruff check --fix` to lint the code.
11
+ 3. Run `uv run pytest ...` to test the code.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: kodit
3
- Version: 0.2.7
3
+ Version: 0.2.9
4
4
  Summary: Code indexing for better AI code generation
5
5
  Project-URL: Homepage, https://docs.helixml.tech/kodit/
6
6
  Project-URL: Documentation, https://docs.helixml.tech/kodit/
@@ -0,0 +1,217 @@
1
+ ---
2
+ title: MCP
3
+ description: Model Context Protocol (MCP) server implementation for AI coding assistants
4
+ weight: 2
5
+ ---
6
+
7
+ Kodit provides an MCP (Model Context Protocol) server that enables AI coding assistants to search and retrieve relevant code snippets from your indexed codebases. This allows AI assistants to provide more accurate and contextually relevant code suggestions.
8
+
9
+ ## What is MCP?
10
+
11
+ The Model Context Protocol (MCP) is a standard that enables AI assistants to communicate with external tools and data sources. Kodit implements an MCP server that exposes your indexed codebases to AI assistants, allowing them to:
12
+
13
+ - Search for relevant code examples
14
+ - Retrieve specific code snippets
15
+ - Filter results by various criteria
16
+ - Provide context-aware code suggestions
17
+
18
+ ## How Kodit MCP Works
19
+
20
+ The Kodit MCP server runs as a separate service that:
21
+
22
+ 1. **Connects to your indexed codebases** - Uses the same database and indexes created by the `kodit index` command
23
+ 2. **Exposes search functionality** - Provides a `search` tool that AI assistants can call
24
+ 3. **Handles filtering** - Supports filtering by language, author, date range, and source repository
25
+ 4. **Returns relevant snippets** - Combines keyword, semantic code, and semantic text search for optimal results
26
+
27
+ ## Integration with AI Assistants
28
+
29
+ To use Kodit with your AI coding assistant, you need to:
30
+
31
+ 1. **Start the Kodit MCP server**:
32
+
33
+ ```sh
34
+ kodit serve
35
+ ```
36
+
37
+ 2. **Configure your AI assistant** to connect to the MCP server. See the [Integration Guide](../../getting-started/integration/index.md) for detailed instructions for:
38
+ - Cursor
39
+ - Cline
40
+ - Other MCP-compatible assistants
41
+
42
+ ## Search Tool
43
+
44
+ The primary tool exposed by the Kodit MCP server is the `search` function, which provides comprehensive code search capabilities.
45
+
46
+ ### Search Parameters
47
+
48
+ The search tool accepts the following parameters:
49
+
50
+ | Parameter | Type | Description | Example |
51
+ |-----------|------|-------------|---------|
52
+ | `user_intent` | string | Description of what the user wants to achieve | "Create a REST API endpoint for user authentication" |
53
+ | `related_file_paths` | list[Path] | Absolute paths to relevant files | `["/path/to/auth.py"]` |
54
+ | `related_file_contents` | list[string] | Contents of relevant files | `["def authenticate(): ..."]` |
55
+ | `keywords` | list[string] | Relevant keywords for the search | `["authentication", "jwt", "login"]` |
56
+ | `language` | string \| None | Filter by programming language | `"python"`, `"go"`, `"javascript"` |
57
+ | `author` | string \| None | Filter by author name | `"john.doe"` |
58
+ | `created_after` | string \| None | Filter by creation date (YYYY-MM-DD) | `"2023-01-01"` |
59
+ | `created_before` | string \| None | Filter by creation date (YYYY-MM-DD) | `"2023-12-31"` |
60
+ | `source_repo` | string \| None | Filter by source repository | `"github.com/example/repo"` |
61
+
62
+ ### Search Functionality
63
+
64
+ The search tool combines multiple search strategies:
65
+
66
+ 1. **Keyword Search** - Uses BM25 algorithm for exact keyword matching
67
+ 2. **Semantic Code Search** - Uses embeddings to find semantically similar code
68
+ 3. **Semantic Text Search** - Uses embeddings to find code matching natural language descriptions
69
+
70
+ Results are fused together to provide the most relevant snippets for the user's intent.
71
+
72
+ ## Filtering Capabilities
73
+
74
+ Kodit's MCP server supports comprehensive filtering to help AI assistants find the most relevant code examples. These filters work the same way as the CLI search filters.
75
+
76
+ ### Language Filtering
77
+
78
+ Filter results by programming language:
79
+
80
+ **Example prompts:**
81
+ > "I need to create a web server in Python. Please search for Flask or FastAPI examples and show me the best practices."
82
+ > "I'm working on a Go microservice. Can you search for Go-specific patterns for handling HTTP requests and database connections?"
83
+ > "I need JavaScript examples for form validation. Please search for modern JavaScript/TypeScript validation patterns."
84
+
85
+ ### Author Filtering
86
+
87
+ Filter results by code author:
88
+
89
+ **Example prompts:**
90
+ > "I'm reviewing code written by john.doe. Can you search for their authentication implementations to understand their coding style?"
91
+ > "I need to find all the database-related code written by alice.smith. Please search for her database connection and query patterns."
92
+
93
+ ### Date Range Filtering
94
+
95
+ Filter results by creation date:
96
+
97
+ **Example prompts:**
98
+ > "I need to see authentication patterns from 2023. Please search for JWT and OAuth implementations created in 2023."
99
+ > "Show me modern React patterns from the last year. Search for React components and hooks created after 2023."
100
+
101
+ ### Source Repository Filtering
102
+
103
+ Filter results by source repository:
104
+
105
+ **Example prompts:**
106
+ > "I'm working on the auth-service project. Please search for authentication patterns specifically from github.com/company/auth-service."
107
+ > "I need to understand how the user-service handles user management. Search for user-related code from github.com/company/user-service."
108
+
109
+ ### Combining Filters
110
+
111
+ You can combine multiple filters for precise results:
112
+
113
+ **Example prompts:**
114
+ > "I need Python authentication code written by alice.smith in 2023 from the auth-service repository. Please search for JWT token validation patterns."
115
+ > "Show me Go microservice patterns from john.doe created in 2023 from the backend-services repository."
116
+ > "I'm looking for modern React patterns from the frontend team (search for authors: alice.smith, bob.jones) created in 2024 from the web-app repository."
117
+
118
+ ## AI Assistant Integration Tips
119
+
120
+ To get the best results from Kodit with your AI assistant, follow these prompting strategies:
121
+
122
+ ### 1. Provide Clear User Intent
123
+
124
+ When the AI assistant calls the search tool, ensure it provides a clear, descriptive `user_intent`:
125
+
126
+ **Good examples:**
127
+
128
+ - "Create a REST API endpoint for user authentication with JWT tokens"
129
+ - "Implement a database connection pool for PostgreSQL"
130
+ - "Write a function to validate email addresses using regex"
131
+
132
+ **Poor examples:**
133
+
134
+ - "Help me with auth"
135
+ - "Database stuff"
136
+ - "Email validation"
137
+
138
+ ### 2. Use Relevant Keywords
139
+
140
+ Provide specific, technical keywords that are relevant to your task, where applicable.
141
+ Remember that the language model is more than capable of generating appropriate keywords
142
+ for your intent.
143
+
144
+ **Good examples:**
145
+
146
+ - `["authentication", "jwt", "login", "password"]`
147
+ - `["database", "postgresql", "connection", "pool"]`
148
+ - `["email", "validation", "regex", "format"]`
149
+
150
+ ### 3. Leverage File Context
151
+
152
+ If you're working with existing files, mention them in your prompt:
153
+
154
+ **Example prompts:**
155
+ > "I'm working on the authentication function in auth.py. Can you search for similar error handling patterns and show me how to improve the error handling in my existing code?"
156
+ > "I have a database connection setup in database.py. Please search for connection pooling patterns and show me how to optimize my current implementation."
157
+
158
+ ### 4. Use Language Filtering
159
+
160
+ Specify the programming language in your prompt:
161
+
162
+ **Example prompts:**
163
+ > "I need to create a web server in Python. Please search for Flask and FastAPI examples and show me the best practices."
164
+ > "I'm building a Go microservice. Can you search for Go-specific patterns for handling HTTP requests and database connections?"
165
+ > "I need JavaScript examples for form validation. Please search for modern JavaScript/TypeScript validation patterns."
166
+
167
+ ### 5. Filter by Source Repository
168
+
169
+ If you have multiple codebases indexed, mention the specific repository:
170
+
171
+ **Example prompts:**
172
+ > "I'm working on the user-service project. Please search for user management patterns specifically from github.com/company/user-service."
173
+ > "I need to understand how the auth-service handles authentication. Search for auth-related code from github.com/company/auth-service."
174
+
175
+ ### 6. Example Prompts for AI Assistants
176
+
177
+ Here are some example prompts you can use with your AI assistant:
178
+
179
+ **For new code development:**
180
+ > "I want to create a new Python web API. Please search for examples of Flask/FastAPI authentication patterns and show me the best practices."
181
+
182
+ **For debugging existing code:**
183
+ > "I'm having issues with this database connection code. Can you search for similar patterns and show me how others handle connection errors?"
184
+
185
+ **For learning new patterns:**
186
+ > "I need to implement JWT authentication in Go. Please search for production-ready examples and show me the security best practices."
187
+
188
+ **For code review:**
189
+ > "I'm reviewing this authentication function. Can you search for similar implementations and show me potential security issues or improvements?"
190
+
191
+ ## Troubleshooting
192
+
193
+ ### Common Issues
194
+
195
+ 1. **AI assistant not using Kodit**: Ensure you've configured the enforcement prompt and MCP server connection properly.
196
+
197
+ 2. **No search results**: Check that you have indexed codebases and that your search terms are relevant.
198
+
199
+ 3. **Filter not working**: Verify that the filter values match your indexed data (e.g., correct language names, author names, repository URLs).
200
+
201
+ 4. **Connection issues**: Ensure the Kodit MCP server is running (`kodit serve`) and accessible to your AI assistant.
202
+
203
+ ### Debugging
204
+
205
+ Enable debug logging to see what's happening:
206
+
207
+ ```sh
208
+ export LOG_LEVEL=DEBUG
209
+ kodit serve
210
+ ```
211
+
212
+ This will show you:
213
+
214
+ - Search queries being executed
215
+ - Filter parameters being applied
216
+ - Results being returned
217
+ - Any errors or issues
@@ -121,7 +121,6 @@ ignore = [
121
121
  "EM102", # As above
122
122
  ]
123
123
  select = ["ALL"]
124
- exclude = ["./tests/*"]
125
124
 
126
125
  [[tool.uv.index]]
127
126
  name = "pypi"
@@ -17,5 +17,5 @@ __version__: str
17
17
  __version_tuple__: VERSION_TUPLE
18
18
  version_tuple: VERSION_TUPLE
19
19
 
20
- __version__ = version = '0.2.7'
21
- __version_tuple__ = version_tuple = (0, 2, 7)
20
+ __version__ = version = '0.2.9'
21
+ __version_tuple__ = version_tuple = (0, 2, 9)
@@ -0,0 +1 @@
1
+ """Application factories package."""
@@ -0,0 +1,119 @@
1
+ """Factory for creating the unified code indexing application service."""
2
+
3
+ from sqlalchemy.ext.asyncio import AsyncSession
4
+
5
+ from kodit.application.services.code_indexing_application_service import (
6
+ CodeIndexingApplicationService,
7
+ )
8
+ from kodit.config import AppContext
9
+ from kodit.domain.entities import EmbeddingType
10
+ from kodit.domain.services.bm25_service import BM25DomainService
11
+ from kodit.domain.services.embedding_service import EmbeddingDomainService
12
+ from kodit.domain.services.enrichment_service import EnrichmentDomainService
13
+ from kodit.domain.services.source_service import SourceService
14
+ from kodit.infrastructure.bm25.bm25_factory import bm25_repository_factory
15
+ from kodit.infrastructure.embedding.embedding_factory import (
16
+ embedding_domain_service_factory,
17
+ )
18
+ from kodit.infrastructure.embedding.embedding_providers import (
19
+ hash_embedding_provider,
20
+ )
21
+ from kodit.infrastructure.embedding.local_vector_search_repository import (
22
+ LocalVectorSearchRepository,
23
+ )
24
+ from kodit.infrastructure.enrichment.enrichment_factory import (
25
+ enrichment_domain_service_factory,
26
+ )
27
+ from kodit.infrastructure.enrichment.null_enrichment_provider import (
28
+ NullEnrichmentProvider,
29
+ )
30
+ from kodit.infrastructure.indexing.indexing_factory import (
31
+ indexing_domain_service_factory,
32
+ )
33
+ from kodit.infrastructure.indexing.snippet_domain_service_factory import (
34
+ snippet_domain_service_factory,
35
+ )
36
+ from kodit.infrastructure.sqlalchemy.embedding_repository import (
37
+ SqlAlchemyEmbeddingRepository,
38
+ )
39
+
40
+
41
+ def create_code_indexing_application_service(
42
+ app_context: AppContext,
43
+ session: AsyncSession,
44
+ source_service: SourceService,
45
+ ) -> CodeIndexingApplicationService:
46
+ """Create a unified code indexing application service with all dependencies."""
47
+ # Create domain services
48
+ indexing_domain_service = indexing_domain_service_factory(session)
49
+ snippet_domain_service = snippet_domain_service_factory(session)
50
+ bm25_service = BM25DomainService(bm25_repository_factory(app_context, session))
51
+ code_search_service = embedding_domain_service_factory("code", app_context, session)
52
+ text_search_service = embedding_domain_service_factory("text", app_context, session)
53
+ enrichment_service = enrichment_domain_service_factory(app_context)
54
+
55
+ # Create and return the unified application service
56
+ return CodeIndexingApplicationService(
57
+ indexing_domain_service=indexing_domain_service,
58
+ snippet_domain_service=snippet_domain_service,
59
+ source_service=source_service,
60
+ bm25_service=bm25_service,
61
+ code_search_service=code_search_service,
62
+ text_search_service=text_search_service,
63
+ enrichment_service=enrichment_service,
64
+ session=session,
65
+ )
66
+
67
+
68
+ def create_fast_test_code_indexing_application_service(
69
+ app_context: AppContext,
70
+ session: AsyncSession,
71
+ source_service: SourceService,
72
+ ) -> CodeIndexingApplicationService:
73
+ """Create a fast test version of CodeIndexingApplicationService."""
74
+ # Create domain services
75
+ indexing_domain_service = indexing_domain_service_factory(session)
76
+ snippet_domain_service = snippet_domain_service_factory(session)
77
+ bm25_service = BM25DomainService(bm25_repository_factory(app_context, session))
78
+
79
+ # Create fast embedding services using HashEmbeddingProvider
80
+ embedding_repository = SqlAlchemyEmbeddingRepository(session=session)
81
+
82
+ # Fast code search service
83
+ code_search_repository = LocalVectorSearchRepository(
84
+ embedding_repository=embedding_repository,
85
+ embedding_provider=hash_embedding_provider.HashEmbeddingProvider(),
86
+ embedding_type=EmbeddingType.CODE,
87
+ )
88
+ code_search_service = EmbeddingDomainService(
89
+ embedding_provider=hash_embedding_provider.HashEmbeddingProvider(),
90
+ vector_search_repository=code_search_repository,
91
+ )
92
+
93
+ # Fast text search service
94
+ text_search_repository = LocalVectorSearchRepository(
95
+ embedding_repository=embedding_repository,
96
+ embedding_provider=hash_embedding_provider.HashEmbeddingProvider(),
97
+ embedding_type=EmbeddingType.TEXT,
98
+ )
99
+ text_search_service = EmbeddingDomainService(
100
+ embedding_provider=hash_embedding_provider.HashEmbeddingProvider(),
101
+ vector_search_repository=text_search_repository,
102
+ )
103
+
104
+ # Fast enrichment service using NullEnrichmentProvider
105
+ enrichment_service = EnrichmentDomainService(
106
+ enrichment_provider=NullEnrichmentProvider()
107
+ )
108
+
109
+ # Create and return the unified application service
110
+ return CodeIndexingApplicationService(
111
+ indexing_domain_service=indexing_domain_service,
112
+ snippet_domain_service=snippet_domain_service,
113
+ source_service=source_service,
114
+ bm25_service=bm25_service,
115
+ code_search_service=code_search_service,
116
+ text_search_service=text_search_service,
117
+ enrichment_service=enrichment_service,
118
+ session=session,
119
+ )