Skip to content

subgraph/cluster and class count #42

Closed
@llaville

Description

@llaville

Hello,

i'm currently working on a PHP solution based on your packages (here are my versions used)

graphp/graph                       dev-master 0d78233 GraPHP is the mathematical graph/network library written in PHP.
graphp/graphviz                    dev-master 5ad4f5d GraphViz graph drawing for the mathematical graph/network library GraPHP.

I've recently be aware that when there are many classes in a diagram, subgraph even with a single class, are displayed correctly.

But when there is only one namespace and one class, such as :

<?php
declare(strict_types=1);

namespace App;

class BackupProject
{
    private $a;
    private const B = 'b';
    public function __construct(string  $a)
    {
        $this->a = $a;
    }
}

subgraph is not generated and give such result :



Statements code corresponding to this image are :

graph {
  graph [name="G" overlap="false"]
  node [fontname="Verdana" fontsize=8 shape="none" margin=0 fillcolor="#FEFECE" style="filled"]
  edge [fontname="Verdana" fontsize=8]
  "App\\BackupProject" [label=<
<table cellspacing="0" border="0" cellborder="1">
    <tr><td bgcolor="#eeeeee"><b>BackupProject</b></td></tr>
    <tr><td><table border="0" cellspacing="0" cellpadding="2">
<tr><td align="left">- a</td></tr>
</table></td></tr>
    <tr><td><table border="0" cellspacing="0" cellpadding="2">
<tr><td align="left">+ __construct()</td></tr>
</table></td></tr>
</table>> shape="none"]
}

While I'm expected to see the rectangle that show the namespace as follow



Statements code corresponding to this image are :

graph {
  graph [name="G" overlap="false"]
  node [fontname="Verdana" fontsize=8 shape="none" margin=0 fillcolor="#FEFECE" style="filled"]
  edge [fontname="Verdana" fontsize=8]
  subgraph cluster_0 {
    label = "App"
    "App\\BackupProject" [label=<
<table cellspacing="0" border="0" cellborder="1">
    <tr><td bgcolor="#eeeeee"><b>BackupProject</b></td></tr>
    <tr><td><table border="0" cellspacing="0" cellpadding="2">
<tr><td align="left">- a</td></tr>
</table></td></tr>
    <tr><td><table border="0" cellspacing="0" cellpadding="2">
<tr><td align="left">+ __construct()</td></tr>
</table></td></tr>
</table>> shape="none"]
  }
}

To produce such result, i've just changed one line in your code : https://github.com/graphp/graphviz/blob/master/src/GraphViz.php#L283

if (count($groups) > 0) {

Tell me what you think, and if you're agree with this change !

Thanks
Laurent

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions