kreuzberg 4.0.8 → 4.1.0

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.
Files changed (308) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile.lock +2 -2
  3. data/README.md +1 -1
  4. data/ext/kreuzberg_rb/native/Cargo.lock +94 -98
  5. data/ext/kreuzberg_rb/native/Cargo.toml +4 -2
  6. data/ext/kreuzberg_rb/native/src/batch.rs +139 -0
  7. data/ext/kreuzberg_rb/native/src/config/mod.rs +10 -0
  8. data/ext/kreuzberg_rb/native/src/config/types.rs +1058 -0
  9. data/ext/kreuzberg_rb/native/src/error_handling.rs +125 -0
  10. data/ext/kreuzberg_rb/native/src/extraction.rs +79 -0
  11. data/ext/kreuzberg_rb/native/src/gc_guarded_value.rs +35 -0
  12. data/ext/kreuzberg_rb/native/src/helpers.rs +176 -0
  13. data/ext/kreuzberg_rb/native/src/lib.rs +342 -3622
  14. data/ext/kreuzberg_rb/native/src/metadata.rs +34 -0
  15. data/ext/kreuzberg_rb/native/src/plugins/mod.rs +92 -0
  16. data/ext/kreuzberg_rb/native/src/plugins/ocr_backend.rs +159 -0
  17. data/ext/kreuzberg_rb/native/src/plugins/post_processor.rs +126 -0
  18. data/ext/kreuzberg_rb/native/src/plugins/validator.rs +99 -0
  19. data/ext/kreuzberg_rb/native/src/result.rs +326 -0
  20. data/ext/kreuzberg_rb/native/src/validation.rs +4 -0
  21. data/lib/kreuzberg/config.rb +66 -0
  22. data/lib/kreuzberg/result.rb +107 -2
  23. data/lib/kreuzberg/types.rb +104 -0
  24. data/lib/kreuzberg/version.rb +1 -1
  25. data/lib/kreuzberg.rb +0 -4
  26. data/sig/kreuzberg.rbs +105 -1
  27. data/vendor/Cargo.toml +3 -3
  28. data/vendor/kreuzberg/Cargo.toml +4 -3
  29. data/vendor/kreuzberg/README.md +1 -1
  30. data/vendor/kreuzberg/src/api/config.rs +69 -0
  31. data/vendor/kreuzberg/src/api/handlers.rs +99 -2
  32. data/vendor/kreuzberg/src/api/mod.rs +14 -7
  33. data/vendor/kreuzberg/src/api/router.rs +214 -0
  34. data/vendor/kreuzberg/src/api/startup.rs +243 -0
  35. data/vendor/kreuzberg/src/api/types.rs +78 -0
  36. data/vendor/kreuzberg/src/cache/cleanup.rs +277 -0
  37. data/vendor/kreuzberg/src/cache/core.rs +428 -0
  38. data/vendor/kreuzberg/src/cache/mod.rs +21 -843
  39. data/vendor/kreuzberg/src/cache/utilities.rs +156 -0
  40. data/vendor/kreuzberg/src/chunking/boundaries.rs +301 -0
  41. data/vendor/kreuzberg/src/chunking/builder.rs +294 -0
  42. data/vendor/kreuzberg/src/chunking/config.rs +52 -0
  43. data/vendor/kreuzberg/src/chunking/core.rs +1017 -0
  44. data/vendor/kreuzberg/src/chunking/mod.rs +14 -2211
  45. data/vendor/kreuzberg/src/chunking/processor.rs +10 -0
  46. data/vendor/kreuzberg/src/chunking/validation.rs +686 -0
  47. data/vendor/kreuzberg/src/core/config/extraction/core.rs +169 -0
  48. data/vendor/kreuzberg/src/core/config/extraction/env.rs +179 -0
  49. data/vendor/kreuzberg/src/core/config/extraction/loaders.rs +204 -0
  50. data/vendor/kreuzberg/src/core/config/extraction/mod.rs +42 -0
  51. data/vendor/kreuzberg/src/core/config/extraction/types.rs +93 -0
  52. data/vendor/kreuzberg/src/core/config/formats.rs +135 -0
  53. data/vendor/kreuzberg/src/core/config/mod.rs +20 -0
  54. data/vendor/kreuzberg/src/core/config/ocr.rs +73 -0
  55. data/vendor/kreuzberg/src/core/config/page.rs +57 -0
  56. data/vendor/kreuzberg/src/core/config/pdf.rs +111 -0
  57. data/vendor/kreuzberg/src/core/config/processing.rs +312 -0
  58. data/vendor/kreuzberg/src/core/config_validation/dependencies.rs +187 -0
  59. data/vendor/kreuzberg/src/core/config_validation/mod.rs +386 -0
  60. data/vendor/kreuzberg/src/core/config_validation/sections.rs +401 -0
  61. data/vendor/kreuzberg/src/core/extractor/batch.rs +246 -0
  62. data/vendor/kreuzberg/src/core/extractor/bytes.rs +116 -0
  63. data/vendor/kreuzberg/src/core/extractor/file.rs +240 -0
  64. data/vendor/kreuzberg/src/core/extractor/helpers.rs +71 -0
  65. data/vendor/kreuzberg/src/core/extractor/legacy.rs +62 -0
  66. data/vendor/kreuzberg/src/core/extractor/mod.rs +490 -0
  67. data/vendor/kreuzberg/src/core/extractor/sync.rs +208 -0
  68. data/vendor/kreuzberg/src/core/mod.rs +4 -1
  69. data/vendor/kreuzberg/src/core/pipeline/cache.rs +60 -0
  70. data/vendor/kreuzberg/src/core/pipeline/execution.rs +89 -0
  71. data/vendor/kreuzberg/src/core/pipeline/features.rs +108 -0
  72. data/vendor/kreuzberg/src/core/pipeline/format.rs +392 -0
  73. data/vendor/kreuzberg/src/core/pipeline/initialization.rs +67 -0
  74. data/vendor/kreuzberg/src/core/pipeline/mod.rs +135 -0
  75. data/vendor/kreuzberg/src/core/pipeline/tests.rs +975 -0
  76. data/vendor/kreuzberg/src/core/server_config/env.rs +90 -0
  77. data/vendor/kreuzberg/src/core/server_config/loader.rs +202 -0
  78. data/vendor/kreuzberg/src/core/server_config/mod.rs +380 -0
  79. data/vendor/kreuzberg/src/core/server_config/tests/basic_tests.rs +124 -0
  80. data/vendor/kreuzberg/src/core/server_config/tests/env_tests.rs +216 -0
  81. data/vendor/kreuzberg/src/core/server_config/tests/file_loading_tests.rs +341 -0
  82. data/vendor/kreuzberg/src/core/server_config/tests/mod.rs +5 -0
  83. data/vendor/kreuzberg/src/core/server_config/validation.rs +17 -0
  84. data/vendor/kreuzberg/src/embeddings.rs +136 -13
  85. data/vendor/kreuzberg/src/extraction/{archive.rs → archive/mod.rs} +45 -239
  86. data/vendor/kreuzberg/src/extraction/archive/sevenz.rs +98 -0
  87. data/vendor/kreuzberg/src/extraction/archive/tar.rs +118 -0
  88. data/vendor/kreuzberg/src/extraction/archive/zip.rs +101 -0
  89. data/vendor/kreuzberg/src/extraction/html/converter.rs +592 -0
  90. data/vendor/kreuzberg/src/extraction/html/image_handling.rs +95 -0
  91. data/vendor/kreuzberg/src/extraction/html/mod.rs +53 -0
  92. data/vendor/kreuzberg/src/extraction/html/processor.rs +659 -0
  93. data/vendor/kreuzberg/src/extraction/html/stack_management.rs +103 -0
  94. data/vendor/kreuzberg/src/extraction/html/types.rs +28 -0
  95. data/vendor/kreuzberg/src/extraction/mod.rs +6 -2
  96. data/vendor/kreuzberg/src/extraction/pptx/container.rs +159 -0
  97. data/vendor/kreuzberg/src/extraction/pptx/content_builder.rs +168 -0
  98. data/vendor/kreuzberg/src/extraction/pptx/elements.rs +132 -0
  99. data/vendor/kreuzberg/src/extraction/pptx/image_handling.rs +57 -0
  100. data/vendor/kreuzberg/src/extraction/pptx/metadata.rs +160 -0
  101. data/vendor/kreuzberg/src/extraction/pptx/mod.rs +558 -0
  102. data/vendor/kreuzberg/src/extraction/pptx/parser.rs +379 -0
  103. data/vendor/kreuzberg/src/extraction/transform/content.rs +205 -0
  104. data/vendor/kreuzberg/src/extraction/transform/elements.rs +211 -0
  105. data/vendor/kreuzberg/src/extraction/transform/mod.rs +480 -0
  106. data/vendor/kreuzberg/src/extraction/transform/types.rs +27 -0
  107. data/vendor/kreuzberg/src/extractors/archive.rs +2 -0
  108. data/vendor/kreuzberg/src/extractors/bibtex.rs +2 -0
  109. data/vendor/kreuzberg/src/extractors/djot_format/attributes.rs +134 -0
  110. data/vendor/kreuzberg/src/extractors/djot_format/conversion.rs +223 -0
  111. data/vendor/kreuzberg/src/extractors/djot_format/extractor.rs +172 -0
  112. data/vendor/kreuzberg/src/extractors/djot_format/mod.rs +24 -0
  113. data/vendor/kreuzberg/src/extractors/djot_format/parsing/block_handlers.rs +271 -0
  114. data/vendor/kreuzberg/src/extractors/djot_format/parsing/content_extraction.rs +257 -0
  115. data/vendor/kreuzberg/src/extractors/djot_format/parsing/event_handlers.rs +101 -0
  116. data/vendor/kreuzberg/src/extractors/djot_format/parsing/inline_handlers.rs +201 -0
  117. data/vendor/kreuzberg/src/extractors/djot_format/parsing/mod.rs +16 -0
  118. data/vendor/kreuzberg/src/extractors/djot_format/parsing/state.rs +78 -0
  119. data/vendor/kreuzberg/src/extractors/djot_format/parsing/table_extraction.rs +68 -0
  120. data/vendor/kreuzberg/src/extractors/djot_format/parsing/text_extraction.rs +61 -0
  121. data/vendor/kreuzberg/src/extractors/djot_format/rendering.rs +452 -0
  122. data/vendor/kreuzberg/src/extractors/docbook.rs +2 -0
  123. data/vendor/kreuzberg/src/extractors/docx.rs +12 -1
  124. data/vendor/kreuzberg/src/extractors/email.rs +2 -0
  125. data/vendor/kreuzberg/src/extractors/epub/content.rs +333 -0
  126. data/vendor/kreuzberg/src/extractors/epub/metadata.rs +137 -0
  127. data/vendor/kreuzberg/src/extractors/epub/mod.rs +186 -0
  128. data/vendor/kreuzberg/src/extractors/epub/parsing.rs +86 -0
  129. data/vendor/kreuzberg/src/extractors/excel.rs +4 -0
  130. data/vendor/kreuzberg/src/extractors/fictionbook.rs +2 -0
  131. data/vendor/kreuzberg/src/extractors/frontmatter_utils.rs +466 -0
  132. data/vendor/kreuzberg/src/extractors/html.rs +80 -8
  133. data/vendor/kreuzberg/src/extractors/image.rs +8 -1
  134. data/vendor/kreuzberg/src/extractors/jats/elements.rs +350 -0
  135. data/vendor/kreuzberg/src/extractors/jats/metadata.rs +21 -0
  136. data/vendor/kreuzberg/src/extractors/{jats.rs → jats/mod.rs} +10 -412
  137. data/vendor/kreuzberg/src/extractors/jats/parser.rs +52 -0
  138. data/vendor/kreuzberg/src/extractors/jupyter.rs +2 -0
  139. data/vendor/kreuzberg/src/extractors/latex/commands.rs +93 -0
  140. data/vendor/kreuzberg/src/extractors/latex/environments.rs +157 -0
  141. data/vendor/kreuzberg/src/extractors/latex/metadata.rs +27 -0
  142. data/vendor/kreuzberg/src/extractors/latex/mod.rs +146 -0
  143. data/vendor/kreuzberg/src/extractors/latex/parser.rs +231 -0
  144. data/vendor/kreuzberg/src/extractors/latex/utilities.rs +126 -0
  145. data/vendor/kreuzberg/src/extractors/markdown.rs +39 -162
  146. data/vendor/kreuzberg/src/extractors/mod.rs +9 -1
  147. data/vendor/kreuzberg/src/extractors/odt.rs +2 -0
  148. data/vendor/kreuzberg/src/extractors/opml/core.rs +165 -0
  149. data/vendor/kreuzberg/src/extractors/opml/mod.rs +31 -0
  150. data/vendor/kreuzberg/src/extractors/opml/parser.rs +479 -0
  151. data/vendor/kreuzberg/src/extractors/orgmode.rs +2 -0
  152. data/vendor/kreuzberg/src/extractors/pdf/extraction.rs +106 -0
  153. data/vendor/kreuzberg/src/extractors/{pdf.rs → pdf/mod.rs} +25 -324
  154. data/vendor/kreuzberg/src/extractors/pdf/ocr.rs +214 -0
  155. data/vendor/kreuzberg/src/extractors/pdf/pages.rs +51 -0
  156. data/vendor/kreuzberg/src/extractors/pptx.rs +9 -2
  157. data/vendor/kreuzberg/src/extractors/rst.rs +2 -0
  158. data/vendor/kreuzberg/src/extractors/rtf/encoding.rs +116 -0
  159. data/vendor/kreuzberg/src/extractors/rtf/formatting.rs +24 -0
  160. data/vendor/kreuzberg/src/extractors/rtf/images.rs +72 -0
  161. data/vendor/kreuzberg/src/extractors/rtf/metadata.rs +216 -0
  162. data/vendor/kreuzberg/src/extractors/rtf/mod.rs +142 -0
  163. data/vendor/kreuzberg/src/extractors/rtf/parser.rs +259 -0
  164. data/vendor/kreuzberg/src/extractors/rtf/tables.rs +83 -0
  165. data/vendor/kreuzberg/src/extractors/structured.rs +2 -0
  166. data/vendor/kreuzberg/src/extractors/text.rs +4 -0
  167. data/vendor/kreuzberg/src/extractors/typst.rs +2 -0
  168. data/vendor/kreuzberg/src/extractors/xml.rs +2 -0
  169. data/vendor/kreuzberg/src/keywords/processor.rs +14 -0
  170. data/vendor/kreuzberg/src/language_detection/processor.rs +10 -0
  171. data/vendor/kreuzberg/src/lib.rs +2 -2
  172. data/vendor/kreuzberg/src/mcp/errors.rs +312 -0
  173. data/vendor/kreuzberg/src/mcp/format.rs +211 -0
  174. data/vendor/kreuzberg/src/mcp/mod.rs +9 -3
  175. data/vendor/kreuzberg/src/mcp/params.rs +196 -0
  176. data/vendor/kreuzberg/src/mcp/server.rs +39 -1438
  177. data/vendor/kreuzberg/src/mcp/tools/cache.rs +179 -0
  178. data/vendor/kreuzberg/src/mcp/tools/extraction.rs +403 -0
  179. data/vendor/kreuzberg/src/mcp/tools/mime.rs +150 -0
  180. data/vendor/kreuzberg/src/mcp/tools/mod.rs +11 -0
  181. data/vendor/kreuzberg/src/ocr/backends/easyocr.rs +96 -0
  182. data/vendor/kreuzberg/src/ocr/backends/mod.rs +7 -0
  183. data/vendor/kreuzberg/src/ocr/backends/paddleocr.rs +27 -0
  184. data/vendor/kreuzberg/src/ocr/backends/tesseract.rs +134 -0
  185. data/vendor/kreuzberg/src/ocr/hocr.rs +60 -16
  186. data/vendor/kreuzberg/src/ocr/language_registry.rs +11 -235
  187. data/vendor/kreuzberg/src/ocr/mod.rs +1 -0
  188. data/vendor/kreuzberg/src/ocr/processor/config.rs +203 -0
  189. data/vendor/kreuzberg/src/ocr/processor/execution.rs +494 -0
  190. data/vendor/kreuzberg/src/ocr/processor/mod.rs +265 -0
  191. data/vendor/kreuzberg/src/ocr/processor/validation.rs +145 -0
  192. data/vendor/kreuzberg/src/ocr/tesseract_backend.rs +41 -24
  193. data/vendor/kreuzberg/src/pdf/bindings.rs +21 -8
  194. data/vendor/kreuzberg/src/pdf/hierarchy/bounding_box.rs +289 -0
  195. data/vendor/kreuzberg/src/pdf/hierarchy/clustering.rs +199 -0
  196. data/vendor/kreuzberg/src/pdf/{hierarchy.rs → hierarchy/extraction.rs} +6 -346
  197. data/vendor/kreuzberg/src/pdf/hierarchy/mod.rs +18 -0
  198. data/vendor/kreuzberg/src/plugins/extractor/mod.rs +319 -0
  199. data/vendor/kreuzberg/src/plugins/extractor/registry.rs +434 -0
  200. data/vendor/kreuzberg/src/plugins/extractor/trait.rs +391 -0
  201. data/vendor/kreuzberg/src/plugins/mod.rs +13 -0
  202. data/vendor/kreuzberg/src/plugins/ocr.rs +11 -0
  203. data/vendor/kreuzberg/src/plugins/processor/mod.rs +365 -0
  204. data/vendor/kreuzberg/src/plugins/processor/registry.rs +37 -0
  205. data/vendor/kreuzberg/src/plugins/processor/trait.rs +284 -0
  206. data/vendor/kreuzberg/src/plugins/registry/extractor.rs +416 -0
  207. data/vendor/kreuzberg/src/plugins/registry/mod.rs +116 -0
  208. data/vendor/kreuzberg/src/plugins/registry/ocr.rs +293 -0
  209. data/vendor/kreuzberg/src/plugins/registry/processor.rs +304 -0
  210. data/vendor/kreuzberg/src/plugins/registry/validator.rs +238 -0
  211. data/vendor/kreuzberg/src/plugins/validator/mod.rs +424 -0
  212. data/vendor/kreuzberg/src/plugins/validator/registry.rs +355 -0
  213. data/vendor/kreuzberg/src/plugins/validator/trait.rs +276 -0
  214. data/vendor/kreuzberg/src/stopwords/languages/asian.rs +40 -0
  215. data/vendor/kreuzberg/src/stopwords/languages/germanic.rs +36 -0
  216. data/vendor/kreuzberg/src/stopwords/languages/mod.rs +10 -0
  217. data/vendor/kreuzberg/src/stopwords/languages/other.rs +44 -0
  218. data/vendor/kreuzberg/src/stopwords/languages/romance.rs +36 -0
  219. data/vendor/kreuzberg/src/stopwords/languages/slavic.rs +36 -0
  220. data/vendor/kreuzberg/src/stopwords/mod.rs +7 -33
  221. data/vendor/kreuzberg/src/text/quality.rs +1 -1
  222. data/vendor/kreuzberg/src/text/quality_processor.rs +10 -0
  223. data/vendor/kreuzberg/src/text/token_reduction/core/analysis.rs +238 -0
  224. data/vendor/kreuzberg/src/text/token_reduction/core/mod.rs +8 -0
  225. data/vendor/kreuzberg/src/text/token_reduction/core/punctuation.rs +54 -0
  226. data/vendor/kreuzberg/src/text/token_reduction/core/reducer.rs +384 -0
  227. data/vendor/kreuzberg/src/text/token_reduction/core/sentence_selection.rs +68 -0
  228. data/vendor/kreuzberg/src/text/token_reduction/core/word_filtering.rs +156 -0
  229. data/vendor/kreuzberg/src/text/token_reduction/filters/general.rs +377 -0
  230. data/vendor/kreuzberg/src/text/token_reduction/filters/html.rs +51 -0
  231. data/vendor/kreuzberg/src/text/token_reduction/filters/markdown.rs +285 -0
  232. data/vendor/kreuzberg/src/text/token_reduction/filters.rs +131 -246
  233. data/vendor/kreuzberg/src/types/djot.rs +209 -0
  234. data/vendor/kreuzberg/src/types/extraction.rs +301 -0
  235. data/vendor/kreuzberg/src/types/formats.rs +443 -0
  236. data/vendor/kreuzberg/src/types/metadata.rs +560 -0
  237. data/vendor/kreuzberg/src/types/mod.rs +281 -0
  238. data/vendor/kreuzberg/src/types/page.rs +182 -0
  239. data/vendor/kreuzberg/src/types/serde_helpers.rs +132 -0
  240. data/vendor/kreuzberg/src/types/tables.rs +39 -0
  241. data/vendor/kreuzberg/src/utils/quality/heuristics.rs +58 -0
  242. data/vendor/kreuzberg/src/utils/{quality.rs → quality/mod.rs} +168 -489
  243. data/vendor/kreuzberg/src/utils/quality/patterns.rs +117 -0
  244. data/vendor/kreuzberg/src/utils/quality/scoring.rs +178 -0
  245. data/vendor/kreuzberg/src/utils/string_pool/buffer_pool.rs +325 -0
  246. data/vendor/kreuzberg/src/utils/string_pool/interned.rs +102 -0
  247. data/vendor/kreuzberg/src/utils/string_pool/language_pool.rs +119 -0
  248. data/vendor/kreuzberg/src/utils/string_pool/mime_pool.rs +235 -0
  249. data/vendor/kreuzberg/src/utils/string_pool/mod.rs +41 -0
  250. data/vendor/kreuzberg/tests/api_chunk.rs +313 -0
  251. data/vendor/kreuzberg/tests/api_embed.rs +6 -9
  252. data/vendor/kreuzberg/tests/batch_orchestration.rs +1 -0
  253. data/vendor/kreuzberg/tests/concurrency_stress.rs +7 -0
  254. data/vendor/kreuzberg/tests/core_integration.rs +1 -0
  255. data/vendor/kreuzberg/tests/docx_metadata_extraction_test.rs +130 -0
  256. data/vendor/kreuzberg/tests/epub_native_extractor_tests.rs +5 -14
  257. data/vendor/kreuzberg/tests/format_integration.rs +2 -0
  258. data/vendor/kreuzberg/tests/helpers/mod.rs +1 -0
  259. data/vendor/kreuzberg/tests/html_table_test.rs +11 -11
  260. data/vendor/kreuzberg/tests/ocr_configuration.rs +16 -0
  261. data/vendor/kreuzberg/tests/ocr_errors.rs +18 -0
  262. data/vendor/kreuzberg/tests/ocr_quality.rs +9 -0
  263. data/vendor/kreuzberg/tests/ocr_stress.rs +1 -0
  264. data/vendor/kreuzberg/tests/pipeline_integration.rs +50 -0
  265. data/vendor/kreuzberg/tests/plugin_ocr_backend_test.rs +13 -0
  266. data/vendor/kreuzberg/tests/plugin_system.rs +12 -0
  267. data/vendor/kreuzberg/tests/registry_integration_tests.rs +2 -0
  268. data/vendor/kreuzberg-ffi/Cargo.toml +2 -1
  269. data/vendor/kreuzberg-ffi/benches/result_view_benchmark.rs +2 -0
  270. data/vendor/kreuzberg-ffi/kreuzberg.h +347 -178
  271. data/vendor/kreuzberg-ffi/src/config/html.rs +318 -0
  272. data/vendor/kreuzberg-ffi/src/config/loader.rs +154 -0
  273. data/vendor/kreuzberg-ffi/src/config/merge.rs +104 -0
  274. data/vendor/kreuzberg-ffi/src/config/mod.rs +385 -0
  275. data/vendor/kreuzberg-ffi/src/config/parse.rs +91 -0
  276. data/vendor/kreuzberg-ffi/src/config/serialize.rs +118 -0
  277. data/vendor/kreuzberg-ffi/src/config_builder.rs +598 -0
  278. data/vendor/kreuzberg-ffi/src/error.rs +46 -14
  279. data/vendor/kreuzberg-ffi/src/helpers.rs +10 -0
  280. data/vendor/kreuzberg-ffi/src/html_options.rs +421 -0
  281. data/vendor/kreuzberg-ffi/src/lib.rs +16 -0
  282. data/vendor/kreuzberg-ffi/src/panic_shield.rs +11 -0
  283. data/vendor/kreuzberg-ffi/src/plugins/ocr_backend.rs +2 -0
  284. data/vendor/kreuzberg-ffi/src/result.rs +148 -122
  285. data/vendor/kreuzberg-ffi/src/result_view.rs +4 -0
  286. data/vendor/kreuzberg-tesseract/Cargo.toml +2 -2
  287. metadata +200 -28
  288. data/vendor/kreuzberg/src/api/server.rs +0 -518
  289. data/vendor/kreuzberg/src/core/config.rs +0 -1914
  290. data/vendor/kreuzberg/src/core/config_validation.rs +0 -949
  291. data/vendor/kreuzberg/src/core/extractor.rs +0 -1200
  292. data/vendor/kreuzberg/src/core/pipeline.rs +0 -1223
  293. data/vendor/kreuzberg/src/core/server_config.rs +0 -1220
  294. data/vendor/kreuzberg/src/extraction/html.rs +0 -1830
  295. data/vendor/kreuzberg/src/extraction/pptx.rs +0 -3102
  296. data/vendor/kreuzberg/src/extractors/epub.rs +0 -696
  297. data/vendor/kreuzberg/src/extractors/latex.rs +0 -653
  298. data/vendor/kreuzberg/src/extractors/opml.rs +0 -635
  299. data/vendor/kreuzberg/src/extractors/rtf.rs +0 -809
  300. data/vendor/kreuzberg/src/ocr/processor.rs +0 -858
  301. data/vendor/kreuzberg/src/plugins/extractor.rs +0 -1042
  302. data/vendor/kreuzberg/src/plugins/processor.rs +0 -650
  303. data/vendor/kreuzberg/src/plugins/registry.rs +0 -1339
  304. data/vendor/kreuzberg/src/plugins/validator.rs +0 -967
  305. data/vendor/kreuzberg/src/text/token_reduction/core.rs +0 -832
  306. data/vendor/kreuzberg/src/types.rs +0 -1713
  307. data/vendor/kreuzberg/src/utils/string_pool.rs +0 -762
  308. data/vendor/kreuzberg-ffi/src/config.rs +0 -1341
@@ -23,6 +23,8 @@
23
23
  use std::collections::HashMap;
24
24
  use std::sync::OnceLock;
25
25
 
26
+ use super::backends;
27
+
26
28
  /// Global language registry instance (lazy initialized)
27
29
  static LANGUAGE_REGISTRY: OnceLock<LanguageRegistry> = OnceLock::new();
28
30
 
@@ -46,241 +48,15 @@ impl LanguageRegistry {
46
48
  backends: HashMap::new(),
47
49
  };
48
50
 
49
- registry.backends.insert(
50
- "easyocr".to_string(),
51
- vec![
52
- "abq".to_string(),
53
- "ady".to_string(),
54
- "af".to_string(),
55
- "ang".to_string(),
56
- "ar".to_string(),
57
- "as".to_string(),
58
- "ava".to_string(),
59
- "az".to_string(),
60
- "be".to_string(),
61
- "bg".to_string(),
62
- "bh".to_string(),
63
- "bho".to_string(),
64
- "bn".to_string(),
65
- "bs".to_string(),
66
- "ch_sim".to_string(),
67
- "ch_tra".to_string(),
68
- "che".to_string(),
69
- "cs".to_string(),
70
- "cy".to_string(),
71
- "da".to_string(),
72
- "dar".to_string(),
73
- "de".to_string(),
74
- "en".to_string(),
75
- "es".to_string(),
76
- "et".to_string(),
77
- "fa".to_string(),
78
- "fr".to_string(),
79
- "ga".to_string(),
80
- "gom".to_string(),
81
- "hi".to_string(),
82
- "hr".to_string(),
83
- "hu".to_string(),
84
- "id".to_string(),
85
- "inh".to_string(),
86
- "is".to_string(),
87
- "it".to_string(),
88
- "ja".to_string(),
89
- "kbd".to_string(),
90
- "kn".to_string(),
91
- "ko".to_string(),
92
- "ku".to_string(),
93
- "la".to_string(),
94
- "lbe".to_string(),
95
- "lez".to_string(),
96
- "lt".to_string(),
97
- "lv".to_string(),
98
- "mah".to_string(),
99
- "mai".to_string(),
100
- "mi".to_string(),
101
- "mn".to_string(),
102
- "mr".to_string(),
103
- "ms".to_string(),
104
- "mt".to_string(),
105
- "ne".to_string(),
106
- "new".to_string(),
107
- "nl".to_string(),
108
- "no".to_string(),
109
- "oc".to_string(),
110
- "pi".to_string(),
111
- "pl".to_string(),
112
- "pt".to_string(),
113
- "ro".to_string(),
114
- "ru".to_string(),
115
- "rs_cyrillic".to_string(),
116
- "rs_latin".to_string(),
117
- "sck".to_string(),
118
- "sk".to_string(),
119
- "sl".to_string(),
120
- "sq".to_string(),
121
- "sv".to_string(),
122
- "sw".to_string(),
123
- "ta".to_string(),
124
- "tab".to_string(),
125
- "te".to_string(),
126
- "th".to_string(),
127
- "tjk".to_string(),
128
- "tl".to_string(),
129
- "tr".to_string(),
130
- "ug".to_string(),
131
- "uk".to_string(),
132
- "ur".to_string(),
133
- "uz".to_string(),
134
- "vi".to_string(),
135
- ],
136
- );
137
-
138
- registry.backends.insert(
139
- "paddleocr".to_string(),
140
- vec![
141
- "ch".to_string(),
142
- "en".to_string(),
143
- "french".to_string(),
144
- "german".to_string(),
145
- "korean".to_string(),
146
- "japan".to_string(),
147
- "chinese_cht".to_string(),
148
- "ta".to_string(),
149
- "te".to_string(),
150
- "ka".to_string(),
151
- "latin".to_string(),
152
- "arabic".to_string(),
153
- "cyrillic".to_string(),
154
- "devanagari".to_string(),
155
- ],
156
- );
157
-
158
- registry.backends.insert(
159
- "tesseract".to_string(),
160
- vec![
161
- "afr".to_string(),
162
- "amh".to_string(),
163
- "ara".to_string(),
164
- "asm".to_string(),
165
- "aze".to_string(),
166
- "aze_cyrl".to_string(),
167
- "bel".to_string(),
168
- "ben".to_string(),
169
- "bod".to_string(),
170
- "bos".to_string(),
171
- "bre".to_string(),
172
- "bul".to_string(),
173
- "cat".to_string(),
174
- "ceb".to_string(),
175
- "ces".to_string(),
176
- "chi_sim".to_string(),
177
- "chi_tra".to_string(),
178
- "chr".to_string(),
179
- "cos".to_string(),
180
- "cym".to_string(),
181
- "dan".to_string(),
182
- "deu".to_string(),
183
- "div".to_string(),
184
- "dzo".to_string(),
185
- "ell".to_string(),
186
- "eng".to_string(),
187
- "enm".to_string(),
188
- "epo".to_string(),
189
- "equ".to_string(),
190
- "est".to_string(),
191
- "eus".to_string(),
192
- "fao".to_string(),
193
- "fas".to_string(),
194
- "fil".to_string(),
195
- "fin".to_string(),
196
- "fra".to_string(),
197
- "frk".to_string(),
198
- "frm".to_string(),
199
- "fry".to_string(),
200
- "gla".to_string(),
201
- "gle".to_string(),
202
- "glg".to_string(),
203
- "grc".to_string(),
204
- "guj".to_string(),
205
- "hat".to_string(),
206
- "heb".to_string(),
207
- "hin".to_string(),
208
- "hrv".to_string(),
209
- "hun".to_string(),
210
- "hye".to_string(),
211
- "iku".to_string(),
212
- "ind".to_string(),
213
- "isl".to_string(),
214
- "ita".to_string(),
215
- "ita_old".to_string(),
216
- "jav".to_string(),
217
- "jpn".to_string(),
218
- "kan".to_string(),
219
- "kat".to_string(),
220
- "kat_old".to_string(),
221
- "kaz".to_string(),
222
- "khm".to_string(),
223
- "kir".to_string(),
224
- "kmr".to_string(),
225
- "kor".to_string(),
226
- "lao".to_string(),
227
- "lat".to_string(),
228
- "lav".to_string(),
229
- "lit".to_string(),
230
- "ltz".to_string(),
231
- "mal".to_string(),
232
- "mar".to_string(),
233
- "mkd".to_string(),
234
- "mlt".to_string(),
235
- "mon".to_string(),
236
- "mri".to_string(),
237
- "msa".to_string(),
238
- "mya".to_string(),
239
- "nep".to_string(),
240
- "nld".to_string(),
241
- "nor".to_string(),
242
- "oci".to_string(),
243
- "ori".to_string(),
244
- "osd".to_string(),
245
- "pan".to_string(),
246
- "pol".to_string(),
247
- "por".to_string(),
248
- "pus".to_string(),
249
- "que".to_string(),
250
- "ron".to_string(),
251
- "rus".to_string(),
252
- "san".to_string(),
253
- "sin".to_string(),
254
- "slk".to_string(),
255
- "slv".to_string(),
256
- "snd".to_string(),
257
- "spa".to_string(),
258
- "spa_old".to_string(),
259
- "sqi".to_string(),
260
- "srp".to_string(),
261
- "srp_latn".to_string(),
262
- "sun".to_string(),
263
- "swa".to_string(),
264
- "swe".to_string(),
265
- "syr".to_string(),
266
- "tam".to_string(),
267
- "tat".to_string(),
268
- "tel".to_string(),
269
- "tgk".to_string(),
270
- "tha".to_string(),
271
- "tir".to_string(),
272
- "ton".to_string(),
273
- "tur".to_string(),
274
- "uig".to_string(),
275
- "ukr".to_string(),
276
- "urd".to_string(),
277
- "uzb".to_string(),
278
- "uzb_cyrl".to_string(),
279
- "vie".to_string(),
280
- "yid".to_string(),
281
- "yor".to_string(),
282
- ],
283
- );
51
+ registry
52
+ .backends
53
+ .insert("easyocr".to_string(), backends::easyocr::languages());
54
+ registry
55
+ .backends
56
+ .insert("paddleocr".to_string(), backends::paddleocr::languages());
57
+ registry
58
+ .backends
59
+ .insert("tesseract".to_string(), backends::tesseract::languages());
284
60
 
285
61
  registry
286
62
  }
@@ -37,6 +37,7 @@
37
37
  //! [dependencies]
38
38
  //! kreuzberg = { version = "4.0", features = ["ocr"] }
39
39
  //! ```
40
+ mod backends;
40
41
  pub mod cache;
41
42
  pub mod error;
42
43
  pub mod hocr;
@@ -0,0 +1,203 @@
1
+ //! Configuration hashing and Tesseract variable management.
2
+ //!
3
+ //! This module handles configuration hashing for caching and
4
+ //! setting Tesseract variables.
5
+
6
+ use crate::ocr::error::OcrError;
7
+ use crate::ocr::types::TesseractConfig;
8
+ use kreuzberg_tesseract::TesseractAPI;
9
+
10
+ /// Compute a deterministic hash of the OCR configuration.
11
+ ///
12
+ /// This hash is used as part of the cache key to ensure different
13
+ /// configurations produce different cached results.
14
+ ///
15
+ /// # Arguments
16
+ ///
17
+ /// * `config` - Configuration to hash
18
+ ///
19
+ /// # Returns
20
+ ///
21
+ /// Hexadecimal string representation of the configuration hash
22
+ pub(super) fn hash_config(config: &TesseractConfig) -> String {
23
+ use ahash::AHasher;
24
+ use std::hash::{Hash, Hasher};
25
+
26
+ let mut hasher = AHasher::default();
27
+ config.language.hash(&mut hasher);
28
+ config.psm.hash(&mut hasher);
29
+ config.output_format.hash(&mut hasher);
30
+ config.enable_table_detection.hash(&mut hasher);
31
+ config.table_min_confidence.to_bits().hash(&mut hasher);
32
+ config.table_column_threshold.hash(&mut hasher);
33
+ config.table_row_threshold_ratio.to_bits().hash(&mut hasher);
34
+ config.classify_use_pre_adapted_templates.hash(&mut hasher);
35
+ config.language_model_ngram_on.hash(&mut hasher);
36
+ config.tessedit_dont_blkrej_good_wds.hash(&mut hasher);
37
+ config.tessedit_dont_rowrej_good_wds.hash(&mut hasher);
38
+ config.tessedit_enable_dict_correction.hash(&mut hasher);
39
+ config.tessedit_char_whitelist.hash(&mut hasher);
40
+ config.tessedit_use_primary_params_model.hash(&mut hasher);
41
+ config.textord_space_size_is_variable.hash(&mut hasher);
42
+ config.thresholding_method.hash(&mut hasher);
43
+
44
+ format!("{:016x}", hasher.finish())
45
+ }
46
+
47
+ /// Apply Tesseract configuration variables to the API.
48
+ ///
49
+ /// Sets all the advanced Tesseract variables from the configuration.
50
+ ///
51
+ /// # Arguments
52
+ ///
53
+ /// * `api` - Tesseract API instance
54
+ /// * `config` - Configuration with variables to apply
55
+ ///
56
+ /// # Returns
57
+ ///
58
+ /// `Ok(())` if all variables were set successfully, otherwise an error
59
+ pub(super) fn apply_tesseract_variables(api: &TesseractAPI, config: &TesseractConfig) -> Result<(), OcrError> {
60
+ api.set_variable(
61
+ "classify_use_pre_adapted_templates",
62
+ &config.classify_use_pre_adapted_templates.to_string(),
63
+ )
64
+ .map_err(|e| OcrError::InvalidConfiguration(format!("Failed to set classify_use_pre_adapted_templates: {}", e)))?;
65
+
66
+ api.set_variable("language_model_ngram_on", &config.language_model_ngram_on.to_string())
67
+ .map_err(|e| OcrError::InvalidConfiguration(format!("Failed to set language_model_ngram_on: {}", e)))?;
68
+
69
+ api.set_variable(
70
+ "tessedit_dont_blkrej_good_wds",
71
+ &config.tessedit_dont_blkrej_good_wds.to_string(),
72
+ )
73
+ .map_err(|e| OcrError::InvalidConfiguration(format!("Failed to set tessedit_dont_blkrej_good_wds: {}", e)))?;
74
+
75
+ api.set_variable(
76
+ "tessedit_dont_rowrej_good_wds",
77
+ &config.tessedit_dont_rowrej_good_wds.to_string(),
78
+ )
79
+ .map_err(|e| OcrError::InvalidConfiguration(format!("Failed to set tessedit_dont_rowrej_good_wds: {}", e)))?;
80
+
81
+ api.set_variable(
82
+ "tessedit_enable_dict_correction",
83
+ &config.tessedit_enable_dict_correction.to_string(),
84
+ )
85
+ .map_err(|e| OcrError::InvalidConfiguration(format!("Failed to set tessedit_enable_dict_correction: {}", e)))?;
86
+
87
+ if !config.tessedit_char_whitelist.is_empty() {
88
+ api.set_variable("tessedit_char_whitelist", &config.tessedit_char_whitelist)
89
+ .map_err(|e| OcrError::InvalidConfiguration(format!("Failed to set tessedit_char_whitelist: {}", e)))?;
90
+ }
91
+
92
+ api.set_variable(
93
+ "tessedit_use_primary_params_model",
94
+ &config.tessedit_use_primary_params_model.to_string(),
95
+ )
96
+ .map_err(|e| OcrError::InvalidConfiguration(format!("Failed to set tessedit_use_primary_params_model: {}", e)))?;
97
+
98
+ api.set_variable(
99
+ "textord_space_size_is_variable",
100
+ &config.textord_space_size_is_variable.to_string(),
101
+ )
102
+ .map_err(|e| OcrError::InvalidConfiguration(format!("Failed to set textord_space_size_is_variable: {}", e)))?;
103
+
104
+ api.set_variable("thresholding_method", &config.thresholding_method.to_string())
105
+ .map_err(|e| OcrError::InvalidConfiguration(format!("Failed to set thresholding_method: {}", e)))?;
106
+
107
+ Ok(())
108
+ }
109
+
110
+ #[cfg(test)]
111
+ mod tests {
112
+ use super::*;
113
+
114
+ fn create_test_config() -> TesseractConfig {
115
+ TesseractConfig {
116
+ output_format: "text".to_string(),
117
+ enable_table_detection: false,
118
+ use_cache: false,
119
+ ..TesseractConfig::default()
120
+ }
121
+ }
122
+
123
+ #[test]
124
+ fn test_hash_config_deterministic() {
125
+ let config = create_test_config();
126
+
127
+ let hash1 = hash_config(&config);
128
+ let hash2 = hash_config(&config);
129
+
130
+ assert_eq!(hash1, hash2);
131
+ assert_eq!(hash1.len(), 16);
132
+ }
133
+
134
+ #[test]
135
+ fn test_hash_config_different_languages() {
136
+ let mut config1 = create_test_config();
137
+ config1.language = "eng".to_string();
138
+
139
+ let mut config2 = create_test_config();
140
+ config2.language = "fra".to_string();
141
+
142
+ let hash1 = hash_config(&config1);
143
+ let hash2 = hash_config(&config2);
144
+
145
+ assert_ne!(hash1, hash2);
146
+ }
147
+
148
+ #[test]
149
+ fn test_hash_config_different_psm() {
150
+ let mut config1 = create_test_config();
151
+ config1.psm = 3;
152
+
153
+ let mut config2 = create_test_config();
154
+ config2.psm = 6;
155
+
156
+ let hash1 = hash_config(&config1);
157
+ let hash2 = hash_config(&config2);
158
+
159
+ assert_ne!(hash1, hash2);
160
+ }
161
+
162
+ #[test]
163
+ fn test_hash_config_different_output_format() {
164
+ let mut config1 = create_test_config();
165
+ config1.output_format = "text".to_string();
166
+
167
+ let mut config2 = create_test_config();
168
+ config2.output_format = "markdown".to_string();
169
+
170
+ let hash1 = hash_config(&config1);
171
+ let hash2 = hash_config(&config2);
172
+
173
+ assert_ne!(hash1, hash2);
174
+ }
175
+
176
+ #[test]
177
+ fn test_hash_config_table_detection_flag() {
178
+ let mut config1 = create_test_config();
179
+ config1.enable_table_detection = false;
180
+
181
+ let mut config2 = create_test_config();
182
+ config2.enable_table_detection = true;
183
+
184
+ let hash1 = hash_config(&config1);
185
+ let hash2 = hash_config(&config2);
186
+
187
+ assert_ne!(hash1, hash2);
188
+ }
189
+
190
+ #[test]
191
+ fn test_hash_config_whitelist() {
192
+ let mut config1 = create_test_config();
193
+ config1.tessedit_char_whitelist = "".to_string();
194
+
195
+ let mut config2 = create_test_config();
196
+ config2.tessedit_char_whitelist = "0123456789".to_string();
197
+
198
+ let hash1 = hash_config(&config1);
199
+ let hash2 = hash_config(&config2);
200
+
201
+ assert_ne!(hash1, hash2);
202
+ }
203
+ }