mirror of
https://github.com/rust-lang/rust.git
synced 2025-02-19 10:24:16 +00:00
![]() 8560: Escape characters in doc comments in macros correctly r=jonas-schievink a=ChayimFriedman2 Previously they were escaped twice, both by `.escape_default()` and the debug view of strings (`{:?}`). This leads to things like newlines or tabs in documentation comments being `\\n`, but we unescape literals only once, ending up with `\n`. This was hard to spot because CMark unescaped them (at least for `'` and `"`), but it did not do so in code blocks. This also was the root cause of #7781. This issue was solved by using `.escape_debug()` instead of `.escape_default()`, but the real issue remained. We can bring the `.escape_default()` back by now, however I didn't do it because it is probably slower than `.escape_debug()` (more work to do), and also in order to change the code the least. Example (the keyword and primitive docs are `include!()`d at https://doc.rust-lang.org/src/std/lib.rs.html#570-578, and thus originate from macro): Before: data:image/s3,"s3://crabby-images/91a7a/91a7a8249b871fb7cc463d0b5f4b6ae6c5e8543d" alt="image" After: data:image/s3,"s3://crabby-images/8dafc/8dafc6585331de84c6ad3ea8202ea4966965aed1" alt="image" Co-authored-by: Chayim Refael Friedman <chayimfr@gmail.com> |
||
---|---|---|
.. | ||
src | ||
Cargo.toml |