In the Julia Zulip server, we have something called “linkifiers” which basically just use a regex to detect specific patterns in text, and turn them into links automatically. The main thing we use this for is to turn strings like “DifferentialEquations.jl” into an automatic link pointing to the JuliaHub page for DifferentialEquations: https://juliahub.com/ui/Packages/General/DifferentialEquations, which should work for any package on the general registry. (previously, we did a Github search, but we switched to JuliaHub around a month ago and it’s been mostly good!)
Is this something people would be interested in having on Discourse? I quite like it in Zulip, so maybe if there’s enough interest, the admins here on Discourse could enable it?
Here’s a little poll if people want to weigh in that way:
I’d like this feature as described
I don’t want this specific implementation, but want something similar
people voting for “I don’t want this specific implementation, but want something similar”, it’d be helpful to comment on what that similar thing you want is. Sorry, I should have mentioned in the original post.
Thanks everyone for your input! Looks like we have a solid majority in favor, let’s try it out. Here’s what I’ve implemented (note that you may need to refresh to get the links):
This is a Julia issue: julia#265
These are Julia commits: julia@7327a8f, julia@72cd63ce28c50c8c72e009df03dfec608802450e
This is a package issue: JuliaStats/Distributions.jl#123
This is a registered package info page on JuliaHub: Distributions.jl
This is a GitHub package link: JuliaStats/Distributions.jl
If you see anything awry or have other suggestions, please make your voice known!
@Mason, just FYI, I added \bs to the beginning of these regexes, which isn’t how it’s configured on Zulip. It may help reduce some false positives, like someone writing path/to/src/SubModule/SubModule.jl without ``s.
I wonder if and/or how we could display these rules. Unlike Zulip, by default Discourse doesn’t display these to users (I don’t think). Anyhow, these are the rules as of right now (the component doesn’t support named groups):
The . in .jl in the regexes should be escaped to not match any character. I noticed this while trying to opt out of this feature in some places (e.g. it looks a bit silly in Markdown headers IMO) but replacing . with e.g. ․ ( U+2024 but looks like it is normalized to . on here) or some other dot looking character didn’t work. Is there another way to opt out?
Given the problems reported in other threads (e.g. Automatic package link pages have poor layout) with the juliahub generated READMEs / docs, i wonder if it’d be possible to make the linkifier send people directly to the source link rather than the juliahub-generated README, since there’s a better chance of the content being correctly displayed on the original hosting platform
oh very nice. I think if we just used this technique and then set up a github action to update it with new links from the general registry a couple times a day, that’d be pretty close to a perfect solution
We’re now using these linkifiers on Zulip and it’s really nice. Thank you again for putting in the work to make these redirect pages @jules.
@mbauman what do you think? Can we switch the Discourse linkifiers to use these redirect pages from the General Registry? I think this solution is a much better fit than the JuliaHub pages because
it’s significantly faster to load
Authors intend for people to visit their repos, and they have control over those repos, unlike the JuliaHub pages (i.e. if a problem comes up with their presentation, they know and they can change it), so it feels like a disservice to send people somewhere that they have no control over.
it gives more immediate access to things like issues / pull requests / giving stars
Most authors don’t check the JuliaHub pages and don’t know if auto-generated pages screwed up their docs or their README (this has happened to me before and was quite aggravating, especially because after I discovered it, there was no way to fix it other than switch from using Org to Markdown for my README.)
The General Registry 404 fallback page is significantly more helpful for finding non-registered packages, or dealing with misspelt package names
Seems like a good change to me. The JuliaHub hosted docs were meant to be a service to the community but they’ve caused as much trouble as they’ve helped. Let’s go ahead and switch to the new linkifiers.
And just to be clear I don’t want to be too negative, or imply anything bad about the intentions behind them. I think it was a well intentioned idea, and I still think it’s good that they exist (though perhaps the build process needs some work).
It was even my (not JuliaHub affiliated) suggestion at the start of this thread to introduce these linkifiers that point to the JuliaHub pages because I thought they were a great idea. But I think after trying them out for a while they’re not such a great fit for the main way to link to a package on a place like Discourse or Zulip. Now that we have a way to link to the original repo, it’d be good to give that a try.
Sometimes you only know if the problems with an idea are minor or major once you try it out.
Thanks so much for doing this @jules! I’ve just updated the rules; reload your page and all previously auto-linkified package names should use the new direct-to-repo service (although note this doesn’t apply to quotes, which hardcode the link at the time of authoring).