renderers 0.1.8.dev31__tar.gz → 0.1.8.dev32__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.
Files changed (63) hide show
  1. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/PKG-INFO +2 -2
  2. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/pyproject.toml +8 -1
  3. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/_version.py +2 -2
  4. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.github/workflows/publish-dev.yml +0 -0
  5. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.github/workflows/publish.yml +0 -0
  6. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.github/workflows/style.yml +0 -0
  7. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.github/workflows/test.yml +0 -0
  8. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.gitignore +0 -0
  9. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.pre-commit-config.yaml +0 -0
  10. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/LICENSE +0 -0
  11. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/README.md +0 -0
  12. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/docs/renderer-config.md +0 -0
  13. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/README.md +0 -0
  14. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/sglang/multiturn_generate_sglang.py +0 -0
  15. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/sglang/online_multiturn_sglang.py +0 -0
  16. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/tinker/multiturn_generate_tinker.py +0 -0
  17. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/transformers/multiturn_generate_transformers.py +0 -0
  18. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/vllm/multiturn_generate_vllm.py +0 -0
  19. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/__init__.py +0 -0
  20. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/base.py +0 -0
  21. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/client.py +0 -0
  22. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/configs.py +0 -0
  23. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/deepseek_v3.py +0 -0
  24. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/default.py +0 -0
  25. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/glm45.py +0 -0
  26. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/glm5.py +0 -0
  27. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/gpt_oss.py +0 -0
  28. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/kimi_k2.py +0 -0
  29. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/kimi_k25.py +0 -0
  30. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/laguna_xs2.py +0 -0
  31. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/minimax_m2.py +0 -0
  32. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/nemotron3.py +0 -0
  33. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/parsers.py +0 -0
  34. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/parsing.py +0 -0
  35. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/qwen3.py +0 -0
  36. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/qwen35.py +0 -0
  37. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/qwen36.py +0 -0
  38. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/qwen3_vl.py +0 -0
  39. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/conftest.py +0 -0
  40. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_bridge.py +0 -0
  41. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_build_helpers.py +0 -0
  42. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_client.py +0 -0
  43. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_gpt_oss_harmony_parity.py +0 -0
  44. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_incremental.py +0 -0
  45. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_is_content.py +0 -0
  46. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_kimi_k25_tool_schema.py +0 -0
  47. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_load_tokenizer.py +0 -0
  48. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_load_tokenizer_fastokens.py +0 -0
  49. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_message_indices.py +0 -0
  50. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_multimodal.py +0 -0
  51. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_parse_response.py +0 -0
  52. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_parse_response_robustness.py +0 -0
  53. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_parsers.py +0 -0
  54. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_preserve_thinking.py +0 -0
  55. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_qwen35_size_coverage.py +0 -0
  56. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_render_ids.py +0 -0
  57. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_renderer_config.py +0 -0
  58. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_renderer_config_parity.py +0 -0
  59. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_roundtrip.py +0 -0
  60. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_sampled_mask.py +0 -0
  61. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_tokens_per_message.py +0 -0
  62. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_tool_arg_type_preservation.py +0 -0
  63. {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/uv.lock +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: renderers
3
- Version: 0.1.8.dev31
3
+ Version: 0.1.8.dev32
4
4
  Summary: Chat template renderers — deterministic message-to-token conversion for LLM training
5
5
  License-Expression: Apache-2.0
6
6
  License-File: LICENSE
@@ -8,7 +8,7 @@ Requires-Python: <3.14,>=3.10
8
8
  Requires-Dist: fastokens>=0.2.0
9
9
  Requires-Dist: jinja2
10
10
  Requires-Dist: numpy
11
- Requires-Dist: openai-harmony>=0.0.8
11
+ Requires-Dist: openai-harmony>=0.0.4
12
12
  Requires-Dist: openai>=1.108.1
13
13
  Requires-Dist: prime-pydantic-config>=0.3.0.dev83
14
14
  Requires-Dist: tiktoken
@@ -23,7 +23,14 @@ dependencies = [
23
23
  # Used by GptOssRenderer to render and parse harmony tokens. Vendoring
24
24
  # OpenAI's reference implementation keeps us byte-identical with vLLM
25
25
  # (which also uses it) and saves us mirroring a 330-line Jinja template.
26
- "openai-harmony>=0.0.8",
26
+ #
27
+ # Floor is ``>=0.0.4`` (not the latest 0.0.8) on purpose: every SGLang
28
+ # release through 0.5.12.post1 hard-pins ``openai-harmony==0.0.4``, so a
29
+ # higher floor makes ``renderers`` uninstallable alongside SGLang. The
30
+ # GptOssRenderer renders byte-identically on 0.0.4 (verified token-for-token
31
+ # against 0.0.8) and ``tests/test_gpt_oss_harmony_parity.py`` passes on it,
32
+ # so the older harmony is safe.
33
+ "openai-harmony>=0.0.4",
27
34
  # Crusoe's Rust BPE tokenizer; ~10x faster encode vs HF's tokenizers.
28
35
  # ``load_tokenizer`` patches it in by default for every supported model
29
36
  # except a small denylist (DeepSeek-V3 family). The patch is bracketed
@@ -18,7 +18,7 @@ version_tuple: tuple[int | str, ...]
18
18
  commit_id: str | None
19
19
  __commit_id__: str | None
20
20
 
21
- __version__ = version = '0.1.8.dev31'
22
- __version_tuple__ = version_tuple = (0, 1, 8, 'dev31')
21
+ __version__ = version = '0.1.8.dev32'
22
+ __version_tuple__ = version_tuple = (0, 1, 8, 'dev32')
23
23
 
24
24
  __commit_id__ = commit_id = None
File without changes
File without changes