Popularity
4.2
Growing
Activity
0.0
Stable
369
22
19

Description

Ok guyz, you have a master degree in Graph Theory, you follow Law of Demeter and you live on S.O.L.I.D principles ?

Let's have some Fun ! (^ω^)

Code Quality Rank: L5
Monthly Downloads: 0
Programming language: PHP
License: Creative Commons Attribution Share Alike 3.0
Tags: Code Analysis     Code     Analysis     Static     Metrics     Graph     Abstract     Refactoring    
Latest version: v1.3.3

Mondrian alternatives and similar libraries

Based on the "Code Analysis" category

Do you think we are missing an alternative of Mondrian or a related project?

Add another 'Code Analysis' Library

README

Mondrian Build Status

Ok guyz, you have a master degree in Graph Theory, you follow Law of Demeter and you live on S.O.L.I.D principles ?

Let's have some Fun ! (ω)

What

It is a set of CLI tools to help you to analyse and refactor highly coupled classes. As you know Law of Demeter and S.O.L.I.D guidances, you need your classes loosely coupled. And for this, there is one only rule : ABSTRACTION

[From Hell To Kiss](./doc/img/abstracting.png)

This app provides some helpers to add abstraction into concrete classes with minimum pain.

Getting started

Download the PHAR : mondrian.phar

Try to run a simple command with a few files (or a small part of a project)

$ mondrian.phar digraph /home/dev/project

This command produces a DOT file for GraphViz. Other formats are available :

  • html : interactive graph with the d3.js awesome library
  • svg : open standard for vector graphics (requires GraphViz)
  • json : format for d3.js for example

Example with html format

$ php mondrian.php d --ignore=tests --ignore=vendor --format=html ./MyPhpProject/

[html-report](./doc/img/sample-d3js.png)

Note: The generated html file does not require any dependencies nor a connection.

Ecosystem

Running unit tests with PHPUnit

$ phpunit.phar

Building the documentation with phpDocumentor

$ phpDocumentor.phar

Building mondrian.phar from the sources with box2

$ box.phar b

Examples

Default digraph on trismegiste/dokudoki

[digraph1](./doc/img/sample1.jpg)

Which components are bottleneck ?

[digraph2](./doc/img/sample2.jpg)

Reduced graph to LSP violations on trismegiste/prolog

[digraph3](./doc/img/sample3.jpg)

How

Read the concept [here][12]

Read the online documentation here

And the API here (not up to date)

Extensible

You can easily add plugins to this tool to make your own algorithm, coloring scheme or new generator. I try to make the API mostly decoupled, re-usable and with great SRP and OCP concerns. Look into the "About" plugin to understand a basic stub of plugin.

Third party

Packages used in this project :

Special thanks

  • William Gibson
  • JS Bach
  • Dream Theater