Sha256: 04968ab17497abb0239a93a25dec9aaca1d4fc5946ffce4c8143f851def77c31
Contents?: true
Size: 1.55 KB
Versions: 1
Compression:
Stored size: 1.55 KB
Contents
require 'graphviz' class GraphViz::DSL attr_accessor :graph def initialize(name, hOpts = {}, &block) @graph = GraphViz.new(name, hOpts) instance_eval(&block) if block end def method_missing(sym, *args, &block) return @graph.get_graph(sym.to_s) unless @graph.get_graph(sym.to_s).nil? return @graph.get_node(sym.to_s) unless @graph.get_node(sym.to_s).nil? if(@graph.respond_to?(sym, true)) @graph.send(sym, *args) elsif(block) @graph.add_graph(GraphViz::DSL.new(sym, { :parent => @graph, :type => @graph.type }, &block).graph) else @graph.add_node(sym.to_s, *args) end end def n(name) return @graph.get_node(name) unless @graph.get_node(name.to_s).nil? @graph.add_node(name) end def e(*args) e = nil last = args.shift while current = args.shift e = @graph.add_edge(last, current) last = current end return e end def subgraph(name, &block) @graph.add_graph(GraphViz::DSL.new(name, { :parent => @graph, :type => @graph.type }, &block).graph) end alias :cluster :subgraph def output(hOpts = {}) @graph.output(hOpts) end end def graph(name, hOpts = {}, &block) GraphViz::DSL.new(name, hOpts.merge( { :type => "graph" } ), &block).graph end def digraph(name, hOpts = {}, &block) GraphViz::DSL.new(name, hOpts.merge( { :type => "digraph" } ), &block).graph end def strict(name, hOpts = {}, &block) GraphViz::DSL.new(name, hOpts.merge( { :type => "strict digraph" } ), &block).graph end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
ruby-graphviz-1.0.1 | lib/graphviz/dsl.rb |