Mercurial > repos > shellac > guppy_basecaller
comparison env/lib/python3.7/site-packages/schema_salad-4.5.20191229160203.dist-info/METADATA @ 0:26e78fe6e8c4 draft
"planemo upload commit c699937486c35866861690329de38ec1a5d9f783"
author | shellac |
---|---|
date | Sat, 02 May 2020 07:14:21 -0400 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:26e78fe6e8c4 |
---|---|
1 Metadata-Version: 2.1 | |
2 Name: schema-salad | |
3 Version: 4.5.20191229160203 | |
4 Summary: Schema Annotations for Linked Avro Data (SALAD) | |
5 Home-page: https://github.com/common-workflow-language/schema_salad | |
6 Author: Common workflow language working group | |
7 Author-email: common-workflow-language@googlegroups.com | |
8 License: Apache 2.0 | |
9 Download-URL: https://github.com/common-workflow-language/schema_salad/releases | |
10 Platform: UNKNOWN | |
11 Classifier: Environment :: Console | |
12 Classifier: Intended Audience :: Science/Research | |
13 Classifier: License :: OSI Approved :: Apache Software License | |
14 Classifier: Operating System :: POSIX | |
15 Classifier: Operating System :: MacOS :: MacOS X | |
16 Classifier: Operating System :: Microsoft :: Windows | |
17 Classifier: Development Status :: 5 - Production/Stable | |
18 Classifier: Programming Language :: Python :: 2.7 | |
19 Classifier: Programming Language :: Python :: 3.5 | |
20 Classifier: Programming Language :: Python :: 3.6 | |
21 Classifier: Programming Language :: Python :: 3.7 | |
22 Classifier: Programming Language :: Python :: 3.8 | |
23 Classifier: Typing :: Typed | |
24 Description-Content-Type: text/x-rst | |
25 Requires-Dist: setuptools | |
26 Requires-Dist: requests (>=1.0) | |
27 Requires-Dist: ruamel.yaml (<=0.16,>=0.12.4) | |
28 Requires-Dist: rdflib (<4.3.0,>=4.2.2) | |
29 Requires-Dist: rdflib-jsonld (<0.5.0,>=0.3.0) | |
30 Requires-Dist: mistune (<0.9,>=0.8.1) | |
31 Requires-Dist: CacheControl (<0.12,>=0.11.7) | |
32 Requires-Dist: lockfile (>=0.9) | |
33 Requires-Dist: six (>=1.8.0) | |
34 Requires-Dist: typing-extensions | |
35 Requires-Dist: future | |
36 Requires-Dist: typing (>=3.7.4) ; python_version<"3.5" | |
37 Provides-Extra: docs | |
38 Requires-Dist: sphinx (>=2.2) ; extra == 'docs' | |
39 Requires-Dist: sphinx-rtd-theme ; extra == 'docs' | |
40 Requires-Dist: pytest ; extra == 'docs' | |
41 | |
42 |Linux Build Status| |Windows Build status| |Code coverage| |CII Best Practices| | |
43 | |
44 .. |Linux Build Status| image:: https://img.shields.io/travis/common-workflow-language/schema_salad/master.svg?label=unix%20build | |
45 :target: https://travis-ci.org/common-workflow-language/schema_salad | |
46 .. |Windows Build status| image:: https://img.shields.io/appveyor/ci/mr-c/schema-salad/master.svg?label=windows%20build | |
47 :target: https://ci.appveyor.com/project/mr-c/schema-salad/branch/master | |
48 .. |Code coverage| image:: https://codecov.io/gh/common-workflow-language/schema_salad/branch/master/graph/badge.svg | |
49 :target: https://codecov.io/gh/common-workflow-language/schema_salad | |
50 .. |CII Best Practices| image:: https://bestpractices.coreinfrastructure.org/projects/1867/badge | |
51 :target: https://bestpractices.coreinfrastructure.org/projects/1867 | |
52 | |
53 Schema Salad | |
54 ------------ | |
55 | |
56 Salad is a schema language for describing JSON or YAML structured | |
57 linked data documents. Salad schema describes rules for | |
58 preprocessing, structural validation, and hyperlink checking for | |
59 documents described by a Salad schema. Salad supports rich data | |
60 modeling with inheritance, template specialization, object | |
61 identifiers, object references, documentation generation, code | |
62 generation, and transformation to RDF_. Salad provides a bridge | |
63 between document and record oriented data modeling and the Semantic | |
64 Web. | |
65 | |
66 Usage | |
67 ----- | |
68 | |
69 :: | |
70 | |
71 $ pip install schema_salad | |
72 | |
73 To install from source:: | |
74 | |
75 git clone https://github.com/common-workflow-language/schema_salad | |
76 cd schema_salad | |
77 python setup.py install | |
78 | |
79 Commands | |
80 -------- | |
81 | |
82 Schema salad can be used as a command line tool or imported as a Python module:: | |
83 | |
84 $ schema-salad-tool | |
85 usage: schema-salad-tool [-h] [--rdf-serializer RDF_SERIALIZER] | |
86 [--print-jsonld-context | --print-rdfs | --print-avro | |
87 | --print-rdf | --print-pre | --print-index | |
88 | --print-metadata | --print-inheritance-dot | |
89 | --print-fieldrefs-dot | --codegen language | |
90 | --print-oneline] | |
91 [--strict | --non-strict] [--verbose | --quiet | |
92 | --debug] | |
93 [--version] | |
94 [schema] [document] | |
95 | |
96 $ python | |
97 >>> import schema_salad | |
98 | |
99 Validate a schema:: | |
100 | |
101 $ schema-salad-tool myschema.yml | |
102 | |
103 Validate a document using a schema:: | |
104 | |
105 $ schema-salad-tool myschema.yml mydocument.yml | |
106 | |
107 Generate HTML documentation:: | |
108 | |
109 $ schema-salad-tool myschema.yml > myschema.html | |
110 | |
111 Get JSON-LD context:: | |
112 | |
113 $ schema-salad-tool --print-jsonld-context myschema.yml mydocument.yml | |
114 | |
115 Convert a document to JSON-LD:: | |
116 | |
117 $ schema-salad-tool --print-pre myschema.yml mydocument.yml > mydocument.jsonld | |
118 | |
119 Generate Python classes for loading/generating documents described by the schema:: | |
120 | |
121 $ schema-salad-tool --codegen=python myschema.yml > myschema.py | |
122 | |
123 Display inheritance relationship between classes as a graphviz 'dot' file and | |
124 render as SVG:: | |
125 | |
126 $ schema-salad-tool --print-inheritance-dot myschema.yml | dot -Tsvg > myschema.svg | |
127 | |
128 | |
129 Quick Start | |
130 ----------- | |
131 | |
132 Let's say you have a 'basket' record that can contain items measured either by | |
133 weight or by count. Here's an example:: | |
134 | |
135 basket: | |
136 - product: bananas | |
137 price: 0.39 | |
138 per: pound | |
139 weight: 1 | |
140 - product: cucumbers | |
141 price: 0.79 | |
142 per: item | |
143 count: 3 | |
144 | |
145 We want to validate that all the expected fields are present, the | |
146 measurement is known, and that "count" cannot be a fractional value. | |
147 Here is an example schema to do that:: | |
148 | |
149 - name: Product | |
150 doc: | | |
151 The base type for a product. This is an abstract type, so it | |
152 can't be used directly, but can be used to define other types. | |
153 type: record | |
154 abstract: true | |
155 fields: | |
156 product: string | |
157 price: float | |
158 | |
159 - name: ByWeight | |
160 doc: | | |
161 A product, sold by weight. Products may be sold by pound or by | |
162 kilogram. Weights may be fractional. | |
163 type: record | |
164 extends: Product | |
165 fields: | |
166 per: | |
167 type: | |
168 type: enum | |
169 symbols: | |
170 - pound | |
171 - kilogram | |
172 jsonldPredicate: '#per' | |
173 weight: float | |
174 | |
175 - name: ByCount | |
176 doc: | | |
177 A product, sold by count. The count must be a integer value. | |
178 type: record | |
179 extends: Product | |
180 fields: | |
181 per: | |
182 type: | |
183 type: enum | |
184 symbols: | |
185 - item | |
186 jsonldPredicate: '#per' | |
187 count: int | |
188 | |
189 - name: Basket | |
190 doc: | | |
191 A basket of products. The 'documentRoot' field indicates it is a | |
192 valid starting point for a document. The 'basket' field will | |
193 validate subtypes of 'Product' (ByWeight and ByCount). | |
194 type: record | |
195 documentRoot: true | |
196 fields: | |
197 basket: | |
198 type: | |
199 type: array | |
200 items: Product | |
201 | |
202 You can check the schema and document in schema_salad/tests/basket_schema.yml | |
203 and schema_salad/tests/basket.yml:: | |
204 | |
205 $ schema-salad-tool basket_schema.yml basket.yml | |
206 Document `basket.yml` is valid | |
207 | |
208 | |
209 Documentation | |
210 ------------- | |
211 | |
212 See the specification_ and the metaschema_ (salad schema for itself). For an | |
213 example application of Schema Salad see the Common Workflow Language_. | |
214 | |
215 | |
216 Rationale | |
217 --------- | |
218 | |
219 The JSON data model is an popular way to represent structured data. It is | |
220 attractive because of it's relative simplicity and is a natural fit with the | |
221 standard types of many programming languages. However, this simplicity comes | |
222 at the cost that basic JSON lacks expressive features useful for working with | |
223 complex data structures and document formats, such as schemas, object | |
224 references, and namespaces. | |
225 | |
226 JSON-LD is a W3C standard providing a way to describe how to interpret a JSON | |
227 document as Linked Data by means of a "context". JSON-LD provides a powerful | |
228 solution for representing object references and namespaces in JSON based on | |
229 standard web URIs, but is not itself a schema language. Without a schema | |
230 providing a well defined structure, it is difficult to process an arbitrary | |
231 JSON-LD document as idiomatic JSON because there are many ways to express the | |
232 same data that are logically equivalent but structurally distinct. | |
233 | |
234 Several schema languages exist for describing and validating JSON data, such as | |
235 JSON Schema and Apache Avro data serialization system, however none | |
236 understand linked data. As a result, to fully take advantage of JSON-LD to | |
237 build the next generation of linked data applications, one must maintain | |
238 separate JSON schema, JSON-LD context, RDF schema, and human documentation, | |
239 despite significant overlap of content and obvious need for these documents to | |
240 stay synchronized. | |
241 | |
242 Schema Salad is designed to address this gap. It provides a schema language | |
243 and processing rules for describing structured JSON content permitting URI | |
244 resolution and strict document validation. The schema language supports linked | |
245 data through annotations that describe the linked data interpretation of the | |
246 content, enables generation of JSON-LD context and RDF schema, and production | |
247 of RDF triples by applying the JSON-LD context. The schema language also | |
248 provides for robust support of inline documentation. | |
249 | |
250 .. _JSON-LD: http://json-ld.org | |
251 .. _Avro: http://avro.apache.org | |
252 .. _metaschema: https://github.com/common-workflow-language/schema_salad/blob/master/schema_salad/metaschema/metaschema.yml | |
253 .. _specification: http://www.commonwl.org/v1.0/SchemaSalad.html | |
254 .. _Language: https://github.com/common-workflow-language/common-workflow-language/blob/master/v1.0/CommandLineTool.yml | |
255 .. _RDF: https://www.w3.org/RDF/ | |
256 | |
257 |