Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/melborne/Gviz
Yet Another Ruby's interface of graphviz
https://github.com/melborne/Gviz
Last synced: 3 months ago
JSON representation
Yet Another Ruby's interface of graphviz
- Host: GitHub
- URL: https://github.com/melborne/Gviz
- Owner: melborne
- License: mit
- Created: 2012-09-23T09:30:03.000Z (over 12 years ago)
- Default Branch: master
- Last Pushed: 2023-12-28T10:00:42.000Z (about 1 year ago)
- Last Synced: 2024-10-27T05:43:58.830Z (4 months ago)
- Language: Ruby
- Size: 524 KB
- Stars: 58
- Watchers: 4
- Forks: 5
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# Gviz
[data:image/s3,"s3://crabby-images/92836/92836759a7151c302b3786d0be4ddaf0ce7c89e4" alt="Build Status"](https://travis-ci.org/melborne/Gviz)
Ruby's interface of graphviz. It generate a dot file with simple ruby's syntax. Some implementations of `Gviz` are inspired by Ryan Davis's [Graph](https://github.com/seattlerb/graph 'seattlerb/graph').
## Installation
Add this line to your application's Gemfile:
gem 'gviz'
And then execute:
$ bundle
Or install it yourself as:
$ gem install gviz
## Usage
A simple example.
# add nodes and edges(route method)
# save to files with dot and png formats(save method)
require "gviz"
Graph do
route :main => [:init, :parse, :cleanup, :printf]
route :init => :make, :parse => :execute
route :execute => [:make, :compare, :printf]save(:sample1, :png)
end
`Graph` is a shortcut for `Gviz.new.graph`.This outputs `sample1.dot` and `sample1.png` files shown as below.
data:image/s3,"s3://crabby-images/e8947/e8947d9183abb6f87209d4bc997cfc3f8523efd1" alt="sample1"
Add some attributes to the graph, nodes, edges.
## add color to all nodes with color set(nodes, nodeset and node methods)
## add color & styles to all edges(edges method)
## add color & styles to a edge(edge method)
## add bgcolor to a graph(global method)
require "gviz"
Graph do
route :main => [:init, :parse, :cleanup, :printf]
route :init => :make, :parse => :execute
route :execute => [:make, :compare, :printf]
nodes(colorscheme:'piyg8', style:'filled')
nodeset.each.with_index(1) { |nd, i| node(nd.id, fillcolor:i) }
edges(arrowhead:'onormal', style:'bold', color:'magenta4')
edge(:main_printf, arrowtail:'diamond', dir:'both', color:'#3355FF')
global(bgcolor:'powderblue')save(:sample2, :png)
endThis outputs below.
data:image/s3,"s3://crabby-images/0fa26/0fa2688b10cf68a2596d869f2781a6cf94fc4274" alt="sample2"
Modify some.
## define specific edge port(node label & edge method)
## adjust node positions(rank method)
## define subgraph(subgraph method)
require "gviz"
Graph do
route :main => [:init, :parse, :cleanup, :printf]
route :init => :make, :parse => :execute
route :execute => [:make, :compare, :printf]
nodes colorscheme:'piyg8', style:'filled'
nodeset.each.with_index(1) { |nd, i| node nd.id, fillcolor:i }
edges arrowhead:'onormal', style:'bold', color:'magenta4'
edge :main_printf, arrowtail:'diamond', dir:'both', color:'#3355FF'
global bgcolor:'powderblue'
node :execute, shape:'Mrecord', label:'{execute | {a | b | c}}'
node :printf, shape:'Mrecord', label:'{printf | format}'
edge 'execute:x_printf:y'
rank :same, :cleanup, :execute
subgraph do
global label:'SUB'
node :init
node :make
endsave(:sample3, :png)
endThis outputs below.
data:image/s3,"s3://crabby-images/2414c/2414cbd4e717823845fd502b39fbe66fa5bc44cc" alt="sample3"
## Use for Drawing
Gviz helps you easily to draw shapes on an exact position using shape-named methods.
require "gviz"
Graph do
line :a, from:[-100,0], to:[100,0]
line :b, from:[0,-100], to:[0,100]
circle :c
rect :d, x:50, y:50, fillcolor:"green", label:"Rect"
triangle :e, x:50, y:-50, fillcolor:"cyan"
diamond :f, x:-50, y:50, fillcolor:"magenta"
egg :g, x:-50, y:-50, fillcolor:"yellow", label:"Egg"save :draw
endThis outputs below(consider a scale if save to output formats).
data:image/s3,"s3://crabby-images/420a3/420a31dbe8b281c7034aa6e122eeefed268f550e" alt="sample4"
Another examples are at `examples` directory
## gviz command
It comes with a `gviz` command. This works with a graph spec file. If 'graph.ru' file exist on a directory of the execution, it will be automatically loaded as a graph spec file.Example of graph.ru:
route :main => [:init, :parse, :cleanup, :printf]
route :init => :make, :parse => :execute
route :execute => [:make, :compare, :printf]save(:sample, :png)
Usage:
gviz build [FILE] [options]
where [options] are:
--name, -n : Graph name (default: G)
--type, -t : Graph type (default: digraph)## Contributing
1. Fork it
2. Create your feature branch (`git checkout -b my-new-feature`)
3. Commit your changes (`git commit -am 'Add some feature'`)
4. Push to the branch (`git push origin my-new-feature`)
5. Create new Pull Request