Skip to content

Latest commit

 

History

History
833 lines (615 loc) · 32.4 KB

CHANGELOG.md

File metadata and controls

833 lines (615 loc) · 32.4 KB

MISS_HIT Release Notes

Known issues

Language support

Compatible with up to MATLAB 2021a.

Not quite compatible with Octave yet. See #43 octave support for more information.

Tooling

  • In some cases MH Style will not fix everything in one run, and it may be necessary to run the tool more than once. Issues like these will be resolved with the planned MH Reformat tool, and will not be fixed in MH Style.

Changelog

0.9.45-dev

0.9.44

  • New configuration item regex_attribute_name for the naming_functions rule. This can be used to enforce naming for class attributes and the associated getters and setters.

0.9.43

  • Fix parsing error surrounding function names (only in classes may you use a dotted name). When such a function appeared outside a class the tools would either incorrectly accept this name or crash.

  • Fix hanging tools when an internal compiler error was raised.

  • Fix parser error for enumeration values with no parameters using brackets.

  • Fix tool crash when --debug-dump-tree was specified without --single. This is now clear in the error message.

  • Add new configuration directive ignore_dir. This works just like exclude_dir but does not raise an error if the directory doesn't exist.

  • Add new configuration option newline_style. By default MISS_HIT will just use the native line endings, but by setting newline_style to lf, crlf, or cr you can force it to use platform-specific newlines. You can also use native to restore the default behaviour.

0.9.42

  • Fix issue with MATLAB functions embedded in Simulink. Usually people left the default name (i.e. fcn) which caused many duplicate items to appear in the mh_trace output. Now embedded functions use the name of the subsystem (i.e. what you'd see in Simulink as the name).

0.9.41

  • Fix parsing bug for argument and property validation blocks. The list of validation functions may be empty, previously the MISS_HIT parser complained about non-empty lists.

0.9.40

  • Fix tool crash when encountering a Simulink area annotation with no text. These annotations are now properly supported and you can even add tracing text to them.

0.9.39

  • Add another method of tracing Simulink models via block properties.

  • The top-level system of a Simulink Library (but not Model) no longer appears in the tracing output, as there is no way to access or manipulate this in the Simulink user interface.

  • Add new option --untagged-blocks-inherit-tags for mh_trace which cases any untagged system to inherit any tags from its parent. Once new tags are encountered this breaks the inheritence chain. Note that embedded MATLAB blocks are unaffected by this option.

0.9.38

  • Fix issue where a Simulink model with self-contained links would not parse the referenced systems. Only the top-level system would be parsed and references were never followed.

  • Fix issue where a Simulink model with referenced stateflow would not parse the referenced machines and charts.

  • Fix issue in mh_trace where sometimes LOBSTER tags could be generated which contained spaces.

  • Support multi-line and HTML annotations in Simulink for mh_trace annotations.

0.9.37

  • Rework mh_trace and its output format. It now generates LOBSTER traces. See https://github.com/bmw-software-engineering/lobster for more information, including a description of the interchange format. The old output format is no longer supported now that there is a good standard.

  • Add support for Simulink tracing in mh_trace. You can add annotations to any block starting with the text lobster-trace: followed by a list of requirement tags. For example lobster-trace: foo.my_req.

  • Remove mh_trace commandline flag --json and replace it with --out-imp and --out-act. The default filename produced is now mh_imp_trace.lobster and mh_act_trace.lobster.

  • Remove mh_trace commandline flag --by-tag. You can use a tool like LOBSTER to recover this information.

  • Add mh_trace commandline flag --only-tagged-blocks. This filters out all Simulink blocks that do not contain at least one tag.

  • Fix a bug in mh_trace where precisely duplicated package + function names result in only one tracable item. Now there are two, and a tool like LOBSTER will complain.

0.9.36

  • Fixed minor issue where mh_trace was not made available as a command-line tool when installing the PyPI package miss_hit.

0.9.35

  • You can now specify more precise Octave and MATLAB versions. This change is massive, and likely to have subtle bugs. You can now write octave: "4.4" or matlab: "2020b" in your config files; or specify --octave=4.4 or --matlab=2020b from the command-line. There is also a special latest version for both Octave and MATLAB, which is an alias for the latest supported version.

    This is also the first change that introduces backwards incompatibility, specifically:

    • The command-line option --octave no longer works. You need to specify --octave=latest to get the same behaviour.
    • The config setting octave: true still works, but is deprecated. It means the same thing as octave: "latest".
    • The config setting octave: false doesn't make sense anymore (and never really did), so it now raises an error.

    As always note that for MATLAB, support should be fairly good and accurate. For Octave many things are missing (such as the end_X set of keywords). I do plan to improve the situation, but please create tickets for things you need sooner.

  • Several tools that generate messages (mh_style, mh_metric, and mh_lint) will now add the originating check id in the message. For example:

    In test.m, line 4
    | false = 0.01; % bad
    | ^^^^^ check (medium): redefining this builtin is very naughty [builtin_shadow]
    

    This should make it much easier to disable rules if you don't like to read the manual.

  • MISS_HIT now recognises and processes Octave test .tst files (along with .m and .slx files). The Octave test annotation language (comments starting with %!) is ignored by MH Style for now. Thank you to Alois Spitzbart for the idea.

0.9.34

  • Relaxed docstring recognition: now you can have blank lines (without the comment indicator) in your docstring.

0.9.33

  • Add a new configuration option "indent_function_file_body" for MH Style. This is true by default. If you set it to false, then you get the odd indentation style that somewhat common in the MATLAB world, where functions in function files do not have their body indented. For example:

    function z = Potato(w)
    z = -w;
    

    Note that this option only affects top-level functions in function files. Any other function (e.g. a method, or a nested function) is not affected.

  • Fix an issue where a broken symlink could cause the tools to crash in some circumstances. Broken symlinks are now ignored.

0.9.32

  • [CORRECTNESS] Fix another lexer bug where a matrix with a unary minus in front did not correctly get interpreted as a separate element in some cases. This could be seen in [-.1 -~0] which was seen as -1.1, instead of [-.1 -1]. This could lead mh_style to change the meaning of the code. You will notice that this is almost the same as the bug in 0.9.31. I hate everything surrounding matrices. I suspect this will not be the laste one like this.

0.9.31

  • [CORRECTNESS] Fix a lexer bug where a matrix with a unary minus in front did not correctly get interpreted as a separate element in some cases. This could be seen in [1 -[1]] which was seen as 0, instead of [1 -1]. This could lead mh_style to change the meaning of the code. This issue affected both matrices and cells.

  • In some cases configuration files could be parsed in a different order on different platforms. This makes no practical difference, except for some error messages that would be slightly differently worded. This can be visible in the internal MISS_HIT testsuite. This is now fixed.

0.9.30

  • Fix a lexing/parsing bug in all tools where classes containing more than one methods block, with a function named end in one of the blocks (but not the last one) would confuse the lexer in ending the special treatment for words such as methods prematurely. This manifested in a confusing error message pointing at methods stating that we expect methods.

    This is now fixed, and you can name functions end again, no matter where.

0.9.29

  • Support the ! and != operators in Octave mode. In Octave mode we now also no longer parse ! as if it was a MATLAB shell escape.

  • Work around an extremely weird bug on some Windows envionments. The behaviour of os.path.abspath could sometimes differ, leading to weird problems like parsing the same config file twice (and then complaining about duplicate definitions). One known environment is using a Windows Python in a git bash environment, but there may be others. This is now hopefully fixed in all such cases.

0.9.28

  • New command-line option for all tools (but only applicable for MH Metric for now): --ignore-justifications-with-tickets. This option can be used to ignore all justifications that quote a ticket. The idea here is that these would be temporary justifications (e.g. "to be fixed in ABC-123"), and you might want to check from time to time how much technical debt you have.

  • MH Lint now checks and enforces the correct syntax for TestTags.

0.9.27

  • MH_Trace now considers all functions in an entrypoint/library tests directory to be a test (not just code in classes with a Test method block). This essentially adds support for test systems that are not based the matlab.unittest.TestCase.

0.9.26

  • All tools have a new common option --include-version, which will print the MISS_HIT version similar to --version; but will continue execution. This is helpful to debug e.g. CI issues.

  • MH_Trace supports a new pragma No_Tracing, which can be used to remove functions from the tracing output. This can be helpful if you have e.g. a test driver or project initialisation code that is neither product code or a test.

0.9.25

  • Support Octave identifiers in Octave mode. In Octave you can start identifiers with an underscore, but you can't do it in MATLAB.

  • Additional information in tracing output produced by mh_trace:

    • test - True if the function is a unit test and false otherwise.
    • shared - Only present if you use project configuration. True if this function is part of a library, and False if it is party of an entrypoint.
  • Minor improvement for error messages on config files with syntax errors: suggestions are offered now.

0.9.24

  • Fix issue in MH Style where the new rule naming_parameters would complain about ~ parameters. These will now always pass name checking, regardless on how your regular expression for parameters looks like.

0.9.23

  • MH Trace can now produce tracing information from code. You can place tracing tags in code using the new pragma Tag:

    %| pragma Tag("Potato");
    
  • MH Style and MH Copyright now support octave-style copyright notices (i.e. Copyright (c) ... instead of (c) Copyright ...).

    The default regular expression for matching copyright notices has changed and must now include a new group. If you have configured this setting, you must also include the new copy group in your regular expression, otherwise the tools break in interesting ways.

  • MH Style supports a new rule "naming_parameters" that enforces a naming scheme for function and method inputs and outputs.

  • MH Style supports a new rule "naming_enumerations" that enforces a naming scheme for class enumerations.

  • Fix various parsing corner cases in parsing extremely dubious code. MISS_HIT previously rejected all of these as parse errors, now it complains about (and fixes) the style instead:

    • A command-form invocation after a try on the same line is now correctly recognised: try rotate3d off; end

    • A global statement can be terminated by a comma or semicolon: try, global dt, f = f*dt; end

    • A single quote directly after a keyword introduces a character array: case'potato'

    • The expression in a for loop does not require any termination: for i=1:indx(1)-1 y(i) = y(indx(1)); end

  • Fix parsing of Contents.m in class directories (previously we expected some code, but these files are supposed to be blank).

  • Fix a tool crash in MH Metrics: when producing the HTML report the tool would crash if there were parse errors in at least one file.

0.9.22

  • Fix bug in MH Trace: libraries unit tests were considered part of the source. This meant tests may have been analysed that would otherwise have been (deliberately) excluded from analysis.

0.9.21

  • MISS_HIT now has an official web-site: http://misshit.org

  • New tool: MH Trace. This tool can extract tracing information (e.g. TestTags) and produce an easy to parse json file.

  • New configuration syntax to allow you to specify directories containing your unit tests. This is specifically useful for mh_trace.

0.9.20

  • Fix a Python 3.6 compatibility issue that I missed during testing.

0.9.19

  • Fix a number of false alarms for MH Lint when detecting built-in shadows. Now functions named e.g. clear are fine if they are in packages (i.e. in directories starting with +).

0.9.18

  • Completely new handling of copyright notices. New configuration option copyright_location decides which approach to use. It can take one of the following values:

    • docstring - the new (and default) approach, copyright notice must be somewhere in the docstring of the class, function, or script file; or at the top of the file.
    • file_header - similar (but not identical) to the old behaviour, copyright notice must be in the file header. However the tool is a bit more relaxed where the copyright notice can appear, and it no longer must be the first line in the file.

    Please note that this changes the default behaviour, if you like something closer to the old approach use file_header. The intention however is to make it possible to write sensible docstrings for working with the MATLAB/Octave help functions; and this new default achieves this.

    Your current notices, if they exist, should be compatible with the new default. Except that we now process and check all notices, not just the first one.

  • The MH Copyright tool has been updated to deal with docstrings as well. It is unfortunately slower (because it now has to parse the file).

  • New rule for MH Style naming_scripts and associated configuration option regex_script_name. The existing naming rules cover all functions, classes and methods. However script escaped this because they are not functions as such. The default for this is the Ada naming scheme (the same default as we have for functions and classes).

  • Fix oversight in MH Lint for checking built-in shadows. Now files (scripts, functions, and classes) are correctly considered. This check uses a much broader list of built-in functions, than the check that looks at assignments.

  • New check for MH Lint to make sure that any file called Contents.m only contains comments.

  • Fixed an obscure internal issue in the lexer: the opening %{ of a block comment now correctly has the block_comment flag set, and the closing marker %} now has the correct value of } instead of %}. There is no user-visible change, but any direct users of the lexer that relied on the old broken behaviour need to remove their workarounds.

  • MISS_HIT is now also published on the MathWorks "File Exchange".

    From now on, the tags will be just the version number, and not pre-pended with release-. For example the tag for this release is 0.9.18 (and not release-0.9.18). The reason for this is that the automatic sync with the MathWorks "File Exchange" only works if the release numbers are following the MAJOR.MINOR.PATCH pattern.

0.9.17

  • Updated language support to MATLAB 2021a. The new feature supported is the new (and extremely unwise) function name-value pairs. This allows you to write foo(bar=baz) instead of two separate arguments: foo('bar', baz). Note very carefully that this is totally different to all other programming languages out there, and not what any reasonable person expects.

    Further note that Octave actually does something worse here, in Octave this would be a side-effect assignment to bar, and only a single argument would be passed.

  • MH Lint has a new (low) check for discouraging the use of name-value function arguments.

  • Fix wrapper class (miss_hit.m), I forgot to update the file names when I remove the .py from the main entry points.

0.9.16

  • New tool MH Copyright to update and change copyright notices in your projects. This can perform one of four actions:

    • update years
    • replace one entity with another
    • merge multiple entities into one
    • add missing notices to files without one
  • New configuration options for the copyright_notice rule of MH Style. You can now change the magic regex to detect copyright notices (copyright_regex), and add 3rd party copyright holders (copyright_3rd_party_entity), and indicate a key copyright holder (copyright_primary_entity). These options are also considered by the MH Copyright tool.

  • Fix issue with entry points: private directories were ignored, they are now considered correctly.

  • Fix issue in MH Style for name checking class methods: class constructors should obviously follow the class naming scheme, not the method naming scheme.

  • Fix issue in MH Style where some confusing messages relating to indentation would be emitted if there was a parse error in the file.

  • Fix bug in all tools relating to copyright_entity. These could be unexpectedly shared between different directory trees, this is now fixed and is working as documented.

  • Support Octave script-global functions in --octave mode. These are function definitions that are sprinkled in the middle of a script file, instead of appearing at the end. Also vastly improve the error message that appears when encountering this construct in MATLAB mode.

0.9.15

  • Added documentation on how to use MISS_HIT through pre-commit hooks.

  • Libraries can now be declared global, making them a dependency for all other libraries and entry points. This is useful for larger code-bases with shared code among all components (e.g. interface definitions).

  • MH Style has a new rule whitespace_around_functions that makes sure each function, nested function, or class method is separated by one blank line from surrounding context. This also works for function without an explicit end keyword.

  • MH Lint has a new check to make sure the filename of a function or class files match the function or class name declared within.

  • Fixed bug in MH Style where blank lines after annotations (e.g. pragma Justify) could sometimes be deleted.

0.9.14

  • Support for projects. This is a major new feature for all MISS_HIT tools, intended to make it easier to analyse specific programs in large shared code repositories. For example instead of having to do:

    $ mh_lint shared_lib_1 shared_lib_2 my_potato_app my_potato_lib
    

    You can now instead simply do:

    $ mh_lint --entry-point=PotatoApp
    

    You can set up libraries and entrypoints and the dependencies between them with new configuration directives.

    Currently the functionality is limited, however in the future this will be the basis for all advanced static analysis; since it provides the equivalent of path or MATLABPATH to the MISS_HIT tools.

  • New documentation for the common command-line interface, which is shared between all MISS_HIT tools (except for MH Diff).

  • New switch for all tools --input-encoding (which is by default cp1252). You can use this to request a different input encoding to be used when reading files.

    Note: this is not applicable for Simulink models, since Simulink models actually specify the input encoding to be used.

  • MH Style has a new rule unicode and two new configuration options enforce_encoding and enforce_encoding_comments to make sure source files only contain ASCII characters.

    You can configure the encoding enforced using enforce_encoding to e.g. iso8859_15, if that is what you want instead; and you can optionally allow comments and line continuations to contain anything.

  • Fixed bug in MH Metric HTML reports. When MH Metric was installed via pip, the link to the assets and style sheets did not resolve. This is now fixed.

    In addition the new --portable-html option for MH Metric will hotlink to the assets from https://florianschanda.github.io/miss_hit instead of trying to use the ones from the locally installed MISS_HIT.

0.9.13

  • All tools can now run without parameters. By default we analyse the current directory, i.e. the default behaviour of mh_style is now the same as mh_style .

  • MH Diff: A new tool, that can be used to diff the code embedded inside Simulink models. The best way to use it is through git, for example: git difftool HEAD^ -yx "mh_diff" Potato.slx

    You can also provide the option --kdiff3 to show a visual diff (on systems that have kdiff3 installed).

  • Config file directive no longer have to be separated by newlines. While this is still encouraged for readability, it is no longer an error to write a single directive over multiple lines or multiple directives on the same line.

  • Fix minor issue with regex_tickets where regular expressions with brackets only matched what was inside the brackets. For example a ticket regex with (a|b)-[0-9] should match both a-5 and b-2, but the ticket mentioned in the report was only a and b.

  • Support hex and binary literals (e.g. 0x12s64) from MATLAB 2019b. This resolves the one outstanding compatibility issue, and we should now be compatible with up to and including MATLAB 2020b.

  • MH Style now accepts a slightly wider form of copyright statements (specifically you can now include the word 'by' before the legal entity).

0.9.12

  • [CORRECTNESS] Fix lexing of 1./b. This was a critical bug that caused the expression to be incorrectly formatted as 1. / b (i.e. using / instead of ./).

    The main user-visible problem is that the style rule operator_whitespace could then re-write expressions and change semantics of the re-written code.

  • Fix parsing of [,]. This is a valid expression and is equivalent to []. Previously a syntax error was issued.

  • Fix parsing of [;;1] and similar expressions where leading or trailing semicolons or newlines were present in a matrix or cell. Previously a syntax error was issued.

  • MH Style has a new rule spurious_row_semicolon which removes useless semicolons from matrix or cell expressions.

  • MH Style now aligns any continuations in a more sensible way if the expression is inside brackets. This works for normal brackets, but also matrix and cell expressions:

    potato = [1 0
              0 1];
    kitten = foo(bar, ...
                 baz);
    

    There are two new configuration options to control this behaviour: align_round_brackets and align_other_brackets for ( and [{ respectively.

  • New configuration option regex_tickets which can be used to identify which text strings are tickets in your particular issue tracking system. This information is used by MH Metric to produce a report on all tickets referenced in justifications.

  • MH BMC: Started work on an experimental tool for bounded model checking. This tool is not usable for anything yet, but is intended as a proof-of-concept.

  • Also provide the --html option for MH Lint.

  • New --json option for MH Style and MH Lint to produce message using JSON. In the future the --html option from MH Style and MH Lint will disappear and be replaced by a small set of tools that render JSON messages in plain text, HTML, or post messages as gerrit review comments. The exact schema of this JSON file is not stable yet.

0.9.11

  • MH Lint now contains the three lint-like messages that were part of MH Style previously (block comments, relation chaining, and builtin redefinition). MH Style no longer issues these messages.

    Note that MH Lint currently operators on a file-by-file basis like, just like the other MISS_HIT tools. However this will definitely change in the future, as we move to a "per project" analysis for the linter. But for now MH Lint can be use just like the other tools.

  • The configuration directive "style rule" for "builtin_redefinition" is now a lint rule; while this change is not documented yet properly it will mean existing configuration files continue to work. I have not yet decided how lint rules will be configurable, but it is likely they will share a namespace with the style rules.

  • Added documentation for lint checks, explaining the meaning of "low", "medium", and "high" checks.

  • Added GitHub and Travis CI templates to the documentation. Thank you Remi Gau for your contribution.

  • MH Style now correctly vertically aligns annotations. One-line annotation blocks were always OK, but multi-line annotations were considered continuations (and thus indented in an unnatural way).

  • MH Style has a new rule spurious_row_comma which complains about trailing or starting commas in matrix and cell expressions (for example: [,1,2,])

  • MH Style has a new rule whitespace_semicolon which does the same as whitespace_comma, but for semicolons; this means one-line matrix expressions are now nicely formatted.

  • MH Style should now only print [fixed] for problems that really are fixed. Specifically in files that contain parse errors, we now no longer pretend the problems are fixed.

  • Fixed an issue for all MISS_HIT tools where any issue in embedded MATLAB code could be reported multiple times.

0.9.10

  • Fixed another Windows multi-threading issue.

  • Reverted new behaviour to consider all directories containing .git as a project root. It is useful, but until it can be configured (#156) it can be really disruptive.

  • MH Metric can now produce reports in JSON using the new --json option.

  • Rename packages (miss_hit_agpl is now miss_hit, and miss_hit is now miss_hit_core). It's likely this is not the last renaming, sorry. I can only promise that it will be stable after 1.0 is released.

0.9.9

  • Minor fix for the case where an excluded_dir contains a broken config file.

0.9.8

  • #151 Rewrote configuration file mechanism. The change is backwards compatible, so existing files will continue to work.
    • Fixed an issue where broken configuration files higher up the directory tree (and unrelated to the project you're analysing) impacted analysis.
    • Fixed an issue where files in directories hard-excluded (i.e. using exclude_dir as opposed to enable: 0) counted as files excluded from analysis. This seems weird, but the intention was that excluded directories were effectively considered deleted and would not influence anything, ever.
    • We no longer enter any directory starting with . when searching for files to analyse.
    • New config directive project_root that effectively resets all configuration and starts from a blank slate.
    • Any directory containing the .git directory is also considered a project root. This means checkout out sub-projects are not influenced by your configuration file. I plan to make this behaviour configurable in the future.
    • Proper documentation for configuration files

0.9.7

  • #148 MISS_HIT is now a PyPI package. This change should also make it much easier to re-use the compiler framework of MISS_HIT in other tools. You can still use it by just checking out the code, but be aware that some entry points have changed:

    • most source code lives in the miss_hit package (not the top-level)
    • the top-level script mh_metric.py is now called mh_metric
    • the top-level script mh_style.py is now called mh_style
  • Reworked Simulink parser to provide a much deeper parsing. While there is no user-visible effect of this change right now, it paves the way for producing code metrics on the Simulink model itself (and not just embedded MATLAB code).

0.9.6

  • MH Style can now analyse (and fix) code inside Simulink models. This new functionality must be enabled with the new command-line flag --process-slx. This flag is temporary and will be removed in the future once this feature is stable enough.

  • MH Style has a new configuration option copyright_in_embedded_code which is turned off by default. By default the copyright_notice rule does not apply to embedded code, and this option can be used to control that behaviour.

  • MH Style has a wider definition of a useless_continuation. This rule now also applies to continuations that begin statements.

  • MH Metric has a new syntax in configuration files to completely disable a named software metric. You do this with disable for a named metric, e.g. metric "function_length": disable. With this option the metric doesn't even appear in the final report (as opposed to the default where we measure a metric, but not complain about it).

  • MH Metric has new syntax in configuration files to enable or disable all metrics. You do this by using metric *: report and metric *: disable respectively.

  • MH Metric now uses more human readable names for the metrics in both the HTML and text report.

0.9.5

  • Disabled (but not removed) the implicit_shortcircuit rule. It turns out that in some cases & really does mean &, even inside an if guard. Curiously, mlint/checkcode shares this bug. To properly resolve this we need semantic analysis and type inference; so until then this rule just does nothing.

  • MH Metric can now process and produce metrics for code inside modern SIMULINK models (slx files). This does not work yet in MH Style, but I plan to also support this there.

0.9.4

Features

  • MH Style has a new (autofixed) rule no_starting_newline to make sure files do not start with just whitespace.

  • MH Style has a new (autofixed) rule implicit_shortcircuit that complains about misleading use of & and | inside if/while guards.

  • The MH tools now allow all possible class method names, even the ones that are highly questionable like "import", "end", or "arguments".

Fixes

  • #131 The parser now allows the end of statement (newline, comma, or semicolon) after an enumeration keyword to be optional. I.e. we can now process this code fragment correctly:

    enumeration Picasso, Laura, King_Edward
    end
    

0.9.3

Features

  • MH Metric can now measure cyclomatic complexity. We've aimed for producing the same numbers as mlint does, even if it's wrong.

  • MH Metric produces an (optional) table of "worst offenders" for each metric. This can be used to get a quick overview of code smell.

Fixes

  • Fix for #133: resolved multi-threading issues on Windows. To be honest, this seems more like a Python bug.

0.9.2

Fixes

  • Workaround for #133. Until I can work what the root cause of this is, multi-threading is disabled on Windows platforms.

0.9.1

This is the first "release", previously it was all just one development stream. This release contains two tools:

  • mh_style.py: a fully functional style checker and code formatter for MATLAB.

  • mh_metric.py: a mostly functional code metrics tool for MATLAB. Some metric (in particular cyclomatic complexity) are not measured yet.