qgallouedec HF Staff commited on
Commit
977db16
·
verified ·
1 Parent(s): cce73ca

Update chat_template.jinja

Browse files
Files changed (1) hide show
  1. chat_template.jinja +72 -17
chat_template.jinja CHANGED
@@ -150,6 +150,21 @@
150
  {{- ns.result | trim -}}
151
  {%- endmacro -%}
152
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
153
  {%- set ns = namespace(prev_message_type=None) -%}
154
  {%- set loop_messages = messages -%}
155
  {{ bos_token }}
@@ -180,11 +195,56 @@
180
  {{- '<turn|>\n' -}}
181
  {%- endif %}
182
 
 
 
 
 
 
 
 
 
183
  {#- Loop through messages -#}
184
  {%- for message in loop_messages -%}
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
185
  {%- set ns.prev_message_type = None -%}
186
  {%- set role = 'model' if message['role'] == 'assistant' else message['role'] -%}
 
 
 
 
 
 
 
 
 
 
 
 
187
  {{- '<|turn>' + role + '\n' }}
 
 
 
 
 
 
 
188
 
189
  {%- if message['tool_calls'] -%}
190
  {%- for tool_call in message['tool_calls'] -%}
@@ -205,23 +265,14 @@
205
  {%- set ns.prev_message_type = 'tool_call' -%}
206
  {%- endif -%}
207
 
208
- {%- if message['tool_responses'] -%}
209
- {#- Tool Response handling -#}
 
210
  {%- for tool_response in message['tool_responses'] -%}
211
- {{- '<|tool_response>' -}}
212
- {%- if tool_response['response'] is mapping -%}
213
- {{- 'response:' + tool_response['name'] | default('unknown') + '{' -}}
214
- {%- for key, value in tool_response['response'] | dictsort -%}
215
- {{- key -}}:{{- format_argument(value, escape_keys=False) -}}
216
- {%- if not loop.last %},{% endif -%}
217
- {%- endfor -%}
218
- {{- '}' -}}
219
- {%- else -%}
220
- {{- 'response:' + tool_response['name'] | default('unknown') + '{value:' + format_argument(tool_response['response'], escape_keys=False) + '}' -}}
221
- {%- endif -%}
222
- {{- '<tool_response|>' -}}
223
  {%- endfor -%}
224
- {%- set ns.prev_message_type = 'tool_response' -%}
225
  {%- endif -%}
226
 
227
  {%- if message['content'] is string -%}
@@ -251,13 +302,17 @@
251
  {%- endfor -%}
252
  {%- endif -%}
253
 
254
- {%- if not (message['tool_responses'] and not message['content']) -%}
255
  {{- '<turn|>\n' -}}
256
  {%- endif -%}
 
257
  {%- endfor -%}
258
 
259
  {%- if add_generation_prompt -%}
260
  {%- if ns.prev_message_type != 'tool_response' -%}
261
  {{- '<|turn>model\n' -}}
262
  {%- endif -%}
263
- {%- endif -%}
 
 
 
 
150
  {{- ns.result | trim -}}
151
  {%- endmacro -%}
152
 
153
+ {%- macro format_tool_response_block(tool_name, response) -%}
154
+ {{- '<|tool_response>' -}}
155
+ {%- if response is mapping -%}
156
+ {{- 'response:' + tool_name + '{' -}}
157
+ {%- for key, value in response | dictsort -%}
158
+ {{- key -}}:{{- format_argument(value, escape_keys=False) -}}
159
+ {%- if not loop.last %},{% endif -%}
160
+ {%- endfor -%}
161
+ {{- '}' -}}
162
+ {%- else -%}
163
+ {{- 'response:' + tool_name + '{value:' + format_argument(response, escape_keys=False) + '}' -}}
164
+ {%- endif -%}
165
+ {{- '<tool_response|>' -}}
166
+ {%- endmacro -%}
167
+
168
  {%- set ns = namespace(prev_message_type=None) -%}
169
  {%- set loop_messages = messages -%}
170
  {{ bos_token }}
 
195
  {{- '<turn|>\n' -}}
196
  {%- endif %}
197
 
198
+ {#- Pre-scan: find last user message index for reasoning guard -#}
199
+ {%- set ns_turn = namespace(last_user_idx=-1) -%}
200
+ {%- for i in range(loop_messages | length) -%}
201
+ {%- if loop_messages[i]['role'] == 'user' -%}
202
+ {%- set ns_turn.last_user_idx = i -%}
203
+ {%- endif -%}
204
+ {%- endfor -%}
205
+
206
  {#- Loop through messages -#}
207
  {%- for message in loop_messages -%}
208
+ {%- if message['role'] == 'tool' -%}
209
+ {#- Render tool responses as standalone blocks (outside model turn) for prefix-preservation -#}
210
+ {%- set tool_name = message.get('name') | default('unknown') -%}
211
+ {%- set tool_body = message.get('content') -%}
212
+ {%- if tool_body is string -%}
213
+ {{- format_tool_response_block(tool_name, tool_body) -}}
214
+ {%- elif tool_body is sequence and tool_body is not string -%}
215
+ {%- set ns_txt = namespace(s='') -%}
216
+ {%- for part in tool_body -%}
217
+ {%- if part.get('type') == 'text' -%}
218
+ {%- set ns_txt.s = ns_txt.s + (part.get('text') | default('')) -%}
219
+ {%- endif -%}
220
+ {%- endfor -%}
221
+ {{- format_tool_response_block(tool_name, ns_txt.s) -}}
222
+ {%- else -%}
223
+ {{- format_tool_response_block(tool_name, tool_body) -}}
224
+ {%- endif -%}
225
+ {%- else -%}
226
  {%- set ns.prev_message_type = None -%}
227
  {%- set role = 'model' if message['role'] == 'assistant' else message['role'] -%}
228
+ {#- Detect continuation: suppress duplicate <|turn>model when previous message was also assistant -#}
229
+ {%- set prev_nt = namespace(role=None, found=false) -%}
230
+ {%- if loop.index0 > 0 -%}
231
+ {%- for j in range(loop.index0 - 1, -1, -1) -%}
232
+ {%- if not prev_nt.found -%}
233
+ {%- set prev_nt.role = loop_messages[j]['role'] -%}
234
+ {%- set prev_nt.found = true -%}
235
+ {%- endif -%}
236
+ {%- endfor -%}
237
+ {%- endif -%}
238
+ {%- set continue_same_model_turn = (role == 'model' and prev_nt.role == 'assistant') -%}
239
+ {%- if not continue_same_model_turn -%}
240
  {{- '<|turn>' + role + '\n' }}
241
+ {%- endif -%}
242
+
243
+ {#- Render reasoning/reasoning_content as thinking channel -#}
244
+ {%- set thinking_text = message.get('reasoning') or message.get('reasoning_content') -%}
245
+ {%- if thinking_text and loop.index0 > ns_turn.last_user_idx and message.get('tool_calls') -%}
246
+ {{- '<|channel>thought\n' + thinking_text + '\n<channel|>' -}}
247
+ {%- endif -%}
248
 
249
  {%- if message['tool_calls'] -%}
250
  {%- for tool_call in message['tool_calls'] -%}
 
265
  {%- set ns.prev_message_type = 'tool_call' -%}
266
  {%- endif -%}
267
 
268
+ {%- set ns_tr_out = namespace(flag=false) -%}
269
+ {%- if message.get('tool_responses') -%}
270
+ {#- Legacy: tool_responses embedded on the assistant message (Google/Gemma native) -#}
271
  {%- for tool_response in message['tool_responses'] -%}
272
+ {{- format_tool_response_block(tool_response['name'] | default('unknown'), tool_response['response']) -}}
273
+ {%- set ns_tr_out.flag = true -%}
274
+ {%- set ns.prev_message_type = 'tool_response' -%}
 
 
 
 
 
 
 
 
 
275
  {%- endfor -%}
 
276
  {%- endif -%}
277
 
278
  {%- if message['content'] is string -%}
 
302
  {%- endfor -%}
303
  {%- endif -%}
304
 
305
+ {%- if not (ns_tr_out.flag and not message.get('content')) -%}
306
  {{- '<turn|>\n' -}}
307
  {%- endif -%}
308
+ {%- endif -%}
309
  {%- endfor -%}
310
 
311
  {%- if add_generation_prompt -%}
312
  {%- if ns.prev_message_type != 'tool_response' -%}
313
  {{- '<|turn>model\n' -}}
314
  {%- endif -%}
315
+ {%- if not enable_thinking | default(false) -%}
316
+ {{- '<|channel>thought\n<channel|>' -}}
317
+ {%- endif -%}
318
+ {%- endif -%}