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.3.1.tar.gz (75.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.3.1-py3-none-any.whl (18.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: semanticlint-0.3.1.tar.gz
  • Upload date:
  • Size: 75.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.3.1.tar.gz
Algorithm Hash digest
SHA256 2295e66c43f3ce6bdc8794af4930a882c9ad87c22ab56b4c590225d2c0e6cbc6
MD5 669e1fc15f897c2823ec4e81219019ac
BLAKE2b-256 1e216c4176ba66bb6a45fded35ff9aea9b7fed00173caeba7ecff46b208c02bd

See more details on using hashes here.

Provenance

The following attestation bundles were made for semanticlint-0.3.1.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.3.1-py3-none-any.whl.

File metadata

  • Download URL: semanticlint-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 18.0 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.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 ef13c39c493af6ee7afa72b99747314fac5932d0b12eaad2fd188d1baebdb16f
MD5 5f978c1a3ab2bc76c61caa658b517a48
BLAKE2b-256 fd6d8fd91a7a0ffda02b638cc925a97b89f891396fea1f282cf1e389f0f433bd

See more details on using hashes here.

Provenance

The following attestation bundles were made for semanticlint-0.3.1-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