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

Refactoring of some functionality in links.rs #998

Merged
merged 7 commits into from
Aug 7, 2019

Conversation

carols10cents
Copy link
Member

Hi, I have a new feature I'm working on that I could really use for the book (#618), but these refactorings make it easier. I decided to submit these first separately from the new feature, to get feedback before basing the new feature on this.

There are 2 big chunks of refactorings in this PR, and I'm happy to split them into 2 PRs if anyone wants:

  • The first commit extracts a data structure to hold the different kind of ranges, so that different kinds of file including mechanisms can use the same data structure. This reduces some kinds of repetition, but adds a bit more boilerplate.
  • The rest of the commits improve the parse_include_path function: I think I've gotten test coverage around all the branches, and I think I've improved the code while keeping those tests passing. I think the code is clearer now, but it's certainly debatable, so I'd love to hear any thoughts.

Thanks! ❤️

@carols10cents
Copy link
Member Author

Looks like the build failed because nightly can't build rand_core.... i'll try that one again tomorrow 🤷‍♀

@ehuss
Copy link
Contributor

ehuss commented Aug 6, 2019

Looks like the build failed because nightly

Yea, there is an issue with sccache, I just merged a temporary fix.

This eliminates some duplication and will enable different kinds of
LinkTypes to have line number ranges.

Implement `From` for the std `Range` types to enable easier
construction.

The new code reaaalllly makes me wish for a delegation mechanism though
:(
I'm not sure in what cases this iterator might possibly return Some
again, but let's make absolutely sure.
@carols10cents
Copy link
Member Author

Yea, there is an issue with sccache, I just merged a temporary fix.

Thank you, it passes now after a rebase!

@ehuss
Copy link
Contributor

ehuss commented Aug 7, 2019

Thanks, the parse_include_path is definitely easier to read.

@ehuss ehuss merged commit f37a89c into rust-lang:master Aug 7, 2019
@carols10cents carols10cents deleted the links-improvements branch August 13, 2019 00:55
Ruin0x11 pushed a commit to Ruin0x11/mdBook that referenced this pull request Aug 30, 2020
Refactoring of some functionality in links.rs
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants