View on GitHub

Muhafiz

Guard your codebase from bad codes!

download .ZIPdownload .TGZ

muhafiz

Master: Build Status

Guard your codebase from bad code!

                         ...',,,,,',:
                        ,,.',okxc,,,Oc
                       .,.',;0OOx,,,;K'
                       :.',,;XoxK,,,,cK.
                      ';.',,,l00d,,,,,oO
                      c''',,,oWWo,,,,,,O:
                     ,:.',,,,;NX,,,,,,,:0
                     ,;.',,,,,K0,,,,,,,,k;
                     ;,',,,,:OMWx;,,,,,,l.
                    .odxxox0NNWNNXkooxOXW.
                     okKWNNX0NNXKkNNWWWWN.
                     'dOWNWNKNWNX0MXNWWWo
                      ,oONWX0KWN0OKNWWNo.
                    ....;c;...cl',',lo;'...
                  .......';odOKXNKc'..'',,,'.
                 ...;ldxlxWWWWWWWWXW0doc;,,,,.
                .'oKNWWWWN0kOKXXX00NWNWWN0xc,,.
               'xNWWWWWN0o'..,:c,'',kNWWWWWWKo,
              ,XWWNX0Odc,',oxxxxc.,,':xXNNNWWWK;
             .0WXOdl:,..''ldolodx;',,,,;lkKXXNWN.
            .:xxc;'.  ..,'ldddooxc',,,,,,,.',:;:
               ....  ...,,,oxxxOd,,,,,,,,,....
                 ... ..',,,'lokd,,,,,,,,,,...
                   .....,,,'oxKd,,,,,,,,,..
                     ...,,,'o0Wd,,,,;;:c:
                     :oxdxxcoNWkxkkkO0KKx
                     .';;;;,OXW0...,,,,,'
                   ...',,,'lKKW0...,,,,,,.
                   ..',,,,.dWO0k,..,,,,,,,
                  ..',,,,,.cNdOk:..,,,,,,,'
                 ..',,,,,,..Ookkc..',,,,,,,
                 '.,,,,,,'. lkdx:...,,,,,,,.
                 ..,,,,,'.. 'xox....',,,,,,.
                 ..,,,,,..   :o:'  ...,,,,,'
                 ..,,,,.      c..     .,,,,.
                 .......      ..      .......

Git

Installation

You need to copy the required git-hook to your project's .git/hooks directory And put the src directory in somewhere (eg. ~/muhafiz/src)

$ git clone git://github.com/sonsuzdongu/muhafiz.git ~/muhafiz
$ cp ~/muhafiz/git-hooks/* /your/project/.git/hooks

Configuration

You have to set your 'muhafiz.bootstrap-file' git config setting to show your muhafiz bootstrap file

$ git config muhafiz.bootstrap-file ~/muhafiz/src/bootstrap.php

Or better you set it system wide or global

$ sudo git config --global muhafiz.bootstrap-file ~/muhafiz/src/bootstrap.php
$ sudo git config --system muhafiz.bootstrap-file ~/muhafiz/src/bootstrap.php

Then you have to set the comma separated list of code checkers(aka runners) using 'muhafiz.active-runners' git config parameter

$ git config muhafiz.active-runners 'phpcs, jshint'

After this, 'all your commits are belongs to us'. All your commits will be checked by given runners and commit will be prevented if are there any errors

Subversion

Installation

You need to copy the required svn-hook to your repository's hooks directory And put the src directory in somewhere (eg. ~/muhafiz/src)

$ git clone git://github.com/sonsuzdongu/muhafiz.git ~/muhafiz
$ cp ~/muhafiz/svn-hooks/pre-commit /home/svn/your_project/hooks/
$ cp ~/muhafiz/svn-hooks/muhafiz.conf /home/svn/your_project/conf/

Configuration

You have to edit your 'muhafiz.conf' file to locate bootstrap file and configure runners:

[muhafiz]
bootstrap-file=~/muhafiz/src/bootstrap.php
active-runners='php, bom'

List of code checkers(aka runners) must be separated by commas.

After this, 'all your commits are belongs to us'. All your commits will be checked by given runners and commit will be prevented if are there any errors

Runners

Setting exclude patterns for runners

Exclude patterns can be set for each runner with setting a RegExp rule in 'muhafiz.runners.RUNNER_NAME.exclude-pattern' like

Git:

$ git config muhafiz.runners.lineend.exclude-pattern '/static\/images/'

Subversion:

[muhafiz]
runners.lineend.exclude-pattern='/static\/images/'

In this example, lineend rune will not be applied to files which matches that rule (like /foo/static/images/bar.xyz)

Disabling pushes to specific branches (Only on pre-receive hook)

You can disable pushes to specific branches by

Git:

$ git config muhafiz.disabled-branches "foo bar"

Subversion:

[muhafiz]
disabled-branches="foo bar"

Contributors

Osman Yüksel
Volkan Altan
chesterx
Adil İlhan
Eser Özvataf

TODO