No project description provided
Project description
The Open Class 3D Exchange (OCX) Schema
Introduction
This is the official GitHub repository for the Open Class 3D Exchange (OCX) schema (working draft version) owned and managed by the OCX Consortium.
The latest published version of the OCX schema is available from the consortium's website.
Changelog
Historic changes (pre 2.8.6)
How to contribute
The schema file is maintained using an XML editor like Altova XMLSpy.
- Installation: Simply download the schema files from the repository or clone it using git.
- Create an Issue for the proposed schema change. Follow the recipe on the Wiki on how to register an issue.
- Then create a branch from the issue, check out the branch and implement the proposed changes.
- When the implementation is completed, create a pull request.
- The pull request will have to be approved by the OCXStandard maintainer before it can be included in the working draft.
Schema versioning
We are using semantic versioning (semver) to version the OCX schema. A published schema verison follows the semver pattern on the form X.Y.Z where X, Y, and Z are non-negative integers, and MUST NOT contain leading zeroes. X is the major version, Y is the minor version, and Z is the patch version. Each element MUST increase numerically. For instance: 1.9.0 -> 1.10.0 -> 1.11.0.
A pre-release version is denoted by appending a hyphen and a pre-release identifier (alpha, beta ...) immediately following the patch version, for example: 3.0.0-alpha
If a pre-release tag needs to be patched, append a letter to the tag separated with an underscore, eg. 3.0.0-alpha_b. Do not use .
(dot) as separator.
tbump
versioning tool
The Python tbump
tool is used to automate and bump schema versions. tbump also provides the possibility for pre- and post-commit actions.
The project config file pyproject.toml
contains the tbump settings.
Usage
Assume that the current schema version is 2.8.6
. To bump the schema version to the pre-release alpha
version, the following command can be issued:
> tbump 3.0.0-alpha
:: Bumping from 2.8.6 to 3.0.0-alpha
=> Would update current version in pyproject.toml
=> Would patch these files
- pyproject.toml:3 version = "2.8.6"
+ pyproject.toml:3 version = "3.0.0-alpha"
- pyproject.toml:34 current = "2.8.6"
+ pyproject.toml:34 current = "3.0.0-alpha"
- OCX_Schema.xsd:103
+ OCX_Schema.xsd:103
- OCX_Schema.xsd:12 xmlns:ocx="https://3docx.org/fileadmin//ocx_schema//V286//OCX_Schema.xsd"
+ OCX_Schema.xsd:12 xmlns:ocx="https://3docx.org/fileadmin//ocx_schema//V300alpha//OCX_Schema.xsd"
- OCX_Schema.xsd:14 targetNamespace="https://3docx.org/fileadmin//ocx_schema//V286//OCX_Schema.xsd"
+ OCX_Schema.xsd:14 targetNamespace="https://3docx.org/fileadmin//ocx_schema//V300alpha//OCX_Schema.xsd"
=> Would run these hooks before commit
* (1/4) $ python xsdata_package.py 3.0.0-alpha
* (2/4) $ xsdata generate OCX_Schema.xsd
* (3/4) $ gid add ./ocx_*
* (4/4) $ python insert_version.py 3.0.0-alpha
=> Would run these git commands
$ git add --update
$ git commit --message Bump to 3.0.0-alpha
$ git tag --annotate --message v3.0.0-alpha v3.0.0-alpha
$ git push --atomic origin working_draft v3.0.0-alpha
:: Looking good? (y/N)
>
Naive databinding
A set of Python dataclasses are autogenerated after each version release, see databindings
OCX Public License
The OCX standard is governed by the 3Docx.org (https://3Docx.org) Consortium Members and published under the Apache 2.0 Public License conditions (the License).
You may obtain a copy of the License at:
Unless required by applicable law or agreed to in writing, the 3Docx standard and software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. The OCX Consortium is not liable to any use whatsoever of the distributed standard or software based on the standard.
See the License for the specific language governing permissions and limitations under the License.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.