| Crates.io | lazy-sparql-result-reader |
| lib.rs | lazy-sparql-result-reader |
| version | 2.0.3 |
| created_at | 2025-12-04 21:47:31.879824+00 |
| updated_at | 2025-12-26 15:07:31.285246+00 |
| description | A lazy SPARQL result reader |
| homepage | |
| repository | https://github.com/IoannisNezis/Lazy-SPARQL-result-reader |
| max_upload_size | |
| id | 1967096 |
| size | 26,631 |
A fast SPARQL results parser for JavaScript and TypeScript, compiled from Rust via WebAssembly.
It reads streamed SPARQL query results and calls a callback for each parsed batch of bindings.
npm install lazy-sparql-result-reader vite @vitejs/plugin-wasm
Create or update vite.config.ts:
import { defineConfig } from 'vite';
import wasm from '@vitejs/plugin-wasm';
export default defineConfig({
plugins: [wasm()],
});
This allows Vite to correctly load WebAssembly modules.
import init, { read } from "lazy-sparql-result-reader?init";
// Initialize the WASM module
await init();
fetch("https://qlever.dev/api/wikidata", {
method: 'POST',
headers: {
"Accept": "application/sparql-results+json",
"Content-Type": "application/x-www-form-urlencoded;charset=UTF-8",
},
body: new URLSearchParams({
query: "SELECT * {?s ?p ?o} LIMIT 1000",
})
})
.then(async response => {
if (!response.ok) {
throw new Error(`SPARQL request failed: ${response.status}`);
}
const stream = response.body; // ReadableStream of the SPARQL JSON results
if (!stream) throw new Error("Response has no body stream");
// Parse the streamed results with the WASM parser
await read(stream, 100, (bindings) => {
console.log("Received batch of bindings:", bindings);
});
})
.catch((err) => {
console.error("Error fetching or parsing SPARQL results:", err);
});
batch_size controls how many bindings are buffered before each callback.This setup allows your JS/TS application to process streaming SPARQL results efficiently,
with immediate access to the head and incremental batches of bindings.
This project is licensed under the MIT License.
You are free to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the software, under the conditions of the MIT License.
For full details, see the LICENSE file.