3 releases (breaking)
0.4.0 | Sep 20, 2024 |
---|---|
0.3.0 | Jun 14, 2022 |
0.2.0 | Feb 17, 2022 |
#55 in #cad
343 downloads per month
Used in truck-stepio
290KB
7K
SLoC
This project is still in experimental stage. DO NOT USE FOR PRODUCT.
ruststep
Crates for STEP (Standard for the Exchange of Product model data) written in pure Rust aimed at replacing stepcode.
name | crates.io | docs.rs | master | description |
---|---|---|---|---|
espr | EXPRESS Language (ISO 10303-11) Compiler | |||
espr-derive | proc-macro for running espr compiler | |||
ruststep | Serialize/Deserialize STEP files | |||
ruststep-derive | proc-macro helper crate |
What is STEP?
- STEP is a set of data serialize formats, schema language, and common schemas.
- Data serialize format is called exchange structure in ISO document, but usually called STEP file,
They are serialized as ASCII text (ISO-10303-21, usually with extension
*.step
,*.stp
or*.p21
) or XML (ISO-10303-28). - Schema language is called EXPRESS. EXPRESS file is usually named with extension
*.exp
. - Many common schemas are defined in ISO-10303 by EXPRESS language.
- schemas contains copies
- Application Protocol (AP) is a class of defined schemas, and the main target of this project.
- AP203 is most famous one in CAD (computer-aided design) applications.
Rosetta Stone for web developers
Protocol Buffers | STEP (ISO 10303) | |
---|---|---|
Schema Language | Protocol Buffers Version 3 Language Specification | EXPRESS Language (ISO 10303-11) |
Schema file | *.proto file |
*.exp file |
Data | Encoded Binary data | "Exchange structure", *.step file (ASCII, ISO 10303-21) |
Compiler | protoc | esprc |
Why ruststep?
- STEP is not only for CAD
- EXPRESS is a general data schema like Protocol Buffers
- Later ISOs also uses EXPRESS
- For computer-aided technologies (CAx) including:
- computer-aided manufacturing (CAM)
- computer-aided engineering (CAE)
- product data management (PDM/EDM)
- manufacturing resource planning (MRP)
- enterprise resource planning (ERP)
- We have to generate many codes from EXPRESS schemas
- Tables for SQL or NoSQL database, Object-Record Mapper (ORM)
- on-wire, on-memory format
- ASCII / XML are inefficient than binary format e.g. protocol buffers
- Extensible EXPRESS compiler is required
- Like as protoc generates gRPC binding using gRPC-plugin
Roadmap
Released features
- 0.1.0
- Minimal EXPRESS Compiler to generate Rust struct definitions
- Deserialize STEP file (ASCII) to Rust struct
TODO until 1.0 release
- Serialize Rust struct to STEP file (ASCII) https://github.com/ricosjp/ruststep/issues/13
- Translate rules in EXPRESS schema into Rust code https://github.com/ricosjp/ruststep/issues/43
- Stablize AST and IR representation of espr
Planned features
- Binary format convertible into STEP ASCII and XML formats
- RDB support, ORM generation
License
Copyright 2021 RICOS Co. Ltd.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
Exception
The following directories are included for development purpose. They are not parts of this project.
Contributor License Agreement (CLA)
When you contribute (code, documentation, or anything else), you have to be aware that your contribution is covered by the same Apache 2.0 License that is applied to ruststep itself. This applies to all contributors, including those contributing on behalf of a company. If you agree to its content, you simply have to click on the link posted by the CLA assistant bot as a comment to the pull request. Click it to check the CLA, then accept it on the following screen if you agree to it. CLA assistant will save this decision for upcoming contributions and will notify you if there is any change to the CLA in the meantime.
Dependencies
~4.5MB
~77K SLoC