You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
Jesse Wright 066b18aaf2 chore: don't suppress shex conversion errors 5 months ago
..
example-init-placeholder Fixed relative path problem for init script 5 months ago
src chore: don't suppress shex conversion errors 5 months ago
test Fix tests 10 months ago
.eslintrc Added LDO package 2 years ago
.gitignore create has all bugs fixed 10 months ago
LICENSE.txt Update Readmes 2 years ago
README.md Update links to ldo.js.org 8 months ago
jest.config.cjs Fix cli test 5 months ago
package.json feat: add shacl support 5 months ago
tsconfig.cjs.json build CLI with ESnext target 5 months ago

README.md

@ldo/cli

The @ldo/cli is a command line interface for initializing LDO and building ShapeTypes.

Setup

Automatic Setup

To setup LDO, cd into your typescript project and run npx @ldo/cli init.

cd my-typescript-project
npx @ldo/cli init
Manual Setup The following is handled by the __automatic setup__:

Install the LDO dependencies.

npm install @ldo/ldo
npm install @ldo/cli --save-dev

Create a folder to store your ShEx shapes:

mkdir shapes

Create a script to build ShEx shapes and convert them into Linked Data Objects. You can put this script in package.json

{
  ...
  scripts: {
    ...
    "build:ldo": "ldo build --input ./shapes --output ./ldo"
    ...
  }
  ...
}

Generating a ShapeType

@ldo/cli generates shape types using the *.shex files in the "input" folder. If you followed the instructions above, run the following command:

npm run build:ldo

This will generate five files:

  • ./ldo/foafProfile.shapeTypes.ts <-- This is the important file
  • ./ldo/foafProfile.typings.ts
  • ./ldo/foafProfile.schema.ts
  • ./ldo/foafProfile.context.ts

Creating a new project to distribure shapes

Sometimes, you might want to distribute shapes to others. The easiest way to do that is to deploy them to NPM. The LDO CLI has an easy-to-use command for generating a standalone project just for your shapes.

npx @ldo/cli create ./my-project

This script will generate a project with a place to put your shapes. Running npm publish will build the shapes and push to project to NPM for you.

API Details

Sponsorship

This project was made possible by a grant from NGI Zero Entrust via nlnet. Learn more on the NLnet project page.

nlnet foundation logo NGI Zero Entrust Logo

Liscense

MIT