Versions Compared


  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Migrated to Confluence 5.3

Java bytecode analysis is required to use this rule.



This coding rule is available for .Net and Java projects.

Note that compiled code must be available.

Source code complies to an architectural model when it fully adheres to a set of architectural constraints. An Setting an architectural constraint allows you to deny set patterns to flag forbidden references between classes by pattern.

Here are some examples of patterns:

  • forbid access to *.web.* from *.dao.* classes
  • forbid access to java.util.Vector, java.util.Hashtable and java.util.Enumeration from any classes
  • forbid access to java.sql.* from *.ui.* and **.web.* classes

An "Architectural constraint" rule, provided by the "Sonar " rule engine, allows to define as many architectural constraints as desired:

The architectural constraint should be considered as a rule template and should not be directly activated. Let's say for instance that you want to forbid use of java.sql package by all your projects. In that case, you must first "Copy" the "Architectural constraint" rule to create and share your own specialized architectural constraint: