Skip to content

Latest commit

 

History

History
186 lines (133 loc) · 3.29 KB

README.md

File metadata and controls

186 lines (133 loc) · 3.29 KB

diagen.sh

diagen.sh (derived from diagram generator) is a simple tool for creating UML-like diagrams of classes (types), and flowcharts. In fact, this is a set of m4 macros expanding into DOT language statements.

diagen.sh needs Graphviz to be installed on your system.

Usage:

./diagen.sh infile.gv.m4 outfile.svg

Examples

Structure Diagrams

Class With Attributes and Operations

DIAGRAM
    CLASS(Foo)
        ATTRIBUTE(bar)
        STATIC ATTRIBUTE(baz)
        OPERATION(qux())
        STATIC OPERATION(quux())
    END
END

Class with attributes and operations

Note

DIAGRAM
    NOTE(Blah blah blah, FooBar)
END

Note

Interface

DIAGRAM
    INTERFACE(Foo)
        ATTRIBUTE(bar)
        OPERATION(baz())
    END
END

Interface

Abstract Class

DIAGRAM
    ABSTRACT CLASS(Foo)
        ATTRIBUTE(bar)
        ABSTRACT ATTRIBUTE(baz)
    END
END

Abstract class

Enumeration

DIAGRAM
    ENUMERATION(Foo)
        LITERAL(bar)
        LITERAL(baz)
        LITERAL(qux)
    END
END

Enumeration

Package Containing Classes

DIAGRAM
    PACKAGE(foobar)
        Foo
        Bar
    END
END

Package containing classes

Module Containing Operations and Classes

DIAGRAM
    MODULE(foo)
        OPERATION(bar())
        OPERATION(baz())
    END

    NESTINGS
        {Qux Quux} -> foo
    END
END

Module containing operations and classes

Other Entities

DIAGRAM
    COMPONENT(foo)
    COLLABORATION(bar)
    USECASE(baz)
    NODE(qux)
    ARTIFACT(quux)
END

Other entities

Relations

DIAGRAM
    ASSOCIATIONS
        Foo1 -> Bar1
    END

    BIDIRECTIONAL ASSOCIATIONS
        Foo2 -> Bar2
    END

    GENERALIZATIONS
        Foo3 -> Bar3
    END

    DEPENDENCIES
        Foo4 -> Bar4
    END

    AGGREGATIONS
        Foo5 -> Bar5
    END

    COMPOSITIONS
        Foo6 -> Bar6
    END

    IMPLEMENTATIONS
        Foo7 -> Bar7
    END
END

Relations

Behavior Diagrams (Flowcharts)

Condition Check

BEHAVIOR DIAGRAM
    INITIAL_NODE(in)
    FINAL_NODE(fn)
    DECISION(foo)
    MERGE(m)

    in -> foo
    TRANSITION(foo -> bar, true)
    TRANSITION(foo -> baz, false)
    {bar baz} -> m -> fn
END

Condition check

Concurrent Activities

BEHAVIOR DIAGRAM
    INITIAL_NODE(in)
    FINAL_NODE(fn)
    FORK(f)
    JOIN(j)
    in -> f -> {foo bar} -> j -> fn
END

Concurrent activities

Subactivity

BEHAVIOR DIAGRAM
    INITIAL_NODE(in)
    FINAL_NODE(fn)

    SUPERACTION(barbaz)
        bar -> baz
    END

    in -> foo -> bar
    baz -> qux -> fn
END

Subactivity