Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Inconsistent sourcepos for two link types #478

Open
SamWilsn opened this issue Oct 23, 2024 · 3 comments
Open

Inconsistent sourcepos for two link types #478

SamWilsn opened this issue Oct 23, 2024 · 3 comments

Comments

@SamWilsn
Copy link
Contributor

Running into a bit of a confusing problem (at least for me.) Two different kinds of links give different sourcepos values when I believe they should be the same.

Here's some demo code:

use comrak::{
    arena_tree::{Node, NodeEdge},
    nodes::{NodeValue, Sourcepos},
    parse_document, Arena, ExtensionOptions, Options,
};

fn demo(source: &str) -> Sourcepos {
    let arena = Arena::new();
    let mut extension = ExtensionOptions::default();
    extension.autolink = true;

    let root = parse_document(
        &arena,
        source,
        &Options {
            extension,
            ..Default::default()
        },
    );

    let link = root
        .traverse()
        .filter_map(|x| match x {
            NodeEdge::Start(Node { data, .. }) => Some(data.borrow().clone()),
            _ => None,
        })
        .filter(|x| matches!(x.value, NodeValue::Link(_)))
        .next()
        .unwrap();

    link.sourcepos
}

fn main() {
    let a = demo("hello <https://example.com/fooo> world");
    let b = demo("hello [foo](https://example.com) world");
    assert_eq!(a, b);
}

And the output I'm getting:

thread 'main' panicked at src/main.rs:37:5:
assertion `left == right` failed
  left: Sourcepos { start: LineColumn { line: 1, column: 8 }, end: LineColumn { line: 1, column: 33 } }
 right: Sourcepos { start: LineColumn { line: 1, column: 7 }, end: LineColumn { line: 1, column: 32 } }
note: run with `RUST_BACKTRACE=1` environment variable to display a backtrace
@digitalmoksha
Copy link
Collaborator

Hmm, I think you're right. It looks like [foo](https://example.com) is generating the correct sourcepos, but <https://example.com/fooo> isn't. They should give the same value, as both links start and end in the same column.

@SamWilsn
Copy link
Contributor Author

There seems to be a similar issue with footnote-style links:

    let b = demo("hello [foo][ooooooooooooooooooo] world\n\n[ooooooooooooooooooo]: https://example.com");

@digitalmoksha
Copy link
Collaborator

And thus the naming of the experimental-inline-sourcepos option 😆 😢

Thank for you for also mentioning the above case. Keep them coming as you find them...

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants