graphviz 点 HTML 属性不起作用?

graphviz dot HTML attributes not working?

我在 macbook 上用 graphviz 点绘制图表,这是我的图表 simple.dot:

digraph {
    node [shape=record, fontname="Courier New, Courier", fontsize=12]
    graph [fontname="Courier New, Courier", fontsize=12]
    edge [fontname="Courier New, Courier", fontsize=12]

    node626 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell625">global.1</TD></TR>
        <TR><TD PORT="cell627">symbol: name: integer_literal, type: ()=&gt;void, kind: Func</TD></TR>
        <TR><TD PORT="cell633">symbol: name: string_literal, type: ()=&gt;void, kind: Func</TD></TR>
        <TR><TD PORT="cell639">symbol: name: floating_point_literal, type: ()=&gt;void, kind: Func</TD></TR>
        <TR><TD PORT="cell645">symbol: name: character_literal, type: ()=&gt;void, kind: Func</TD></TR>
        <TR><TD PORT="cell651">typeSymbol: name: byte, kind: Plain</TD></TR>
        <TR><TD PORT="cell652">typeSymbol: name: ubyte, kind: Plain</TD></TR>
        <TR><TD PORT="cell653">typeSymbol: name: short, kind: Plain</TD></TR>
        <TR><TD PORT="cell654">typeSymbol: name: ushort, kind: Plain</TD></TR>
        <TR><TD PORT="cell655">typeSymbol: name: int, kind: Plain</TD></TR>
        <TR><TD PORT="cell656">typeSymbol: name: uint, kind: Plain</TD></TR>
        <TR><TD PORT="cell657">typeSymbol: name: long, kind: Plain</TD></TR>
        <TR><TD PORT="cell658">typeSymbol: name: ulong, kind: Plain</TD></TR>
        <TR><TD PORT="cell659">typeSymbol: name: float, kind: Plain</TD></TR>
        <TR><TD PORT="cell660">typeSymbol: name: double, kind: Plain</TD></TR>
        <TR><TD PORT="cell661">typeSymbol: name: char, kind: Plain</TD></TR>
        <TR><TD PORT="cell662">typeSymbol: name: boolean, kind: Plain</TD></TR>
        <TR><TD PORT="cell663">typeSymbol: name: void, kind: Plain</TD></TR></TABLE>>]
    node629 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell628">integer_literal</TD></TR>
        <TR><TD PORT="cell630">symbol: name: local.2, type: void, kind: Local</TD></TR></TABLE>>]
    node632 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell631">local.2</TD></TR></TABLE>>]
    node635 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell634">string_literal</TD></TR>
        <TR><TD PORT="cell636">symbol: name: local.3, type: void, kind: Local</TD></TR></TABLE>>]
    node638 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell637">local.3</TD></TR></TABLE>>]
    node641 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell640">floating_point_literal</TD></TR>
        <TR><TD PORT="cell642">symbol: name: local.4, type: void, kind: Local</TD></TR></TABLE>>]
    node644 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell643">local.4</TD></TR></TABLE>>]
    node647 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell646">character_literal</TD></TR>
        <TR><TD PORT="cell648">symbol: name: local.5, type: void, kind: Local</TD></TR></TABLE>>]
    node650 [label=<<TABLE BORDER="0" CELLSPACING="0" CELLBORDER="1">
        <TR><TD PORT="cell649">local.5</TD></TR></TABLE>>]

    node629:cell630 -> node632:cell631
    node626:cell627 -> node629:cell628
    node635:cell636 -> node638:cell637
    node626:cell633 -> node635:cell634
    node641:cell642 -> node644:cell643
    node626:cell639 -> node641:cell640
    node647:cell648 -> node650:cell649
    node626:cell645 -> node647:cell646
}

dot -Tpng simple.dot -o simple.png编译,它给我:

但是 PORT 似乎不起作用,因为边缘应该从 <TD> 指向另一个 <TD><TABLE BORDER> 也不起作用,因为我的 table 边框是粗体。

请帮忙。

您文件中的核心问题是这一行:

node [shape=record, fontname="Courier New, Courier", fontsize=12]

你要的是node [shape=none ...]

node [shape=none, fontname="Courier New, Courier", fontsize=12]

这修复了 table 边界和端口问题。如果在某些边缘添加罗盘点,情况会变得更好。

 node626:cell627 -> node629:cell628:n