Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

subgraph/cluster and class count #42

Closed
llaville opened this issue Apr 3, 2020 · 5 comments
Closed

subgraph/cluster and class count #42

llaville opened this issue Apr 3, 2020 · 5 comments

Comments

@llaville
Copy link

llaville commented Apr 3, 2020

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

@llaville
Copy link
Author

@clue hello.
Do you have time to have a look on this suggestion ?

@clue
Copy link
Member

clue commented Apr 21, 2020

@llaville Thanks for reporting, it looks like you've spotted a missing feature / a minor bug!

I agree that we should draw a subgraph if only one group has been assigned explicitly. On top of this, we should not draw a subgraph if only one group has been assigned implicitly (all vertices are in the null group by default).

Adding this shouldn't be too hard. I'll take a look at this again before the next release is tagged, PRs are very welcome in case anybody beats me to it 👍

@llaville
Copy link
Author

llaville commented Jan 1, 2022

@clue Here is the final patch I used with cweagans/composer-patches to modify your package on installation to add this new feature !

diff --git a/src/GraphViz.php b/src/GraphViz.php
index 9d6d8a0..5d8a530 100644
--- a/src/GraphViz.php
+++ b/src/GraphViz.php
@@ -280,13 +280,29 @@ class GraphViz
         }

         // only cluster vertices into groups if there are at least 2 different groups
-        if (count($groups) > 1) {
+        if (count($groups) > 0) {
+            // add subgraph cluster attributes
+            $clusters = array(
+                'graph' => 'graphviz.cluster.%s.graph.',
+                'node'  => 'graphviz.cluster.%s.node.',
+                'edge'  => 'graphviz.cluster.%s.edge.',
+            );
             $indent = str_repeat($this->formatIndent, 2);
             $gid = 0;
             // put each group of vertices in a separate subgraph cluster
             foreach ($groups as $group => $vertices) {
-                $script .= $this->formatIndent . 'subgraph cluster_' . $gid++ . ' {' . self::EOL .
-                           $indent . 'label = ' . $this->escape($group) . self::EOL;
+                $script .= $this->formatIndent . 'subgraph cluster_' . $gid . ' {' . self::EOL;
+                foreach ($clusters as $key => $prefix) {
+                    foreach (array($group, $gid) as $clusterId) {
+                        $layout = $this->getAttributesPrefixed($graph, sprintf($prefix, $clusterId));
+                        if (!empty($layout)) {
+                            $script .= $indent . $key . ' ' . $this->escapeAttributes($layout) . self::EOL;
+                            break;
+                        }
+                    }
+                }
+                $script .= $indent . 'label = ' . $this->escape($group) . self::EOL;
+                $gid++;
                 foreach ($vertices as $vertex) {
                     $vid = $vids[\spl_object_hash($vertex)];
                     $layout = $this->getLayoutVertex($vertex, $vid);
@@ -320,7 +336,7 @@ class GraphViz

         // add all edges as directed edges
         foreach ($graph->getEdges() as $currentEdge) {
-            $both = $currentEdge->getVertices()->getVector();
+            $both = $currentEdge->getVertices();
             $currentStartVertex = $both[0];
             $currentTargetVertex = $both[1];

@llaville
Copy link
Author

This project seems unmaintained, and I'm not sure to want to keep a fork with patch. Perharps I'll create a new standalone project in future days to replace it.
Now I'll close this report as it seems your architecture (see relative ticket #14) is not yet ready.

@SimonFrings
Copy link
Contributor

@llaville This project is indeed maintained, @clue and I have over 100 open source projects to look over here on GitHub and we're currently a lot involved in working on ReactPHP. Even if we're currently not actively working on new features in this project doesn't mean we're not reviewing any suggestions made by contributors. If you need this urgently, you can also reach out to us or help us by becoming as sponsor

If you would like to add this new feature to the project you can also open up a pull request, just add the necessary tests to assure everything works as expected and we're happy to take a look 👍

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants