/checkstyle-idea

CheckStyle plug-in for IntelliJ IDEA

Primary LanguageJavaOtherNOASSERTION

CheckStyle-IDEA
---------------
(c) Copyright 2006-2013 CheckStyle-IDEA Contributors

https://github.com/jshiell/checkstyle-idea

A plug-in for JetBrains' IntelliJ IDEA 12 which provides real-time feedback
against a given CheckStyle (http://checkstyle.sourceforge.net/)
profile by way of an inspection.

Released under a BSD-style licence - please see the LICENCE file for details.

Use
---

Once installed, a new inspection will be available in the group 'CheckStyle'.
The 'Inspections' item in the preferences panel will allow you to turn this on
and to configure it.

Project exceptions are treated a little oddly. Because CheckStyle demands these
to be on the current classpath errors will appear if these have not as yet
been compiled. Further, because we cache the real-time checkers for performance
reasons, real-time scans may continue to show the errors after a compilation.
A static scan will force a reload of the Checker and should resolve this.


Configuration
-------------

Configuration is available under the Settings dialogue. This controls
configuration for both the inspection and static scanning.

- Configuration File tab -

The main configuration option is that of the CheckStyle file. Multiple
CheckStyle file may be added, and swapped between by using the checkbox.
Files may be added using the 'Add' button.

The 'Scan Test Classes' checkbox will enable scanning of Java files
under test source roots. If disabled, these files will be ignored.

If a custom file is being used and properties are available for definition
then these will accessible using the 'Edit Properties' button.

- Third Party Checks tab -

This tab allows you to specify any third-party checks which your
configuration file makes use of. All selected directories/JAR files
will be added to CheckStyle's classpath.


Troubleshooting
---------------

If an error occurs during the check an exception will be thrown, which
IDEA will then catch and display in the standard exceptions dialogue. If
you're unsure as to why things are awry this would be your best bet - chances
are it's a missing property or classpath pre-requisite.


Frequently Asked Questions
--------------------------

q) I see 'Got an exception - java.lang.RuntimeException: Unable to get class
   information for <Exception Class>. (0:0)'
a) CheckStyle is unable to retrieve information on exceptions in your project
   until you have built it. Build your project in IDEA and then rescan.


Limitations
-----------

* The plugin will throw exceptions if used with class files targeted at a
  later version than that of the JDK used by IDEA. In particular, this will
  affect Mac users with the pre-release of JDK6. The solution is to target
  class files at the version of the IDEA JRE (i.e. 1.5 for Mac users). Thanks
  to J. G. Christopher.

* If you change the configuration options the real-time scan will not be updated
  until the file is either changed or reopened.

* We do not check if a property definition is required for a given file.
  Hence you can exit configuration without setting required properties. Given,
  however, that CheckStyle files can change without the plug-in being aware
  this is something we'll always have to live with to some degree.

* CheckStyle errors and warnings from the inspection are both shown at
  a single level, as IDEA will only allow one warning level for an inspection.
  
* Loading a file from a URL is current experimental and not guaranteed to do
  anything at all.


Future
------

The following are potential features which are likely to be investigated
for future releases.

* Scan selected files/folder in the project panel.
* Better error feedback.


Feedback
--------

Any comments or bug reports are most welcome - please visit
the project website at https://github.com/jshiell/checkstyle-idea/


Acknowledgements
----------------

This plug-in owes its existence to both the style-overlords at work mandating
compliance with a CheckStyle configuration, and the Eclipse-CS
(http://eclipse-cs.sourceforge.net/) authors for making me jealous of the
real-time scan support available for Eclipse.

Thanks to those who have contributed work and effort directly to this project:

* J. G. Christopher
* jicken
* Jonas Bergvall
* Edward Campbell
* LightGuard.JP
* Gerhard Radatz
* Benjy W
* Yuri
* Kristin Young

 And also thanks are due to the authors and contributors of:

* Eclipse-CS, for inspiration and solutions to coding problems.
* JetStyle, for filling the area of static scanning and also giving me
  inspirations on coding solutions.
* CheckStyle, for without them we'd have merely void and chaos.
* JetBrains, for an IDE which is worth every penny and them some.

And a big thank-you to everyone who's sent me feedback or bug reports - both
are much appreciated!


Licence
-------

This code is released under a BSD licence, as specified in the accompanying
LICENCE file.


Version History
---------------

4.2   - New: There is now a specific option to make rules files project relative (#60).
4.2   - Fixed: Suppression files accessed via HTTP(S) now work again; thanks to Kristin Young (#61).
4.1   - New: There is now a configuration option to stop CheckStyle errors being display as IDEA errors (#50).
4.1   - New: A warning is now displayed for rules files using DoubleCheckedLocking.
4.1   - Fixed: Case of file prefix should now no longer randomly change (#59).
4.0.2 - Fixed: Module classpath should only expose classes, not resources (#56).
4.0.2 - Fixed: IllegalArgumentException sometimes thrown by CheckerFactory.getConfig (#55).
4.0.2 - Fixed: ToolWindow icon is now 13x13 pixels (#52).
4.0.1 - Fixed: NPE on Checker lookup (#49).
4.0.1 - Fixed: Read Access error (#39).
4.0   - New: You can now specify template CheckStyle configuration in the Default Project (#33).
4.0   - New: CheckStyle errors will now be marked as errors by the inspection.
4.0   - New: Updated to IDEA 12 API. . This means we now require IDEA 12.0.1 or above.
4.0   - Improved: Updated plugin structure to something a little more modern, allowing goodies such as #33.
4.0   - Fixed: Dependent modules are now probably included when searching for custom exceptions (#42).
3.9.1 - Fixed: Default rules are invalid with CS5.6.
3.9   - Fixed: Match on leading project path causes tokenisation silliness (#9).
3.9   - New: Updated CheckStyle to 5.6.
3.8.4 - Fixed: IDE error on pre-check-in scan (#39).
3.8.3 - Fixed: Synchronisation issue introduced by earlier fix (#36).
3.8.2 - Fixed: Library classes are now included in the Checkstyle classpath (#34).
3.8.2 - Fixed: Removed actions not specific to the current editor from the popup menu (#31).
3.8.2 - Fixed: Changed text to match IDEA by removing full-stops (#30).
3.8.1 - Fixed: Inline regexp header defs no longer cause an exception (#29).
3.8   - New: An option has been added to scan all (i.e. non-Java) files.
3.8   - New: A button has been added to scan the current change list.
3.8   - New: Modules can now be excluded from scans.
3.8   - New: Add File dialogue now sets the base directory to the project directory.
3.8   - Improved: RegexpHeader.headerFile is now resolved in the same manner as the suppression file.
3.8   - Improved: Rewrote file tokenisation to hopefully help with #9.
3.7   - New: Updated CheckStyle to 5.5.
3.7   - New: Added button to trigger rules refresh (#25).
3.7   - Fixed: Assertion errors from IDEA are now ignored during Inspections executions (#22).
3.7   - Fixed: Scan on check-in broken in IDEA 11 (#24).
3.6.2 - Improved: Scan results are now sorted alphabetically.
3.6.2 - Fixed: Duplicate errors reported during project scans (#16).
3.6.2 - Fixed: Edited rule file properties are now properly saved.
3.6.1 - Fixed: Deadlock when trying to access editor information with IDEA 11.
3.6   - New: Changed to work with IDEA 11. Thanks to Yuri.
3.5   - New: Updated CheckStyle to 5.4.
3.5   - Fixed: NPE during property handling.
3.5   - Fixed: Property change detection improved.
3.5   - Improved: General cleanup and deprecation removals.
3.4.1 - Fixed: Intermittent NPE on check-in handler registration.
3.4   - New: Support for IDEA 10.5. Older versions are no longer supported.
3.3.2 - Fixed: Relative paths for suppression filters were not working.
3.3.1 - Fixed: StringIndexOutOfBoundsException when creating temporary files under Windows.
3.3   - Improved: Suppression filters now work on package paths.
3.3   - Improved: Closed and saved files are no longer copied to temporary files.
3.2   - New: Updated CheckStyle to 5.3.
3.2   - Improved: Temporary files now use original filename. Thanks to Benjy W.
3.2   - Improved: Removed deprecated calls to IDEA SDK. This may break compatibility with older versions,
        but as the SDK isn't annotated with @since, who knows?
3.2   - Improved: Introduced setup thread to project scans to improve responsiveness.
3.1.2 - Fixed: Property names trimmed.
3.1.2 - Fixed: Cache is now invalidated when settings are changed.
3.1.2 - Fixed: Files downloaded via HTTP are now scheduled for deletion of JVM termination.
3.1.1 - Fixed: NPE on notifications.
3.1   - New: Upgraded to CheckStyle 5.1.
3.1   - Improved: Suppression files are now searched for relative to the project if they are not present relative to the config file.
3.1   - Improved: If a suppression file is not found then it will be ignored and the user will be warned.
3.1   - Fixed: Concurrency issues. Thanks to Gerhard Radatz.
3.0.13- Fixed: File location fixes galore! Thanks to Gerhard Radatz.
3.0.13- Fixed: Removing active configuration no longer causes an exception. Thanks to Gerhard Radatz.
3.0.12- Fixed: Inspection ID now correctly conforms to rules. Apologies if this breaks inspection config.
3.0.11- Improved: Module/Project scans are properly batched and a lot faster. Progress feedback is more limited, however.
3.0.10- Fixed: Partial property detection. Thanks to LightGuard.JP.
3.0.9 - Fixed: Cache sychronisation problem.
3.0.8 - Fixed: Null property in configuration hash-table resulting in NPE.
3.0.7 - Fixed: Module scan results are no longer shared between files.
3.0.6 - Fixed: IDEA 9 compatibility.
3.0.5 - Fixed: Filters (e.g. SuppressionCommentFilter) now work correctly.
3.0.5 - Fixed: JavadocPackage now respects allowLegacy. Thanks to Edward Campbell.
3.0.4 - Fixed: CheckStyle DTD 1.3 added. Thanks to Jonas Bergvall.
3.0.3 - Fixed: Removed dependency on Apache commons-lang to restore compatibility with IDEA 7.0.x/Linux.
3.0.2 - Fixed: File configuration column headings were incorrect.
3.0.1 - Fixed: Rule files added with no description cause an exception.
3.0   - New: Module-specific configuration support.
3.0   - New: CheckStyle 5.0 support. Thanks to jicken.
             Note that CheckStyle 5.0 is not entirely backwards compatible. A quick guide to many of the changes
             can be found here: http://checkstyle.sourceforge.net/releasenotes.html
3.0   - New: Result list may be filtered on severity.
3.0   - New: Back-end re-written to support multiple CheckStyle files. You will need to set your configuration
             once again I'm afraid.
             
2.4   - New: Default CheckStyle file now has generics patch applied.
2.4   - New: Scans in progress may be aborted.
2.4   - Fixed: Null Pointer Exception with package HTML check.
2.4   - Fixed: Null Pointer Exception when files have no module.
2.4   - Fixed: Background scan thread does not wait on event thread.
2.3   - Fixed: Property values are not lost on configuration commit.
2.3   - Fixed: Exceptions in JAR files are not picked up.
2.3   - Fixed: Scan Modified Files is now disabled while other scans are active.
2.3   - Fixed: Background scan thread is now lower priority.
2.3   - Fixed: Module scan now works again.
2.2   - Fixed: Now works with IDEA8.0.
2.2   - New: Ability to scan on check-in. Thanks to J. G. Christopher.
2.2   - Experimental: Ability to load CheckStyle configuration from a URL. This is NOT robust at present.
2.1   - New: Ability to scan only modified files if project uses VCS. If the project
        does not use VCS then this action will have no effect. Thanks to J. G. Christopher
        for this patch.
2.1   - New: Ability to suppress checks on test classes.
2.1   - New: Updated CheckStyle to 4.4.
2.1   - Fixed: Suppression filters with relative paths now load correctly.
2.1   - Fixed: NewlineAtEndOfFile now works on Windows.
2.1   - Fixed: PackageHtml test will now work.
2.0.1 - WARNING: Due to persistence changes you will need to reconfigure the plug-in after upgrading.
2.0.1 - Fixed: Configuration dialogue now enables 'apply' when moving to default
        scheme from a configuration file.
2.0.1 - Changed: Remove deprecated API calls to [hopefully] ensure forward 7.0 compatibility.      
2.0.1 - Changed: Icons improved.
2.0.0 - This version offers no new features. However, 2.x versions will only work
        with IDEA 7M2 or above.
2.0.0 - Fixed: API changes for IDEA 7M2.

1.0.2 - Improved: Error handling
1.0.2 - Fixed: Exception when settings opened while no project loaded.
1.0.2 - Fixed: Exception if inspection cancelled during results processing.
1.0.2 - Fixed: Exception if configuration panel opened while puppycrawl.com
        could not be accessed.
1.0.1 - Fixed: Potentially IllegalState if project path cannot be retrieved
        within IDEA 7M1.
1.0   - New: Static scanning for current module implemented.
      - New: Ability to add third-party checks.
      - New: Ability to define external properties.
      - New: Now works with IDEA 7M1.
      - Fixed: Exceptions defined in project will no longer generate
        a CheckStyle error once they have been compiled.

0.5.2 - New: Settings are now stored in project, not workspace.
0.5.1 - Fixed: NullPointer when a null PSI element is encountered
        during scanning.
0.5   - Improved: Localisation support.
      - Improved: Config file locations under the project root are now
        stored as relative rather than the system-specific absolute path.
      - New: CheckStyle icons added.
0.4   - New: Added static scanning support.
      - New: Updated CheckStyle to 4.3.
0.3   - Improved: CheckStyle caching improved.
      - Improved: Temporary file deletion.
0.2   - Fix: File browser for configuration file filters out directories.
0.1   - Initial release.