Crates.io | dstv |
lib.rs | dstv |
version | 0.7.0 |
source | src |
created_at | 2023-06-02 14:14:28.788682 |
updated_at | 2024-11-01 15:58:14.477096 |
description | DSTV is a Rust library for parsing DSTV files and visualizing the parsed data. |
homepage | https://github.com/tluijken/dstv |
repository | https://github.com/tluijken/dstv |
max_upload_size | |
id | 880877 |
size | 64,893,792 |
Welcome to the DSTV crate repository! This Rust crate is designed to parse DSTV (NC/NC1) files and visualize them as SVG (Scalable Vector Graphics). DSTV is a format extensively used in the steel industry for exchanging data about steel parts.
To install DSTV, add it to your Cargo.toml
file:
[dependencies]
DSTV = "0.1.0"
Then run cargo build
to download and compile the DSTV crate along with your project.
Here's a basic example of how to use DSTV to parse a DSTV file and generate an SVG:
use dstv::prelude::*;
let dstv = Dstv::from_file("./tests/data/0008-SE0009.nc1");
assert_eq!(dstv.is_ok(), true);
// Declare the dstv as mutable, as `to_svg` will reorder the elements for the
// best representation
let mut dstv = dstv.unwrap();
assert_eq!(dstv.header.order_identification, "PROJECT-1");
let svg = dstv.to_svg();
To work with specific element types in a DSTV file, use the DstvElementType enum to match each element and perform type-specific actions. Once you load the DSTV file with Dstv::from_file, iterate over dstv.elements and use a match expression to handle each variant, like OuterBorder, InnerBorder, or Hole, accessing their unique fields and properties.
Here’s an example:
let dstv = Dstv::from_file("./tests/data/P1565.nc").unwrap();
for element in dstv.elements {
match element {
DstvElementType::OuterBorder(e) =>
{
assert!(e.contour.len() > 0);
},
DstvElementType::InnerBorder(e) =>
{
assert!(e.contour.len() > 0);
},
DstvElementType::Cut(e) =>
{
assert!(e.nor_vec_x > 0.0);
},
DstvElementType::Bend(e) =>
{
assert!(e.angle > 0.0);
},
DstvElementType::Slot(e) =>
{
assert!(e.angle > 0.0);
},
DstvElementType::Hole(e) =>
{
assert!(e.diameter > 0.0);
},
DstvElementType::Numeration(e) =>
{
assert_ne!(e.text, "");
},
}
}
Contributions to the DSTV are welcome. If you find a bug or have a feature request, please open an issue. If you want to contribute code, please open a pull request.
This project is licensed under the MIT License.
This library is provided as-is, and while we strive for quality, we cannot guarantee that there will never be any bugs or issues.
If you have any questions or comments about DSTV, feel free to contact us.