Commit 0fd342e
authored
fix: granite33 citation spans wrong for duplicate sentences (generative-computing#851) (generative-computing#872)
str.find() without an offset always returned the first occurrence, so
when the same sentence appeared more than once in the response, every
citation after the first got response_begin/response_end pointing at
the first occurrence.
Introduce search_offset that advances past each consumed sentence.
When find() misses after search_offset the sentence appears only once
(multiple citations on one sentence); fall back to searching from the
start so those citations share the correct span.
Adds two regression tests to TestAddCitationResponseSpans:
- test_duplicate_sentences_each_get_own_span
- test_multiple_citations_on_same_sentence_share_span
Assisted-by: Claude Code
Signed-off-by: Nigel Jones <jonesn@uk.ibm.com>1 parent 8501b3d commit 0fd342e
2 files changed
Lines changed: 73 additions & 7 deletions
File tree
- mellea/formatters/granite/granite3/granite33
- test/formatters/granite
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
211 | 211 | | |
212 | 212 | | |
213 | 213 | | |
214 | | - | |
215 | | - | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
216 | 221 | | |
217 | 222 | | |
218 | | - | |
| 223 | + | |
| 224 | + | |
219 | 225 | | |
220 | | - | |
221 | | - | |
222 | | - | |
223 | | - | |
| 226 | + | |
| 227 | + | |
| 228 | + | |
| 229 | + | |
| 230 | + | |
| 231 | + | |
| 232 | + | |
| 233 | + | |
| 234 | + | |
| 235 | + | |
224 | 236 | | |
225 | 237 | | |
226 | 238 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
292 | 292 | | |
293 | 293 | | |
294 | 294 | | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
| 320 | + | |
| 321 | + | |
| 322 | + | |
| 323 | + | |
| 324 | + | |
| 325 | + | |
| 326 | + | |
| 327 | + | |
| 328 | + | |
| 329 | + | |
| 330 | + | |
| 331 | + | |
| 332 | + | |
| 333 | + | |
| 334 | + | |
| 335 | + | |
| 336 | + | |
| 337 | + | |
| 338 | + | |
| 339 | + | |
| 340 | + | |
| 341 | + | |
| 342 | + | |
| 343 | + | |
| 344 | + | |
| 345 | + | |
| 346 | + | |
| 347 | + | |
| 348 | + | |
295 | 349 | | |
296 | 350 | | |
297 | 351 | | |
| |||
0 commit comments