Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/awalterschulze/gographviz
Parses the Graphviz DOT language in golang
https://github.com/awalterschulze/gographviz
go golang graphviz graphviz-dot-language parse
Last synced: 2 days ago
JSON representation
Parses the Graphviz DOT language in golang
- Host: GitHub
- URL: https://github.com/awalterschulze/gographviz
- Owner: awalterschulze
- License: other
- Created: 2015-03-14T18:27:00.000Z (almost 10 years ago)
- Default Branch: main
- Last Pushed: 2023-02-28T18:35:05.000Z (almost 2 years ago)
- Last Synced: 2024-12-13T07:05:12.396Z (9 days ago)
- Topics: go, golang, graphviz, graphviz-dot-language, parse
- Language: Go
- Homepage:
- Size: 399 KB
- Stars: 554
- Watchers: 12
- Forks: 74
- Open Issues: 8
-
Metadata Files:
- Readme: Readme.md
- License: LICENSE
- Authors: AUTHORS
Awesome Lists containing this project
- awesome-go - gographviz - Parses the Graphviz DOT language. (Text Processing / Parsers/Encoders/Decoders)
- awesome-go - gographviz - Parses the Graphviz DOT language in golang - ★ 222 (Text Processing)
- awesome-go-extra - gographviz - 03-14T18:27:00Z|2022-06-01T18:49:53Z| (Bot Building / Parsers/Encoders/Decoders)
README
Parses the Graphviz DOT language and creates an interface, in golang, with which to easily create new and manipulate existing graphs which can be written back to the DOT format.
This parser has been created using [gocc](http://code.google.com/p/gocc).
### Example (Parse and Edit) ###
```
graphAst, _ := gographviz.ParseString(`digraph G {}`)
graph := gographviz.NewGraph()
if err := gographviz.Analyse(graphAst, graph); err != nil {
panic(err)
}
graph.AddNode("G", "a", nil)
graph.AddNode("G", "b", nil)
graph.AddEdge("a", "b", true, nil)
output := graph.String()
```### Documentation ###
- The [godoc](https://godoc.org/github.com/awalterschulze/gographviz) includes some more examples.
- [How to implement an anonymous subgraph](https://github.com/awalterschulze/gographviz/issues/59)### Installation ###
go get github.com/awalterschulze/gographviz### Build and Tests ###
[![Build Status](https://github.com/awalterschulze/gographviz/workflows/build/badge.svg)](https://github.com/awalterschulze/gographviz/actions)
### Users ###
- [aptly](https://github.com/smira/aptly) - Debian repository management tool
- [gorgonia](https://github.com/chewxy/gorgonia) - A Library that helps facilitate machine learning in Go
- [imagemonkey](https://imagemonkey.io/graph?editor=true) - Let's create our own image dataset
- [depviz](https://github.com/moul/depviz) - GitHub dependency visualizer (auto-roadmap)
- [kustomize-graph](https://github.com/jpreese/kustomize-graph) - A tool to visualize Kustomize dependencies
- [inframap](https://github.com/cycloidio/inframap) - Read your tfstate or HCL to generate a graph specific for each Terraform provider
- [Antrea Traceflow](https://github.com/vmware-tanzu/antrea/blob/master/docs/traceflow-guide.md) supports using Traceflow for network diagnosis for Antrea, a Kubernetes networking solution intended to be Kubernetes native### Mentions ###
[Using Golang and GraphViz to Visualize Complex Grails Applications](http://ilikeorangutans.github.io/2014/05/03/using-golang-and-graphviz-to-visualize-complex-grails-applications/)