-
Notifications
You must be signed in to change notification settings - Fork 15
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
rename to cromulent for pypi uniqueness
- Loading branch information
Showing
10 changed files
with
157 additions
and
121 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,6 +13,6 @@ notifications: | |
recipients: | ||
- [email protected] | ||
script: | ||
coverage run --source=crom setup.py test | ||
coverage run --source=cromulent setup.py test | ||
after_success: | ||
coveralls |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,10 +1,53 @@ | ||
[data:image/s3,"s3://crabby-images/31145/311451fe578d7df4a9f3f8606b5f32e07c0c4a02" alt="Build Status"](https://travis-ci.org/azaroth42/crom) [data:image/s3,"s3://crabby-images/cbf8f/cbf8f82d6ab00b4d26fa798053f30943d98e9069" alt="Coverage Status"](https://coveralls.io/github/azaroth42/crom?branch=master) | ||
|
||
# Python-CIDOC-ORM | ||
Python library to make creation of CIDOC CRM easier by mapping classes/predicates to python objects | ||
# Cromulent | ||
|
||
# Status | ||
Very Alpha. Extracted the interesting bits from IIIF-Prezi and refactored to be a bit stricter. | ||
Parses an extraction of the CRM ontology as TSV to generate class hierarchy and property/predicate mapping. | ||
A Python library to make creation of CIDOC CRM easier by mapping classes/predicates to python objects/properties, thereby making the CRM "CRoMulent", a Simpsons neologism for "acceptable" or "fine". | ||
|
||
## Status | ||
|
||
Alpha. Active development and compatibility breaking changes to be expected as we use it in anger in various projects at The Getty, and beyond. | ||
|
||
## How to Use It | ||
|
||
### Basic Usage | ||
|
||
```python | ||
from cromulent.model import Person | ||
p = Person("Mother") | ||
p2 = Person("Son") | ||
p3 = Person("Daughter") | ||
p.parent_of = p2 | ||
p.parent_of = p3 | ||
``` | ||
|
||
Some tricks to know: | ||
|
||
* Assigning to the same property repeatedly does NOT overwrite the value, instead it appends. To overwrite a value, instead set it to a false value first. | ||
|
||
### Factory settings | ||
|
||
There are several settings for how the module works, which are managed by a `factory` object in model. | ||
|
||
* `base_url` The base url on to which to append any slug given when an object is created | ||
* `base_dir` The base directory into which to write files, via factory.toFile() | ||
* `default_lang` The code for the default language to use on text values | ||
* `context_uri` The URI to use for `@context` in the JSON-LD serialization | ||
* `debug_level` Settings for debugging errors and warnings, defaults to "warn" | ||
* `log_stream` An object implementing the stream API to write log messages to, defaults to sys.stderr | ||
* `materialize_inverses` Should the inverse relationships be set automatically, defaults to False | ||
* `filename_extension` The extension to use on files written via toFile(), defaults to ".json" | ||
* `full_names` Should the serialization use the full CRM names for classes and properties instead of the more readable ones defined in the mapping, defaults to False | ||
* `validate_properties` Should the model be validated at run time when setting properties, defaults to True (this allows you to save processing time once you're certain your code does the right thing) | ||
|
||
Note that factories are NOT thread safe during serialization. A property on the factory is used to maintain which objects have been serialized already, to avoid infinite recursion in a cyclic graph. Create a new factory object per thread if necessary. | ||
|
||
|
||
## How it Works | ||
|
||
At import time, the library parses the vocabulary data file (data/crm_vocab.tsv) and creates Python classes in the module's global scope from each of the defined RDF classes. The names of the classes are intended to be easy to use and remember, not necessarily identical to the CRM ontology's names. It also records the properties that can be used with that class, and at run time checks whether the property is defined and that the value fits the defined range. | ||
|
||
## Hacking | ||
|
||
You can change the mapping by tweaking `build_tsv/vocab_reader.py` and rerunning it to build a new TSV input file. | ||
|
||
Collaboration and feedback welcome! |
File renamed without changes.
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -7,18 +7,18 @@ | |
install_requires = [] | ||
|
||
setup( | ||
name = 'crom', | ||
packages = ['crom'], | ||
name = 'cromulent', | ||
packages = ['cromulent'], | ||
include_package_data = True, | ||
package_data = { | ||
'crom': ['data/crm_vocab.tsv'] | ||
'cromulent': ['data/crm_vocab.tsv'] | ||
}, | ||
test_suite="tests", | ||
version = '0.0.3', | ||
version = '0.1', | ||
description = 'A library for mapping CIDOC-CRM classes to Python objects', | ||
author = 'Getty Research Institute, Rob Sanderson', | ||
author_email = '[email protected]', | ||
url = 'https://github.com/gri-is/crom', | ||
url = 'https://github.com/gri-is/cromulent', | ||
install_requires=install_requires, | ||
classifiers = [ | ||
"Programming Language :: Python", | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.