2 releases
0.0.2 | Dec 12, 2023 |
---|---|
0.0.1 | Dec 12, 2023 |
#251 in Visualization
92KB
2K
SLoC
ML -Modeling Language-
A library (and cli tool) to generating UML language from Rust's project into graphiz/dot file.
QuickStart
Obtain mml
$ git clone https://github.com/silence-coding/ml.git
$ cd ml
Install Dependencies
The dot
binary from graphviz package must exist in your path.
$ apt install graphviz
(or do the equivalent for your OS)
Nightly rustc is required. Run this from within ml crate.
$ rustup install rustc llvm-tools-preview
Build and run mml
$ cargo run --example ml
important: ml looks for files beneath ./src, so you should always cd to crate root before running it.
View generated diagram
$ firefox target/doc/ml.svg
inkscape
also works well as an svg viewer.
Usage
$ ./target/debug/examples/ml --help Usage: ml [OPTIONS]
Parses rust source code and generates UML diagram
Arguments:
--include_fields [bool] include fields/variants in diagram
--include_implems [bool] include trait implementation methods in diagram
--include_methods [bool] include methods in diagram
--struct_header_bgcolor [str] header background color for structs
--struct_fields_bgcolor [str] fields background color for structs
--struct_method_bgcolor [str] methods background color for structs
--struct_implem_bgcolor [str] implems background color for structs
--enum_header_bgcolor [str] header background color for enums
--enum_fields_bgcolor [str] fields background color for enums
--enum_method_bgcolor [str] methods background color for enums
--enum_implem_bgcolor [str] implems background color for enums
--trait_header_bgcolor [str] header background color for traits
--trait_method_bgcolor [str] methods background color for traits
--font [str] Font name
Output is always under target/doc/mml/
You can add ml
binary to your path and then you should be able to run
it for any rust crate.
--------------------------- Old, possibly obsolete -----------------
Usage
This repo is provided as a Cargo package and a build script.
- adjust your
Cargo.toml
to include.
build = "build.rs"
[build-dependencies.rust2uml]
version = "0.0.1"
- And your
build.rs
to generate your uml graph/viz and Structured Vector Graphics attarget/dot/$CARGO_PKG_NAME.{dot,svg}
.
extern crate mml;
fn main() {
let dest: String = concat!("target/doc/", env!("CARGO_PKG_NAME")).to_string();
let mut config = rust2uml::Config::default();
rust2uml::Config::set_global(config);
let _ = rust2uml::src2both("src", dest.replace("-", "_").as_str());
}
- (Facultative) From your entry point library file, you can add the generated vectorized graph.
//! ![uml](ml.svg)
- (Facultative) With the travis-cargo's instructions, you can prepare your graphviz's dependency like with this example.
addons:
apt:
packages:
- graphviz
before_script:
- if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew update ; fi
- if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew install graphviz ; fi
...
script:
- |
travis-cargo build &&
...
Features
Consider this list of fonctionalities like unstandard-uml.
- implem -- add a column to show the functions from a implementation.
- fn-emilgardis -- the function fields are preceded by fn keyword (Asked by Emilgardis).
Knowledge
This is a reading list of material relevant to Ml. It includes prior research that has - at one time or another - influenced the design of Ml, as well as publications about Ml.
License
ml
is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0), with portions covered by various BSD-like licenses.
See LICENSE-APACHE, and LICENSE-MIT for details.
Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.
Dependencies
~1MB
~15K SLoC