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

Prevent duplicate prefixes #163

Open
wants to merge 4 commits into
base: master
Choose a base branch
from

Conversation

simonvbrae
Copy link

Fixing Issue #149.

Some questions:
Should I also account for "PREFIX" not being written all caps in the query?
Can I assume that PREFIX lines start with PREFIX or with only whitespace before?
Can I assume that each PREFIX declaration is on a seperate line starting with PREFIX? Or could there be multiple?
Can prefixes be declared deeper in the query or only at the top?

@rubensworks
Copy link
Member

Instead of parsing the query manually, I would recommend plugging into the actual SPARQL parser.
This would also solve the questions you raised above, and make the code more robust.

I don't remember if the jquery widget here will actually call the parser here directly.
So duplicate handling may actually be necessary to do in comunica base, or even SPARQL.js.

@simonvbrae
Copy link
Author

Since it doesn't look like Jquery calls the parser, I'll have a look at doing it further up. Comunica seems like the logical place to do duplicate handling. For this case, using the last-defined prefix in the case of a duplicate should work.

var prefixesString = '';
if (this.options.queryFormat === 'sparql') {
for (var prefix in this.options.prefixes)
prefixesString += 'PREFIX ' + prefix + ': <' + this.options.prefixes[prefix] + '>\n';
}
let query = prefixesString + queryWithoutPrefixes;
let query = prefixesString + this.$queryTextsIndexed[this.options.queryFormat].val();
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could you check if it's possible to pass these prefixes directly to the SparqlParser options?
I think there was an option for that.
If that's possible, we don't need the prefixesString anymore.

let query = prefixesString + this.$queryTextsIndexed[this.options.queryFormat].val();

// Remove duplicate prefixes
const parsedQuery = new SparqlParser({ sparqlStar: true }).parse(query);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This can only be done if if (this.options.queryFormat === 'sparql') { (because queries can also be defined as GraphQL)

prefixesString += 'PREFIX ' + prefix + ': <' + this.options.prefixes[prefix] + '>\n';
// Add pre-defined prefixes to query and remove duplicates
const parsedQuery = new SparqlParser({ prefixes:this.options.prefixes, sparqlStar: true }).parse(query);
query = new SparqlGenerator({}).stringify(parsedQuery);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This looks perfect!

@simonvbrae simonvbrae force-pushed the fix-query-interface-adds-prefix-declarations branch from a50c364 to 5432f57 Compare October 18, 2024 00:20
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