NickMystic commited on
Commit
bd8e5c2
·
verified ·
1 Parent(s): 37261ff

Upload chat_template.jinja with huggingface_hub

Browse files
Files changed (1) hide show
  1. chat_template.jinja +289 -0
chat_template.jinja ADDED
@@ -0,0 +1,289 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ {% if 'role' in messages[0] %}
2
+ {%- if tools %}
3
+ {{- '<|im_start|>system
4
+ ' }}
5
+ {%- if messages[0].role == 'system' %}
6
+ {{- messages[0].content + '
7
+
8
+ ' }}
9
+ {%- endif %}
10
+ {{- "# Tools
11
+
12
+ You may call one or more functions to assist with the user query.
13
+
14
+ You are provided with function signatures within <tools></tools> XML tags:
15
+ <tools>" }}
16
+ {%- for tool in tools %}
17
+ {{- "
18
+ " }}
19
+ {{- tool | tojson }}
20
+ {%- endfor %}
21
+ {{- "
22
+ </tools>
23
+
24
+ For each function call, return a json object with function name and arguments within <tool_call></tool_call> XML tags:
25
+ <tool_call>
26
+ {\"name\": <function-name>, \"arguments\": <args-json-object>}
27
+ </tool_call><|im_end|>
28
+ " }}
29
+ {%- else %}
30
+ {%- if messages[0].role == 'system' %}
31
+ {{- '<|im_start|>system
32
+ ' + messages[0].content + '<|im_end|>
33
+ ' }}
34
+ {%- endif %}
35
+ {%- endif %}
36
+ {%- set ns = namespace(multi_step_tool=true, last_query_index=messages|length - 1) %}
37
+ {%- for forward_message in messages %}
38
+ {%- set index = (messages|length - 1) - loop.index0 %}
39
+ {%- set message = messages[index] %}
40
+ {%- set current_content = message.content if message.content is not none else '' %}
41
+ {%- set tool_start = '<tool_response>' %}
42
+ {%- set tool_start_length = tool_start|length %}
43
+ {%- set start_of_message = current_content[:tool_start_length] %}
44
+ {%- set tool_end = '</tool_response>' %}
45
+ {%- set tool_end_length = tool_end|length %}
46
+ {%- set start_pos = (current_content|length) - tool_end_length %}
47
+ {%- if start_pos < 0 %}
48
+ {%- set start_pos = 0 %}
49
+ {%- endif %}
50
+ {%- set end_of_message = current_content[start_pos:] %}
51
+ {%- if ns.multi_step_tool and message.role == "user" and not(start_of_message == tool_start and end_of_message == tool_end) %}
52
+ {%- set ns.multi_step_tool = false %}
53
+ {%- set ns.last_query_index = index %}
54
+ {%- endif %}
55
+ {%- endfor %}
56
+ {%- for message in messages %}
57
+ {%- if (message.role == "user") or (message.role == "system" and not loop.first) %}
58
+ {{- '<|im_start|>' + message.role + '
59
+ ' + message.content + '<|im_end|>' + '
60
+ ' }}
61
+ {%- elif message.role == "assistant" %}
62
+ {%- set content = message.content %}
63
+ {%- set reasoning_content = '' %}
64
+ {%- if message.reasoning_content is defined and message.reasoning_content is not none %}
65
+ {%- set reasoning_content = message.reasoning_content %}
66
+ {%- else %}
67
+ {%- if '</think>' in message.content %}
68
+ {%- set content = (message.content.split('</think>')|last).lstrip('
69
+ ') %}
70
+ {%- set reasoning_content = (message.content.split('</think>')|first).rstrip('
71
+ ') %}
72
+ {%- set reasoning_content = (reasoning_content.split('<think>')|last).lstrip('
73
+ ') %}
74
+ {%- endif %}
75
+ {%- endif %}
76
+ {%- if loop.index0 > ns.last_query_index %}
77
+ {%- if loop.last or (not loop.last and reasoning_content) %}
78
+ {{- '<|im_start|>' + message.role + '
79
+ <think>
80
+ ' + reasoning_content.strip('
81
+ ') + '
82
+ </think>
83
+
84
+ ' + content.lstrip('
85
+ ') }}
86
+ {%- else %}
87
+ {{- '<|im_start|>' + message.role + '
88
+ ' + content }}
89
+ {%- endif %}
90
+ {%- else %}
91
+ {{- '<|im_start|>' + message.role + '
92
+ ' + content }}
93
+ {%- endif %}
94
+ {%- if message.tool_calls %}
95
+ {%- for tool_call in message.tool_calls %}
96
+ {%- if (loop.first and content) or (not loop.first) %}
97
+ {{- '
98
+ ' }}
99
+ {%- endif %}
100
+ {%- if tool_call.function %}
101
+ {%- set tool_call = tool_call.function %}
102
+ {%- endif %}
103
+ {{- '<tool_call>
104
+ {"name": "' }}
105
+ {{- tool_call.name }}
106
+ {{- '", "arguments": ' }}
107
+ {%- if tool_call.arguments is string %}
108
+ {{- tool_call.arguments }}
109
+ {%- else %}
110
+ {{- tool_call.arguments | tojson }}
111
+ {%- endif %}
112
+ {{- '}
113
+ </tool_call>' }}
114
+ {%- endfor %}
115
+ {%- endif %}
116
+ {{- '<|im_end|>
117
+ ' }}
118
+ {%- elif message.role == "tool" %}
119
+ {%- if loop.first or (messages[loop.index0 - 1].role != "tool") %}
120
+ {{- '<|im_start|>user' }}
121
+ {%- endif %}
122
+ {{- '
123
+ <tool_response>
124
+ ' }}
125
+ {{- message.content }}
126
+ {{- '
127
+ </tool_response>' }}
128
+ {%- if loop.last or (messages[loop.index0 + 1].role != "tool") %}
129
+ {{- '<|im_end|>
130
+ ' }}
131
+ {%- endif %}
132
+ {%- endif %}
133
+ {%- endfor %}
134
+ {%- if add_generation_prompt %}
135
+ {{- '<|im_start|>assistant
136
+ ' }}
137
+ {%- if enable_thinking is defined and enable_thinking is false %}
138
+ {{- '<think>
139
+
140
+ </think>
141
+
142
+ ' }}
143
+ {%- endif %}
144
+ {%- endif %}
145
+ {% else %}
146
+ {%- if tools %}
147
+ {{- '<|im_start|>system
148
+ ' }}
149
+ {%- if messages[0].role == 'system' %}
150
+ {{- messages[0].content + '
151
+
152
+ ' }}
153
+ {%- endif %}
154
+ {{- "# Tools
155
+
156
+ You may call one or more functions to assist with the user query.
157
+
158
+ You are provided with function signatures within <tools></tools> XML tags:
159
+ <tools>" }}
160
+ {%- for tool in tools %}
161
+ {{- "
162
+ " }}
163
+ {{- tool | tojson }}
164
+ {%- endfor %}
165
+ {{- "
166
+ </tools>
167
+
168
+ For each function call, return a json object with function name and arguments within <tool_call></tool_call> XML tags:
169
+ <tool_call>
170
+ {\"name\": <function-name>, \"arguments\": <args-json-object>}
171
+ </tool_call><|im_end|>
172
+ " }}
173
+ {%- else %}
174
+ {%- if messages[0].role == 'system' %}
175
+ {{- '<|im_start|>system
176
+ ' + messages[0].content + '<|im_end|>
177
+ ' }}
178
+ {%- endif %}
179
+ {%- endif %}
180
+ {%- set ns = namespace(multi_step_tool=true, last_query_index=messages|length - 1) %}
181
+ {%- for forward_message in messages %}
182
+ {%- set index = (messages|length - 1) - loop.index0 %}
183
+ {%- set message = messages[index] %}
184
+ {%- set current_content = message.content if message.content is not none else '' %}
185
+ {%- set tool_start = '<tool_response>' %}
186
+ {%- set tool_start_length = tool_start|length %}
187
+ {%- set start_of_message = current_content[:tool_start_length] %}
188
+ {%- set tool_end = '</tool_response>' %}
189
+ {%- set tool_end_length = tool_end|length %}
190
+ {%- set start_pos = (current_content|length) - tool_end_length %}
191
+ {%- if start_pos < 0 %}
192
+ {%- set start_pos = 0 %}
193
+ {%- endif %}
194
+ {%- set end_of_message = current_content[start_pos:] %}
195
+ {%- if ns.multi_step_tool and message.role == "user" and not(start_of_message == tool_start and end_of_message == tool_end) %}
196
+ {%- set ns.multi_step_tool = false %}
197
+ {%- set ns.last_query_index = index %}
198
+ {%- endif %}
199
+ {%- endfor %}
200
+ {%- for message in messages %}
201
+ {%- if (message.role == "user") or (message.role == "system" and not loop.first) %}
202
+ {{- '<|im_start|>' + message.role + '
203
+ ' + message.content + '<|im_end|>' + '
204
+ ' }}
205
+ {%- elif message.role == "assistant" %}
206
+ {%- set content = message.content %}
207
+ {%- set reasoning_content = '' %}
208
+ {%- if message.reasoning_content is defined and message.reasoning_content is not none %}
209
+ {%- set reasoning_content = message.reasoning_content %}
210
+ {%- else %}
211
+ {%- if '</think>' in message.content %}
212
+ {%- set content = (message.content.split('</think>')|last).lstrip('
213
+ ') %}
214
+ {%- set reasoning_content = (message.content.split('</think>')|first).rstrip('
215
+ ') %}
216
+ {%- set reasoning_content = (reasoning_content.split('<think>')|last).lstrip('
217
+ ') %}
218
+ {%- endif %}
219
+ {%- endif %}
220
+ {%- if loop.index0 > ns.last_query_index %}
221
+ {%- if loop.last or (not loop.last and reasoning_content) %}
222
+ {{- '<|im_start|>' + message.role + '
223
+ <think>
224
+ ' + reasoning_content.strip('
225
+ ') + '
226
+ </think>
227
+
228
+ ' + content.lstrip('
229
+ ') }}
230
+ {%- else %}
231
+ {{- '<|im_start|>' + message.role + '
232
+ ' + content }}
233
+ {%- endif %}
234
+ {%- else %}
235
+ {{- '<|im_start|>' + message.role + '
236
+ ' + content }}
237
+ {%- endif %}
238
+ {%- if message.tool_calls %}
239
+ {%- for tool_call in message.tool_calls %}
240
+ {%- if (loop.first and content) or (not loop.first) %}
241
+ {{- '
242
+ ' }}
243
+ {%- endif %}
244
+ {%- if tool_call.function %}
245
+ {%- set tool_call = tool_call.function %}
246
+ {%- endif %}
247
+ {{- '<tool_call>
248
+ {"name": "' }}
249
+ {{- tool_call.name }}
250
+ {{- '", "arguments": ' }}
251
+ {%- if tool_call.arguments is string %}
252
+ {{- tool_call.arguments }}
253
+ {%- else %}
254
+ {{- tool_call.arguments | tojson }}
255
+ {%- endif %}
256
+ {{- '}
257
+ </tool_call>' }}
258
+ {%- endfor %}
259
+ {%- endif %}
260
+ {{- '<|im_end|>
261
+ ' }}
262
+ {%- elif message.role == "tool" %}
263
+ {%- if loop.first or (messages[loop.index0 - 1].role != "tool") %}
264
+ {{- '<|im_start|>user' }}
265
+ {%- endif %}
266
+ {{- '
267
+ <tool_response>
268
+ ' }}
269
+ {{- message.content }}
270
+ {{- '
271
+ </tool_response>' }}
272
+ {%- if loop.last or (messages[loop.index0 + 1].role != "tool") %}
273
+ {{- '<|im_end|>
274
+ ' }}
275
+ {%- endif %}
276
+ {%- endif %}
277
+ {%- endfor %}
278
+ {%- if add_generation_prompt %}
279
+ {{- '<|im_start|>assistant
280
+ ' }}
281
+ {%- if enable_thinking is defined and enable_thinking is false %}
282
+ {{- '<think>
283
+
284
+ </think>
285
+
286
+ ' }}
287
+ {%- endif %}
288
+ {%- endif %}
289
+ {% endif %}