From 2a320f21d0e5f943b9cd02bb7882531bfb7ef0b9 Mon Sep 17 00:00:00 2001 From: Earl St Sauver Date: Mon, 12 Jan 2015 01:37:01 -0800 Subject: [PATCH] Fix playpen links to not all be the same Fixes #20732, that all links in some modules point to the same code examples was reported. The ID's generated for documents in librustdoc are not all unique, which means the code rendered as text is not being properly selected. This change removes the unique id generation and instead changes the frontend code to grab the correct code sample by it's relative position in the dom. --- src/librustdoc/html/markdown.rs | 25 ++++++++----------------- src/librustdoc/html/static/playpen.js | 4 +--- 2 files changed, 9 insertions(+), 20 deletions(-) diff --git a/src/librustdoc/html/markdown.rs b/src/librustdoc/html/markdown.rs index a063191a12f..0dbd13b4616 100644 --- a/src/librustdoc/html/markdown.rs +++ b/src/librustdoc/html/markdown.rs @@ -30,7 +30,7 @@ use libc; use std::ascii::AsciiExt; use std::ffi::CString; -use std::cell::{RefCell, Cell}; +use std::cell::RefCell; use std::collections::HashMap; use std::fmt; use std::slice; @@ -155,7 +155,6 @@ fn stripped_filtered_line<'a>(s: &'a str) -> Option<&'a str> { thread_local!(static USED_HEADER_MAP: RefCell> = { RefCell::new(HashMap::new()) }); -thread_local!(static TEST_IDX: Cell = Cell::new(0)); thread_local!(pub static PLAYGROUND_KRATE: RefCell>> = { RefCell::new(None) @@ -195,26 +194,19 @@ pub fn render(w: &mut fmt::Formatter, s: &str, print_toc: bool) -> fmt::Result { if rendered { return } PLAYGROUND_KRATE.with(|krate| { let mut s = String::new(); - let id = krate.borrow().as_ref().map(|krate| { - let idx = TEST_IDX.with(|slot| { - let i = slot.get(); - slot.set(i + 1); - i - }); - + krate.borrow().as_ref().map(|krate| { let test = origtext.lines().map(|l| { stripped_filtered_line(l).unwrap_or(l) }).collect::>().connect("\n"); let krate = krate.as_ref().map(|s| s.as_slice()); let test = test::maketest(test.as_slice(), krate, false, false); - s.push_str(format!("{}", - idx, Escape(test.as_slice())).as_slice()); - format!("rust-example-rendered-{}", idx) + s.push_str(format!("{}", + Escape(test.as_slice())).as_slice()); }); - let id = id.as_ref().map(|a| a.as_slice()); - s.push_str(highlight::highlight(text.as_slice(), None, id) - .as_slice()); + s.push_str(highlight::highlight(text.as_slice(), + None, + Some("rust-example-rendered")) + .as_slice()); let output = CString::from_vec(s.into_bytes()); hoedown_buffer_puts(ob, output.as_ptr()); }) @@ -432,7 +424,6 @@ impl LangString { /// previous state (if any). pub fn reset_headers() { USED_HEADER_MAP.with(|s| s.borrow_mut().clear()); - TEST_IDX.with(|s| s.set(0)); } impl<'a> fmt::String for Markdown<'a> { diff --git a/src/librustdoc/html/static/playpen.js b/src/librustdoc/html/static/playpen.js index f7d6b872940..687f764f020 100644 --- a/src/librustdoc/html/static/playpen.js +++ b/src/librustdoc/html/static/playpen.js @@ -14,10 +14,8 @@ (function() { if (window.playgroundUrl) { $('pre.rust').hover(function() { - if (!$(this).attr('id')) { return; } - var id = '#' + $(this).attr('id').replace('rendered', 'raw'); var a = $('').text('⇱').attr('class', 'test-arrow'); - var code = $(id).text(); + var code = $(this).siblings(".rusttest").text(); a.attr('href', window.playgroundUrl + '?code=' + encodeURIComponent(code)); a.attr('target', '_blank');