Skip to main content

A prettifier for CWL code

Project description

CWL Format

CWL Format is a specification and a reference implementation for a very opinionated CWL code formatter.

It outputs CWL in a standardized YAML format. It has no settings or options because you have better things to do with your time. And because CWL Format is always correct.

This repository lists the formatting rules and also contains a Python implementation of the formatter.

Rules

  • Only comment lines at the top of the file, including blank lines, before the actual CWL code are preserved. All other comments are lost. Do not use this if all comments in the YAML are important to you.

  • All CWL fields are ordered systematically. The field order for specific fields have a defined precedence ("pinned fields"). Any fields not present in this file ("free fields") are printed after the pinned fields and ordered alphabetically.

  • The pinned fields are defined in this YAML file.

  • Specific pinned field orderings are available for CommandLineTool, ExpressionTool and Workflow processes. All other types follow a generic pinned field list.

  • All strings that fit within 80 columns are expressed in flow style. Longer strings or strings with new lines are expressed in block style.

  • All lists and maps are expressed in block style

  • The ordering of all lists are preserved

  • Indentation is 2 spaces, including for lists

Conformance tests

A series of documents are found in the tests directory that can be used to check correctness of a formatter. The files named original-* are the input files and the files named formatted-* are the corresponding formatted documents. There are a mixture of YAML and JSON input files. Formatted files are always YAML.

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

cwlformat-2020.3.26.1-py3-none-any.whl (4.6 kB view hashes)

Uploaded Python 3

Supported by

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