-
-
Notifications
You must be signed in to change notification settings - Fork 393
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
Add ability to load other highlight languages via config #2152
Comments
There was some further work on top of that PR by @VladimirAlexiev, which led to this branch: https://github.com/VladimirAlexiev/highlight.js/tree/feature/language-sparql-ttl I've tried this for SPARQL and Turtle, and it works well. I had to follow the build instructions to create a It looks like maintainership of highlight.js is somewhat adrift at the moment (highlightjs/highlight.js#1678), so PRs are not being merged. |
We are currently moving away from using the hljs bundle. So, the way to do this is to use async function loadSparqlLang() {
const worker = await new Promise(resolve => {
require(["core/worker"], ({ worker }) => resolve(worker));
});
const action = "highlight-load-lang";
const langURL = new URL(/*URL to your language file*/).href;
// this needs to match the name of the property created in highlight js for the language
const propName = "sparql-ttl";
const lang = "sparql-ttl"; // check what this should be
worker.postMessage({ action, langURL, propName, lang });
return new Promise(resolve => {
worker.addEventListener("message", function listener({ data }) {
const { action: responseAction, lang: responseLang } = data;
if (responseAction === action && responseLang === lang) {
worker.removeEventListener("message", listener);
resolve();
}
});
});
}
var respecConfig = {
preProcess: [loadSparqlLang],
// other stuff
} In the future, we will make this a bit easier... allowing languages to be dynamically loaded by just having a |
Updated the above. |
About the language support, I followed up: We need a maintainer for the language itself. I maintain hljs now. |
My PR is also used in Ontotext training presentations, which are made with reveal.js, so I have some code to repackage hljs for reveal. We have a task to merge my PR that's been outstanding for a year but now if the w3c wants to use it, I'll requisition a JS dev to do it. See highlightjs/highlight.js#1553 and highlightjs/highlight.js#1844 |
@VladimirAlexiev that would be great. I can get the repo set up for you on the hljs side and we can go from there. |
Had a play at this locally. Unfortunately, highlightjs doesn't export the languages in the way ReSpec wants to use. ReSpec uses Possible solutions:
|
Follow-up from #1063
Description of problem
Many specs at the W3C (and elsewhere) use the Turtle format.
There is a PR to highlight.js for adding Turtle that has apparently been available since shortly after I filed #1063.
The JSON-LD WG is nearing CR for the JSON-LD 1.1 syntax document, and we use a good bit of Turtle, so having this added would help us there particularly.
Also, credit goes to @cygri for finding this highlighter! w3c/json-ld-syntax#67 (comment)
Thanks!
🎩
P.S.: The PR also includes a highlighter for SPARQL which W3C specs and notes also use from time to time.
The text was updated successfully, but these errors were encountered: