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.
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/PKG-INFO +2 -2
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/pyproject.toml +8 -1
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/_version.py +2 -2
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.github/workflows/publish-dev.yml +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.github/workflows/publish.yml +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.github/workflows/style.yml +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.github/workflows/test.yml +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.gitignore +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/.pre-commit-config.yaml +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/LICENSE +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/README.md +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/docs/renderer-config.md +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/README.md +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/sglang/multiturn_generate_sglang.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/sglang/online_multiturn_sglang.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/tinker/multiturn_generate_tinker.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/transformers/multiturn_generate_transformers.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/vllm/multiturn_generate_vllm.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/__init__.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/base.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/client.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/configs.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/deepseek_v3.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/default.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/glm45.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/glm5.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/gpt_oss.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/kimi_k2.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/kimi_k25.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/laguna_xs2.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/minimax_m2.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/nemotron3.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/parsers.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/parsing.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/qwen3.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/qwen35.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/qwen36.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/renderers/qwen3_vl.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/conftest.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_bridge.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_build_helpers.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_client.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_gpt_oss_harmony_parity.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_incremental.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_is_content.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_kimi_k25_tool_schema.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_load_tokenizer.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_load_tokenizer_fastokens.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_message_indices.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_multimodal.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_parse_response.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_parse_response_robustness.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_parsers.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_preserve_thinking.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_qwen35_size_coverage.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_render_ids.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_renderer_config.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_renderer_config_parity.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_roundtrip.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_sampled_mask.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_tokens_per_message.py +0 -0
- {renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/tests/test_tool_arg_type_preservation.py +0 -0
- {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.
|
|
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.
|
|
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
|
-
|
|
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.
|
|
22
|
-
__version_tuple__ = version_tuple = (0, 1, 8, '
|
|
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
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/sglang/multiturn_generate_sglang.py
RENAMED
|
File without changes
|
|
File without changes
|
{renderers-0.1.8.dev31 → renderers-0.1.8.dev32}/examples/tinker/multiturn_generate_tinker.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|