Skip to main content

Extensible linter and quality pipeline for RDF, SKOS, OWL and RDFS vocabularies

Project description

semanticlint

semanticlint

Extensible linter and quality pipeline for RDF, SKOS, OWL and RDFS vocabularies.

PyPI version CI Coverage Ruff License


Features

  • Stage 1 — Lint: syntax validation for Turtle, RDF/XML, N-Triples, JSON-LD
  • Stage 2 — Integrity: SKOS integrity conditions (W3C), OWL consistency, RDFS checks
  • Stage 3 — Quality: label coverage, definition coverage, hierarchy metrics
  • Auto-detection: identifies SKOS / OWL / RDFS / RDF vocabulary types automatically
  • Extensible: add custom checks with a single class and @CheckRegistry.register
  • Configurable: onto-ci.yml alongside your vocabulary files controls which stages run

Installation

pip install semanticlint

Quick start

semanticlint check my-taxonomy.ttl
semanticlint check vocabularies/ --select SKO --ignore SKO003

Writing a custom check

from semanticlint import Check, CheckRegistry, VocabType, Severity, Violation
from rdflib import RDF
from rdflib.namespace import SKOS

@CheckRegistry.register
class CamelCaseConceptCheck(Check):
    id          = "CUS001"
    description = "Concept local names should be CamelCase"
    severity    = Severity.WARNING
    applies_to  = VocabType.SKOS

    def run(self, graph, config):
        violations = []
        for concept in graph.subjects(RDF.type, SKOS.Concept):
            local = str(concept).split("#")[-1].split("/")[-1]
            if not local[0].isupper():
                violations.append(Violation(self.id, f"{local} is not CamelCase", self.severity, concept))
        return violations

Configuration (onto-ci.yml)

version: 1
sources: ["*.ttl", "vocabularies/**/*.ttl"]

select: ["RDF", "SKO", "QUA"]
ignore: []

quality:
  min_label_coverage: 1.0
  min_definition_coverage: 0.5
  languages: ["en"]

plugins:
  - my_project.custom_checks

License

MIT — logo is public domain (W3C RDF logo via Wikimedia Commons).

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

semanticlint-0.2.0.tar.gz (70.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

semanticlint-0.2.0-py3-none-any.whl (15.6 kB view details)

Uploaded Python 3

File details

Details for the file semanticlint-0.2.0.tar.gz.

File metadata

  • Download URL: semanticlint-0.2.0.tar.gz
  • Upload date:
  • Size: 70.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for semanticlint-0.2.0.tar.gz
Algorithm Hash digest
SHA256 1ba32d0c423b5134c70c39e70e912f8498ec59abe0b22c0b25f75ff058d1e508
MD5 b7839e3ce49fee72933627c4dda8c5f5
BLAKE2b-256 e7a9c9794cb9c9e19fb39e76565aee861f1fa92bd0ab95cf8db0df829fc87cb4

See more details on using hashes here.

Provenance

The following attestation bundles were made for semanticlint-0.2.0.tar.gz:

Publisher: publish.yml on gbelbe/semanticlint

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file semanticlint-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: semanticlint-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 15.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for semanticlint-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f188deb3831c6a204d761f90f67ac3be1070d0841de4c9345b1ab2ab5210c620
MD5 63292f4e49f03883d787cf083240e0fc
BLAKE2b-256 1f6679c4e8ca167960a33e770e900554821ed462aa6ea914c2c4cfb8bc029ffe

See more details on using hashes here.

Provenance

The following attestation bundles were made for semanticlint-0.2.0-py3-none-any.whl:

Publisher: publish.yml on gbelbe/semanticlint

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page