]> source.dussan.org Git - sonarqube.git/commitdiff
Reformat Findbugs rules.xml for better readability
authorEvgeny Mandrikov <mandrikov@gmail.com>
Wed, 8 Aug 2012 10:13:10 +0000 (16:13 +0600)
committerEvgeny Mandrikov <mandrikov@gmail.com>
Wed, 8 Aug 2012 10:13:10 +0000 (16:13 +0600)
plugins/sonar-findbugs-plugin/src/main/resources/org/sonar/plugins/findbugs/rules.xml

index ddb0a82bbb153a84e244e330a20a1621e00a48ac..cc53c9794ce69be10883be838103613d2aa3ec1d 100644 (file)
 <rules>
-  <!-- Findbugs 1.3.9 -->
+
   <rule key="BC_IMPOSSIBLE_DOWNCAST">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - Impossible downcast]]></name>
     <configKey><![CDATA[BC_IMPOSSIBLE_DOWNCAST]]></configKey>
-
-
   </rule>
+
   <rule key="BC_IMPOSSIBLE_DOWNCAST_OF_TOARRAY">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - Impossible downcast of toArray() result]]></name>
     <configKey><![CDATA[BC_IMPOSSIBLE_DOWNCAST_OF_TOARRAY]]></configKey>
-
-
   </rule>
+
   <rule key="EC_INCOMPATIBLE_ARRAY_COMPARE">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - equals(...) used to compare incompatible arrays]]></name>
     <configKey><![CDATA[EC_INCOMPATIBLE_ARRAY_COMPARE]]></configKey>
-
-
   </rule>
+
   <rule key="EC_INCOMPATIBLE_ARRAY_COMPARE">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - equals(...) used to compare incompatible arrays]]></name>
     <configKey><![CDATA[EC_INCOMPATIBLE_ARRAY_COMPARE]]></configKey>
-
-
   </rule>
+
   <rule key="LG_LOST_LOGGER_DUE_TO_WEAK_REFERENCE">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Potential lost logger changes due to weak reference in OpenJDK ]]></name>
     <configKey><![CDATA[LG_LOST_LOGGER_DUE_TO_WEAK_REFERENCE]]></configKey>
-
-
   </rule>
 
   <rule key="NP_CLOSING_NULL">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - close() invoked on a value that is always null]]></name>
     <configKey><![CDATA[NP_CLOSING_NULL]]></configKey>
-
-
   </rule>
 
   <rule key="RC_REF_COMPARISON_BAD_PRACTICE">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Suspicious reference comparison to constant]]></name>
     <configKey><![CDATA[RC_REF_COMPARISON_BAD_PRACTICE]]></configKey>
-
-
   </rule>
 
   <rule key="RC_REF_COMPARISON_BAD_PRACTICE_BOOLEAN">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Suspicious reference comparison of Boolean values]]></name>
     <configKey><![CDATA[RC_REF_COMPARISON_BAD_PRACTICE_BOOLEAN]]></configKey>
-
-
   </rule>
 
   <rule key="RV_RETURN_VALUE_OF_PUTIFABSENT_IGNORED">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Return value of putIfAbsent ignored, value passed to putIfAbsent reused ]]></name>
     <configKey><![CDATA[RV_RETURN_VALUE_OF_PUTIFABSENT_IGNORED]]></configKey>
-
-
   </rule>
 
   <rule key="SIC_THREADLOCAL_DEADLY_EMBRACE">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Deadly embrace of non-static inner class and thread local]]></name>
     <configKey><![CDATA[SIC_THREADLOCAL_DEADLY_EMBRACE]]></configKey>
-
-
   </rule>
 
   <rule key="UR_UNINIT_READ_CALLED_FROM_SUPER_CONSTRUCTOR">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Uninitialized read of field method called from constructor of superclass]]></name>
     <configKey><![CDATA[UR_UNINIT_READ_CALLED_FROM_SUPER_CONSTRUCTOR]]></configKey>
-
-
   </rule>
 
   <rule key="VA_FORMAT_STRING_EXPECTED_MESSAGE_FORMAT_SUPPLIED">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - MessageFormat supplied where printf style format expected ]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_EXPECTED_MESSAGE_FORMAT_SUPPLIED]]></configKey>
-
-
   </rule>
 
-
-  <!-- Before Findbugs 1.3.9 -->
   <rule key="UWF_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR">
     <priority>MINOR</priority>
     <name><![CDATA[Correctness - Field not initialized in constructor]]></name>
     <configKey><![CDATA[UWF_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR]]></configKey>
-
-
   </rule>
+
   <rule key="NP_UNWRITTEN_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Read of unwritten field]]></name>
     <configKey><![CDATA[NP_UNWRITTEN_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="UWF_UNWRITTEN_FIELD">
     <priority>MINOR</priority>
     <name><![CDATA[Correctness - Unwritten field]]></name>
     <configKey><![CDATA[UWF_UNWRITTEN_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="SKIPPED_CLASS_TOO_BIG">
     <priority>MINOR</priority>
     <name><![CDATA[Dodgy - Class too big for analysis]]></name>
     <configKey><![CDATA[SKIPPED_CLASS_TOO_BIG]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_SCHEDULED_THREAD_POOL_EXECUTOR_WITH_ZERO_CORE_THREADS">
     <priority>MINOR</priority>
     <name><![CDATA[Correctness - Creation of ScheduledThreadPoolExecutor with zero core threads]]></name>
     <configKey><![CDATA[DMI_SCHEDULED_THREAD_POOL_EXECUTOR_WITH_ZERO_CORE_THREADS]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_FUTILE_ATTEMPT_TO_CHANGE_MAXPOOL_SIZE_OF_SCHEDULED_THREAD_POOL_EXECUTOR">
     <priority>MINOR</priority>
     <name><![CDATA[Correctness - Futile attempt to change max pool size of ScheduledThreadPoolExecutor]]></name>
     <configKey><![CDATA[DMI_FUTILE_ATTEMPT_TO_CHANGE_MAXPOOL_SIZE_OF_SCHEDULED_THREAD_POOL_EXECUTOR]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_UNSUPPORTED_METHOD">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Call to unsupported method]]></name>
     <configKey><![CDATA[DMI_UNSUPPORTED_METHOD]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_EMPTY_DB_PASSWORD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Security - Empty database password]]></name>
     <configKey><![CDATA[DMI_EMPTY_DB_PASSWORD]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_CONSTANT_DB_PASSWORD">
     <priority>BLOCKER</priority>
     <name><![CDATA[Security - Hardcoded constant database password]]></name>
     <configKey><![CDATA[DMI_CONSTANT_DB_PASSWORD]]></configKey>
-
-
   </rule>
+
   <rule key="HRS_REQUEST_PARAMETER_TO_COOKIE">
     <priority>MAJOR</priority>
     <name><![CDATA[Security - HTTP cookie formed from untrusted input]]></name>
     <configKey><![CDATA[HRS_REQUEST_PARAMETER_TO_COOKIE]]></configKey>
-
-
   </rule>
+
   <rule key="HRS_REQUEST_PARAMETER_TO_HTTP_HEADER">
     <priority>MAJOR</priority>
     <name><![CDATA[Security - HTTP Response splitting vulnerability]]></name>
     <configKey><![CDATA[HRS_REQUEST_PARAMETER_TO_HTTP_HEADER]]></configKey>
-
-
   </rule>
+
   <rule key="XSS_REQUEST_PARAMETER_TO_SERVLET_WRITER">
     <priority>CRITICAL</priority>
     <name><![CDATA[Security - Servlet reflected cross site scripting vulnerability]]></name>
     <configKey><![CDATA[XSS_REQUEST_PARAMETER_TO_SERVLET_WRITER]]></configKey>
-
-
   </rule>
+
   <rule key="XSS_REQUEST_PARAMETER_TO_SEND_ERROR">
     <priority>CRITICAL</priority>
     <name><![CDATA[Security - Servlet reflected cross site scripting vulnerability]]></name>
     <configKey><![CDATA[XSS_REQUEST_PARAMETER_TO_SEND_ERROR]]></configKey>
-
-
   </rule>
+
   <rule key="XSS_REQUEST_PARAMETER_TO_JSP_WRITER">
     <priority>CRITICAL</priority>
     <name><![CDATA[Security - JSP reflected cross site scripting vulnerability]]></name>
     <configKey><![CDATA[XSS_REQUEST_PARAMETER_TO_JSP_WRITER]]></configKey>
-
-
   </rule>
+
   <rule key="SW_SWING_METHODS_INVOKED_IN_SWING_THREAD">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Certain swing methods needs to be invoked in Swing thread]]></name>
     <configKey><![CDATA[SW_SWING_METHODS_INVOKED_IN_SWING_THREAD]]></configKey>
-
-
   </rule>
+
   <rule key="IL_INFINITE_LOOP">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - An apparent infinite loop]]></name>
     <configKey><![CDATA[IL_INFINITE_LOOP]]></configKey>
-
-
   </rule>
+
   <rule key="IL_INFINITE_RECURSIVE_LOOP">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - An apparent infinite recursive loop]]></name>
     <configKey><![CDATA[IL_INFINITE_RECURSIVE_LOOP]]></configKey>
-
-
   </rule>
+
   <rule key="IL_CONTAINER_ADDED_TO_ITSELF">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - A collection is added to itself]]></name>
     <configKey><![CDATA[IL_CONTAINER_ADDED_TO_ITSELF]]></configKey>
-
-
   </rule>
+
   <rule key="VO_VOLATILE_REFERENCE_TO_ARRAY">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Multithreaded correctness - A volatile reference to an array doesn't treat the array elements as volatile]]></name>
+    <name><![CDATA[Multithreaded correctness - A volatile reference to an array doesn't treat the array elements as volatile]]></name>
     <configKey><![CDATA[VO_VOLATILE_REFERENCE_TO_ARRAY]]></configKey>
-
-
   </rule>
+
   <rule key="UI_INHERITANCE_UNSAFE_GETRESOURCE">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Usage of GetResource may be unsafe if class is extended]]></name>
     <configKey><![CDATA[UI_INHERITANCE_UNSAFE_GETRESOURCE]]></configKey>
-
-
   </rule>
+
   <rule key="NP_BOOLEAN_RETURN_NULL">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Method with Boolean return type returns explicit null]]></name>
     <configKey><![CDATA[NP_BOOLEAN_RETURN_NULL]]></configKey>
-
-
   </rule>
+
   <rule key="NP_SYNC_AND_NULL_CHECK_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Synchronize and null check on the same field.]]></name>
     <configKey><![CDATA[NP_SYNC_AND_NULL_CHECK_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="RpC_REPEATED_CONDITIONAL_TEST">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Repeated conditional tests]]></name>
     <configKey><![CDATA[RpC_REPEATED_CONDITIONAL_TEST]]></configKey>
-
-
   </rule>
+
   <rule key="AM_CREATES_EMPTY_ZIP_FILE_ENTRY">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Creates an empty zip file entry]]></name>
     <configKey><![CDATA[AM_CREATES_EMPTY_ZIP_FILE_ENTRY]]></configKey>
-
-
   </rule>
+
   <rule key="AM_CREATES_EMPTY_JAR_FILE_ENTRY">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Creates an empty jar file entry]]></name>
     <configKey><![CDATA[AM_CREATES_EMPTY_JAR_FILE_ENTRY]]></configKey>
-
-
   </rule>
+
   <rule key="IMSE_DONT_CATCH_IMSE">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Dubious catching of IllegalMonitorStateException]]></name>
     <configKey><![CDATA[IMSE_DONT_CATCH_IMSE]]></configKey>
-
-
   </rule>
+
   <rule key="FL_MATH_USING_FLOAT_PRECISION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Method performs math using floating point precision]]></name>
     <configKey><![CDATA[FL_MATH_USING_FLOAT_PRECISION]]></configKey>
-
-
   </rule>
+
   <rule key="CN_IDIOM">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Class implements Cloneable but does not define or use clone method]]></name>
     <configKey><![CDATA[CN_IDIOM]]></configKey>
-
-
   </rule>
+
   <rule key="CN_IMPLEMENTS_CLONE_BUT_NOT_CLONEABLE">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Class defines clone() but doesn't implement Cloneable]]></name>
     <configKey><![CDATA[CN_IMPLEMENTS_CLONE_BUT_NOT_CLONEABLE]]></configKey>
-
-
   </rule>
+
   <rule key="CN_IDIOM_NO_SUPER_CALL">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - clone method does not call super.clone()]]></name>
     <configKey><![CDATA[CN_IDIOM_NO_SUPER_CALL]]></configKey>
-
-
   </rule>
+
   <rule key="NM_FUTURE_KEYWORD_USED_AS_IDENTIFIER">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Use of identifier that is a keyword in later versions of Java]]></name>
     <configKey><![CDATA[NM_FUTURE_KEYWORD_USED_AS_IDENTIFIER]]></configKey>
-
-
   </rule>
+
   <rule key="NM_FUTURE_KEYWORD_USED_AS_MEMBER_IDENTIFIER">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Use of identifier that is a keyword in later versions of Java]]></name>
     <configKey><![CDATA[NM_FUTURE_KEYWORD_USED_AS_MEMBER_IDENTIFIER]]></configKey>
-
-
   </rule>
+
   <rule key="DE_MIGHT_DROP">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Method might drop exception]]></name>
     <configKey><![CDATA[DE_MIGHT_DROP]]></configKey>
-
-
   </rule>
+
   <rule key="DE_MIGHT_IGNORE">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Method might ignore exception]]></name>
     <configKey><![CDATA[DE_MIGHT_IGNORE]]></configKey>
-
-
   </rule>
+
   <rule key="DP_DO_INSIDE_DO_PRIVILEGED">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Method invoked that should be only be invoked inside a doPrivileged block]]></name>
     <configKey><![CDATA[DP_DO_INSIDE_DO_PRIVILEGED]]></configKey>
-
-
   </rule>
+
   <rule key="DP_CREATE_CLASSLOADER_INSIDE_DO_PRIVILEGED">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Classloaders should only be created inside doPrivileged block]]></name>
     <configKey><![CDATA[DP_CREATE_CLASSLOADER_INSIDE_DO_PRIVILEGED]]></configKey>
-
-
   </rule>
+
   <rule key="JCIP_FIELD_ISNT_FINAL_IN_IMMUTABLE_CLASS">
     <priority>MINOR</priority>
     <name><![CDATA[Bad practice - Fields of immutable classes should be final]]></name>
     <configKey><![CDATA[JCIP_FIELD_ISNT_FINAL_IN_IMMUTABLE_CLASS]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_THREAD_PASSED_WHERE_RUNNABLE_EXPECTED">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Thread passed where Runnable expected]]></name>
     <configKey><![CDATA[DMI_THREAD_PASSED_WHERE_RUNNABLE_EXPECTED]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_COLLECTION_OF_URLS">
     <priority>BLOCKER</priority>
     <name><![CDATA[Performance - Maps and sets of URLs can be performance hogs]]></name>
     <configKey><![CDATA[DMI_COLLECTION_OF_URLS]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_BLOCKING_METHODS_ON_URL">
     <priority>BLOCKER</priority>
     <name><![CDATA[Performance - The equals and hashCode methods of URL are blocking]]></name>
     <configKey><![CDATA[DMI_BLOCKING_METHODS_ON_URL]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_ANNOTATION_IS_NOT_VISIBLE_TO_REFLECTION">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Correctness - Can't use reflection to check for presence of annotation without runtime retention]]></name>
+    <name><![CDATA[Correctness - Can't use reflection to check for presence of annotation without runtime retention]]></name>
     <configKey><![CDATA[DMI_ANNOTATION_IS_NOT_VISIBLE_TO_REFLECTION]]></configKey>
-
-
   </rule>
+
   <rule key="DM_EXIT">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Method invokes System.exit(...)]]></name>
     <configKey><![CDATA[DM_EXIT]]></configKey>
-
-
   </rule>
+
   <rule key="DM_RUN_FINALIZERS_ON_EXIT">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Method invokes dangerous method runFinalizersOnExit]]></name>
     <configKey><![CDATA[DM_RUN_FINALIZERS_ON_EXIT]]></configKey>
-
-
   </rule>
+
   <rule key="DM_STRING_CTOR">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Method invokes inefficient new String(String) constructor]]></name>
     <configKey><![CDATA[DM_STRING_CTOR]]></configKey>
-
-
   </rule>
+
   <rule key="DM_STRING_VOID_CTOR">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Method invokes inefficient new String() constructor]]></name>
     <configKey><![CDATA[DM_STRING_VOID_CTOR]]></configKey>
-
-
   </rule>
+
   <rule key="DM_STRING_TOSTRING">
     <priority>INFO</priority>
     <name><![CDATA[Performance - Method invokes toString() method on a String]]></name>
     <configKey><![CDATA[DM_STRING_TOSTRING]]></configKey>
-
-
   </rule>
+
   <rule key="DM_GC">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Explicit garbage collection; extremely dubious except in benchmarking code]]></name>
     <configKey><![CDATA[DM_GC]]></configKey>
-
-
   </rule>
+
   <rule key="DM_BOOLEAN_CTOR">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Performance - Method invokes inefficient Boolean constructor; use Boolean.valueOf(...) instead]]></name>
+    <name><![CDATA[Performance - Method invokes inefficient Boolean constructor; use Boolean.valueOf(...) instead]]></name>
     <configKey><![CDATA[DM_BOOLEAN_CTOR]]></configKey>
-
-
   </rule>
+
   <rule key="DM_NUMBER_CTOR">
     <priority>CRITICAL</priority>
     <name><![CDATA[Performance - Method invokes inefficient Number constructor; use static valueOf instead]]></name>
     <configKey><![CDATA[DM_NUMBER_CTOR]]></configKey>
-
-
   </rule>
+
   <rule key="DM_FP_NUMBER_CTOR">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Performance - Method invokes inefficient floating-point Number constructor; use static valueOf instead]]></name>
+    <name><![CDATA[Performance - Method invokes inefficient floating-point Number constructor; use static valueOf instead]]></name>
     <configKey><![CDATA[DM_FP_NUMBER_CTOR]]></configKey>
-
-
   </rule>
+
   <rule key="DM_CONVERT_CASE">
     <priority>INFO</priority>
     <name><![CDATA[Internationalization - Consider using Locale parameterized version of invoked method]]></name>
     <configKey><![CDATA[DM_CONVERT_CASE]]></configKey>
-
-
   </rule>
+
   <rule key="BX_UNBOXED_AND_COERCED_FOR_TERNARY_OPERATOR">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Primitive value is unboxed and coerced for ternary operator]]></name>
     <configKey><![CDATA[BX_UNBOXED_AND_COERCED_FOR_TERNARY_OPERATOR]]></configKey>
-
-
   </rule>
+
   <rule key="BX_BOXING_IMMEDIATELY_UNBOXED">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Primitive value is boxed and then immediately unboxed]]></name>
     <configKey><![CDATA[BX_BOXING_IMMEDIATELY_UNBOXED]]></configKey>
-
-
   </rule>
+
   <rule key="BX_BOXING_IMMEDIATELY_UNBOXED_TO_PERFORM_COERCION">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Primitive value is boxed then unboxed to perform primitive coercion]]></name>
     <configKey><![CDATA[BX_BOXING_IMMEDIATELY_UNBOXED_TO_PERFORM_COERCION]]></configKey>
-
-
   </rule>
+
   <rule key="DM_BOXED_PRIMITIVE_TOSTRING">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Method allocates a boxed primitive just to call toString]]></name>
     <configKey><![CDATA[DM_BOXED_PRIMITIVE_TOSTRING]]></configKey>
-
-
   </rule>
+
   <rule key="DM_NEW_FOR_GETCLASS">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Method allocates an object, only to get the class object]]></name>
     <configKey><![CDATA[DM_NEW_FOR_GETCLASS]]></configKey>
-
-
   </rule>
+
   <rule key="DM_MONITOR_WAIT_ON_CONDITION">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Monitor wait() called on Condition]]></name>
     <configKey><![CDATA[DM_MONITOR_WAIT_ON_CONDITION]]></configKey>
-
-
   </rule>
+
   <rule key="RV_01_TO_INT">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Random value from 0 to 1 is coerced to the integer 0]]></name>
     <configKey><![CDATA[RV_01_TO_INT]]></configKey>
-
-
   </rule>
+
   <rule key="DM_NEXTINT_VIA_NEXTDOUBLE">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Performance - Use the nextInt method of Random rather than nextDouble to generate a random integer]]></name>
+    <name><![CDATA[Performance - Use the nextInt method of Random rather than nextDouble to generate a random integer]]></name>
     <configKey><![CDATA[DM_NEXTINT_VIA_NEXTDOUBLE]]></configKey>
-
-
   </rule>
+
   <rule key="SQL_NONCONSTANT_STRING_PASSED_TO_EXECUTE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Security - Nonconstant string passed to execute method on an SQL statement]]></name>
     <configKey><![CDATA[SQL_NONCONSTANT_STRING_PASSED_TO_EXECUTE]]></configKey>
-
-
   </rule>
+
   <rule key="SQL_PREPARED_STATEMENT_GENERATED_FROM_NONCONSTANT_STRING">
     <priority>CRITICAL</priority>
     <name><![CDATA[Security - A prepared statement is generated from a nonconstant String]]></name>
     <configKey><![CDATA[SQL_PREPARED_STATEMENT_GENERATED_FROM_NONCONSTANT_STRING]]></configKey>
-
-
   </rule>
+
   <rule key="DM_USELESS_THREAD">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - A thread was created using the default empty run method]]></name>
     <configKey><![CDATA[DM_USELESS_THREAD]]></configKey>
-
-
   </rule>
+
   <rule key="DC_DOUBLECHECK">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Possible double check of field]]></name>
     <configKey><![CDATA[DC_DOUBLECHECK]]></configKey>
-
-
   </rule>
+
   <rule key="FI_FINALIZER_NULLS_FIELDS">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Finalizer nulls fields]]></name>
     <configKey><![CDATA[FI_FINALIZER_NULLS_FIELDS]]></configKey>
-
-
   </rule>
+
   <rule key="FI_FINALIZER_ONLY_NULLS_FIELDS">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Finalizer only nulls fields]]></name>
     <configKey><![CDATA[FI_FINALIZER_ONLY_NULLS_FIELDS]]></configKey>
-
-
   </rule>
+
   <rule key="FI_PUBLIC_SHOULD_BE_PROTECTED">
     <priority>MAJOR</priority>
     <name><![CDATA[Malicious code vulnerability - Finalizer should be protected, not public]]></name>
     <configKey><![CDATA[FI_PUBLIC_SHOULD_BE_PROTECTED]]></configKey>
-
-
   </rule>
+
   <rule key="FI_EMPTY">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Empty finalizer should be deleted]]></name>
     <configKey><![CDATA[FI_EMPTY]]></configKey>
-
-
   </rule>
+
   <rule key="FI_NULLIFY_SUPER">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Finalizer nullifies superclass finalizer]]></name>
     <configKey><![CDATA[FI_NULLIFY_SUPER]]></configKey>
-
-
   </rule>
+
   <rule key="FI_USELESS">
     <priority>MINOR</priority>
     <name><![CDATA[Bad practice - Finalizer does nothing but call superclass finalizer]]></name>
     <configKey><![CDATA[FI_USELESS]]></configKey>
-
-
   </rule>
+
   <rule key="FI_MISSING_SUPER_CALL">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Finalizer does not call superclass finalizer]]></name>
     <configKey><![CDATA[FI_MISSING_SUPER_CALL]]></configKey>
-
-
   </rule>
+
   <rule key="FI_EXPLICIT_INVOCATION">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Explicit invocation of finalizer]]></name>
     <configKey><![CDATA[FI_EXPLICIT_INVOCATION]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_CHECK_FOR_OPERAND_NOT_COMPATIBLE_WITH_THIS">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Equals checks for noncompatible operand]]></name>
     <configKey><![CDATA[EQ_CHECK_FOR_OPERAND_NOT_COMPATIBLE_WITH_THIS]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_DONT_DEFINE_EQUALS_FOR_ENUM">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Covariant equals() method defined for enum]]></name>
     <configKey><![CDATA[EQ_DONT_DEFINE_EQUALS_FOR_ENUM]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_SELF_USE_OBJECT">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Covariant equals() method defined, Object.equals(Object) inherited]]></name>
     <configKey><![CDATA[EQ_SELF_USE_OBJECT]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_OTHER_USE_OBJECT">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - equals() method defined that doesn't override Object.equals(Object)]]></name>
     <configKey><![CDATA[EQ_OTHER_USE_OBJECT]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_OTHER_NO_OBJECT">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - equals() method defined that doesn't override equals(Object)]]></name>
     <configKey><![CDATA[EQ_OTHER_NO_OBJECT]]></configKey>
-
-
-  </rule>
+  </rule>
 
   <!-- warning : http://sourceforge.net/tracker/?func=detail&aid=2786054&group_id=96405&atid=614693 -->
   <rule key="EQ_DOESNT_OVERRIDE_EQUALS">
     <name><![CDATA[Dodgy - Class doesn't override equals in superclass]]></name>
     <configKey><![CDATA[EQ_DOESNT_OVERRIDE_EQUALS]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_SELF_NO_OBJECT">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Covariant equals() method defined]]></name>
     <configKey><![CDATA[EQ_SELF_NO_OBJECT]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_OVERRIDING_EQUALS_NOT_SYMMETRIC">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - equals method overrides equals in superclass and may not be symmetric]]></name>
     <configKey><![CDATA[EQ_OVERRIDING_EQUALS_NOT_SYMMETRIC]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_GETCLASS_AND_CLASS_CONSTANT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - equals method fails for subtypes]]></name>
     <configKey><![CDATA[EQ_GETCLASS_AND_CLASS_CONSTANT]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_UNUSUAL">
     <priority>MINOR</priority>
     <name><![CDATA[Dodgy - Unusual equals method ]]></name>
     <configKey><![CDATA[EQ_UNUSUAL]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_COMPARING_CLASS_NAMES">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - equals method compares class names rather than class objects]]></name>
     <configKey><![CDATA[EQ_COMPARING_CLASS_NAMES]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_ALWAYS_TRUE">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - equals method always returns true]]></name>
     <configKey><![CDATA[EQ_ALWAYS_TRUE]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_ALWAYS_FALSE">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - equals method always returns false]]></name>
     <configKey><![CDATA[EQ_ALWAYS_FALSE]]></configKey>
-
-
   </rule>
+
   <rule key="HSC_HUGE_SHARED_STRING_CONSTANT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Performance - Huge string constants is duplicated across multiple class files]]></name>
     <configKey><![CDATA[HSC_HUGE_SHARED_STRING_CONSTANT]]></configKey>
-
-
   </rule>
+
   <rule key="NP_ARGUMENT_MIGHT_BE_NULL">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Method does not check for null argument]]></name>
     <configKey><![CDATA[NP_ARGUMENT_MIGHT_BE_NULL]]></configKey>
-
-
   </rule>
+
   <rule key="NP_EQUALS_SHOULD_HANDLE_NULL_ARGUMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - equals() method does not check for null argument]]></name>
     <configKey><![CDATA[NP_EQUALS_SHOULD_HANDLE_NULL_ARGUMENT]]></configKey>
-
-
   </rule>
+
   <rule key="CO_SELF_NO_OBJECT">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Covariant compareTo() method defined]]></name>
     <configKey><![CDATA[CO_SELF_NO_OBJECT]]></configKey>
-
-
   </rule>
+
   <rule key="HE_SIGNATURE_DECLARES_HASHING_OF_UNHASHABLE_CLASS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Signature declares use of unhashable class in hashed construct]]></name>
     <configKey><![CDATA[HE_SIGNATURE_DECLARES_HASHING_OF_UNHASHABLE_CLASS]]></configKey>
-
-
   </rule>
+
   <rule key="HE_USE_OF_UNHASHABLE_CLASS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Use of class without a hashCode() method in a hashed data structure]]></name>
     <configKey><![CDATA[HE_USE_OF_UNHASHABLE_CLASS]]></configKey>
-
-
   </rule>
+
   <rule key="HE_HASHCODE_USE_OBJECT_EQUALS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Class defines hashCode() and uses Object.equals()]]></name>
     <configKey><![CDATA[HE_HASHCODE_USE_OBJECT_EQUALS]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_COMPARETO_USE_OBJECT_EQUALS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Class defines compareTo(...) and uses Object.equals()]]></name>
     <configKey><![CDATA[EQ_COMPARETO_USE_OBJECT_EQUALS]]></configKey>
-
-
   </rule>
+
   <rule key="HE_HASHCODE_NO_EQUALS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Class defines hashCode() but not equals()]]></name>
     <configKey><![CDATA[HE_HASHCODE_NO_EQUALS]]></configKey>
-
-
   </rule>
+
   <rule key="HE_EQUALS_USE_HASHCODE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Class defines equals() and uses Object.hashCode()]]></name>
     <configKey><![CDATA[HE_EQUALS_USE_HASHCODE]]></configKey>
-
-
   </rule>
+
   <rule key="HE_INHERITS_EQUALS_USE_HASHCODE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Class inherits equals() and uses Object.hashCode()]]></name>
     <configKey><![CDATA[HE_INHERITS_EQUALS_USE_HASHCODE]]></configKey>
-
-
   </rule>
+
   <rule key="HE_EQUALS_NO_HASHCODE">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Class defines equals() but not hashCode()]]></name>
     <configKey><![CDATA[HE_EQUALS_NO_HASHCODE]]></configKey>
-
-
   </rule>
+
   <rule key="EQ_ABSTRACT_SELF">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Abstract class defines covariant equals() method]]></name>
     <configKey><![CDATA[EQ_ABSTRACT_SELF]]></configKey>
-
-
   </rule>
+
   <rule key="ES_COMPARING_STRINGS_WITH_EQ">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Comparison of String objects using == or !=]]></name>
     <configKey><![CDATA[ES_COMPARING_STRINGS_WITH_EQ]]></configKey>
-
-
   </rule>
+
   <rule key="ES_COMPARING_PARAMETER_STRING_WITH_EQ">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Comparison of String parameter using == or !=]]></name>
     <configKey><![CDATA[ES_COMPARING_PARAMETER_STRING_WITH_EQ]]></configKey>
-
-
   </rule>
+
   <rule key="CO_ABSTRACT_SELF">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Abstract class defines covariant compareTo() method]]></name>
     <configKey><![CDATA[CO_ABSTRACT_SELF]]></configKey>
-
-
   </rule>
+
   <rule key="IS_FIELD_NOT_GUARDED">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Field not guarded against concurrent access]]></name>
     <configKey><![CDATA[IS_FIELD_NOT_GUARDED]]></configKey>
-
-
   </rule>
+
   <rule key="MSF_MUTABLE_SERVLET_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Mutable servlet field]]></name>
     <configKey><![CDATA[MSF_MUTABLE_SERVLET_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="IS2_INCONSISTENT_SYNC">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Inconsistent synchronization]]></name>
     <configKey><![CDATA[IS2_INCONSISTENT_SYNC]]></configKey>
-
-
   </rule>
+
   <rule key="NN_NAKED_NOTIFY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Naked notify]]></name>
     <configKey><![CDATA[NN_NAKED_NOTIFY]]></configKey>
-
-
   </rule>
+
   <rule key="MS_EXPOSE_REP">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Malicious code vulnerability - Public static method may expose internal representation by returning array]]></name>
+    <name><![CDATA[Malicious code vulnerability - Public static method may expose internal representation by returning array]]></name>
     <configKey><![CDATA[MS_EXPOSE_REP]]></configKey>
-
-
   </rule>
+
   <rule key="EI_EXPOSE_REP">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Malicious code vulnerability - May expose internal representation by returning reference to mutable object]]></name>
+    <name><![CDATA[Malicious code vulnerability - May expose internal representation by returning reference to mutable object]]></name>
     <configKey><![CDATA[EI_EXPOSE_REP]]></configKey>
-
-
   </rule>
+
   <rule key="EI_EXPOSE_REP2">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Malicious code vulnerability - May expose internal representation by incorporating reference to mutable object]]></name>
+    <name><![CDATA[Malicious code vulnerability - May expose internal representation by incorporating reference to mutable object]]></name>
     <configKey><![CDATA[EI_EXPOSE_REP2]]></configKey>
-
-
   </rule>
+
   <rule key="EI_EXPOSE_STATIC_REP2">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Malicious code vulnerability - May expose internal static state by storing a mutable object into a static field]]></name>
+    <name><![CDATA[Malicious code vulnerability - May expose internal static state by storing a mutable object into a static field]]></name>
     <configKey><![CDATA[EI_EXPOSE_STATIC_REP2]]></configKey>
-
-
   </rule>
+
   <rule key="RU_INVOKE_RUN">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Invokes run on a thread (did you mean to start it instead?)]]></name>
     <configKey><![CDATA[RU_INVOKE_RUN]]></configKey>
-
-
   </rule>
+
   <rule key="SP_SPIN_ON_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Method spins on field]]></name>
     <configKey><![CDATA[SP_SPIN_ON_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="NS_DANGEROUS_NON_SHORT_CIRCUIT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Potentially dangerous use of non-short-circuit logic]]></name>
     <configKey><![CDATA[NS_DANGEROUS_NON_SHORT_CIRCUIT]]></configKey>
-
-
   </rule>
+
   <rule key="NS_NON_SHORT_CIRCUIT">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Questionable use of non-short-circuit logic]]></name>
     <configKey><![CDATA[NS_NON_SHORT_CIRCUIT]]></configKey>
-
-
   </rule>
+
   <rule key="TLW_TWO_LOCK_WAIT">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Wait with two locks held]]></name>
     <configKey><![CDATA[TLW_TWO_LOCK_WAIT]]></configKey>
-
-
   </rule>
+
   <rule key="UW_UNCOND_WAIT">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Unconditional wait]]></name>
     <configKey><![CDATA[UW_UNCOND_WAIT]]></configKey>
-
-
   </rule>
+
   <rule key="UR_UNINIT_READ">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Uninitialized read of field in constructor]]></name>
     <configKey><![CDATA[UR_UNINIT_READ]]></configKey>
-
-
   </rule>
+
   <rule key="UG_SYNC_SET_UNSYNC_GET">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Unsynchronized get method, synchronized set method]]></name>
     <configKey><![CDATA[UG_SYNC_SET_UNSYNC_GET]]></configKey>
-
-
   </rule>
+
   <rule key="IC_INIT_CIRCULARITY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Initialization circularity]]></name>
     <configKey><![CDATA[IC_INIT_CIRCULARITY]]></configKey>
-
-
   </rule>
+
   <rule key="IC_SUPERCLASS_USES_SUBCLASS_DURING_INITIALIZATION">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Superclass uses subclass during initialization]]></name>
     <configKey><![CDATA[IC_SUPERCLASS_USES_SUBCLASS_DURING_INITIALIZATION]]></configKey>
-
-
   </rule>
+
   <rule key="IT_NO_SUCH_ELEMENT">
     <priority>MINOR</priority>
     <name><![CDATA[Bad practice - Iterator next() method can't throw NoSuchElementException]]></name>
     <configKey><![CDATA[IT_NO_SUCH_ELEMENT]]></configKey>
-
-
   </rule>
+
   <rule key="DL_SYNCHRONIZATION_ON_SHARED_CONSTANT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Synchronization on interned String could lead to deadlock]]></name>
     <configKey><![CDATA[DL_SYNCHRONIZATION_ON_SHARED_CONSTANT]]></configKey>
-
-
   </rule>
+
   <rule key="DL_SYNCHRONIZATION_ON_BOOLEAN">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Synchronization on Boolean could lead to deadlock]]></name>
     <configKey><![CDATA[DL_SYNCHRONIZATION_ON_BOOLEAN]]></configKey>
-
-
   </rule>
+
   <rule key="DL_SYNCHRONIZATION_ON_UNSHARED_BOXED_PRIMITIVE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Synchronization on boxed primitive values]]></name>
     <configKey><![CDATA[DL_SYNCHRONIZATION_ON_UNSHARED_BOXED_PRIMITIVE]]></configKey>
-
-
   </rule>
+
   <rule key="DL_SYNCHRONIZATION_ON_BOXED_PRIMITIVE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Synchronization on boxed primitive could lead to deadlock]]></name>
     <configKey><![CDATA[DL_SYNCHRONIZATION_ON_BOXED_PRIMITIVE]]></configKey>
-
-
   </rule>
+
   <rule key="ESync_EMPTY_SYNC">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Empty synchronized block]]></name>
     <configKey><![CDATA[ESync_EMPTY_SYNC]]></configKey>
-
-
   </rule>
+
   <rule key="IS_INCONSISTENT_SYNC">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Inconsistent synchronization]]></name>
     <configKey><![CDATA[IS_INCONSISTENT_SYNC]]></configKey>
-
-
   </rule>
+
   <rule key="ML_SYNC_ON_FIELD_TO_GUARD_CHANGING_THAT_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Synchronization on field in futile attempt to guard that field]]></name>
     <configKey><![CDATA[ML_SYNC_ON_FIELD_TO_GUARD_CHANGING_THAT_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="ML_SYNC_ON_UPDATED_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Multithreaded correctness - Method synchronizes on an updated field]]></name>
     <configKey><![CDATA[ML_SYNC_ON_UPDATED_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="MS_OOI_PKGPROTECT">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Malicious code vulnerability - Field should be moved out of an interface and made package protected]]></name>
+    <name><![CDATA[Malicious code vulnerability - Field should be moved out of an interface and made package protected]]></name>
     <configKey><![CDATA[MS_OOI_PKGPROTECT]]></configKey>
-
-
   </rule>
+
   <rule key="MS_FINAL_PKGPROTECT">
     <priority>MAJOR</priority>
     <name><![CDATA[Malicious code vulnerability - Field should be both final and package protected]]></name>
     <configKey><![CDATA[MS_FINAL_PKGPROTECT]]></configKey>
-
-
   </rule>
+
   <rule key="MS_SHOULD_BE_FINAL">
     <priority>MAJOR</priority>
     <name><![CDATA[Malicious code vulnerability - Field isn't final but should be]]></name>
     <configKey><![CDATA[MS_SHOULD_BE_FINAL]]></configKey>
-
-
   </rule>
+
   <rule key="MS_PKGPROTECT">
     <priority>MAJOR</priority>
     <name><![CDATA[Malicious code vulnerability - Field should be package protected]]></name>
     <configKey><![CDATA[MS_PKGPROTECT]]></configKey>
-
-
   </rule>
+
   <rule key="MS_MUTABLE_HASHTABLE">
     <priority>MAJOR</priority>
     <name><![CDATA[Malicious code vulnerability - Field is a mutable Hashtable]]></name>
     <configKey><![CDATA[MS_MUTABLE_HASHTABLE]]></configKey>
-
-
   </rule>
+
   <rule key="MS_MUTABLE_ARRAY">
     <priority>MAJOR</priority>
     <name><![CDATA[Malicious code vulnerability - Field is a mutable array]]></name>
     <configKey><![CDATA[MS_MUTABLE_ARRAY]]></configKey>
-
-
   </rule>
+
   <rule key="MS_CANNOT_BE_FINAL">
     <priority>MAJOR</priority>
     <name><![CDATA[Malicious code vulnerability - Field isn't final and can't be protected from malicious code]]></name>
     <configKey><![CDATA[MS_CANNOT_BE_FINAL]]></configKey>
-
-
   </rule>
+
   <rule key="IA_AMBIGUOUS_INVOCATION_OF_INHERITED_OR_OUTER_METHOD">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Ambiguous invocation of either an inherited or outer method]]></name>
     <configKey><![CDATA[IA_AMBIGUOUS_INVOCATION_OF_INHERITED_OR_OUTER_METHOD]]></configKey>
-
-
   </rule>
+
   <rule key="NM_SAME_SIMPLE_NAME_AS_SUPERCLASS">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Class names shouldn't shadow simple name of superclass]]></name>
     <configKey><![CDATA[NM_SAME_SIMPLE_NAME_AS_SUPERCLASS]]></configKey>
-
-
   </rule>
+
   <rule key="NM_SAME_SIMPLE_NAME_AS_INTERFACE">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Class names shouldn't shadow simple name of implemented interface]]></name>
     <configKey><![CDATA[NM_SAME_SIMPLE_NAME_AS_INTERFACE]]></configKey>
-
-
   </rule>
+
   <rule key="NM_VERY_CONFUSING">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Very confusing method names]]></name>
     <configKey><![CDATA[NM_VERY_CONFUSING]]></configKey>
-
-
   </rule>
+
   <rule key="NM_VERY_CONFUSING_INTENTIONAL">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Very confusing method names (but perhaps intentional)]]></name>
     <configKey><![CDATA[NM_VERY_CONFUSING_INTENTIONAL]]></configKey>
-
-
   </rule>
+
   <rule key="NM_WRONG_PACKAGE">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Correctness - Method doesn't override method in superclass due to wrong package for parameter]]></name>
+    <name><![CDATA[Correctness - Method doesn't override method in superclass due to wrong package for parameter]]></name>
     <configKey><![CDATA[NM_WRONG_PACKAGE]]></configKey>
-
-
   </rule>
+
   <rule key="NM_WRONG_PACKAGE_INTENTIONAL">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Bad practice - Method doesn't override method in superclass due to wrong package for parameter]]></name>
+    <name><![CDATA[Bad practice - Method doesn't override method in superclass due to wrong package for parameter]]></name>
     <configKey><![CDATA[NM_WRONG_PACKAGE_INTENTIONAL]]></configKey>
-
-
   </rule>
+
   <rule key="NM_CONFUSING">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Confusing method names]]></name>
     <configKey><![CDATA[NM_CONFUSING]]></configKey>
-
-
   </rule>
+
   <rule key="NM_METHOD_CONSTRUCTOR_CONFUSION">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Apparent method/constructor confusion]]></name>
     <configKey><![CDATA[NM_METHOD_CONSTRUCTOR_CONFUSION]]></configKey>
-
-
   </rule>
+
   <rule key="NM_CLASS_NOT_EXCEPTION">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Class is not derived from an Exception, even though it is named as such]]></name>
     <configKey><![CDATA[NM_CLASS_NOT_EXCEPTION]]></configKey>
-
-
   </rule>
+
   <rule key="RR_NOT_CHECKED">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Method ignores results of InputStream.read()]]></name>
     <configKey><![CDATA[RR_NOT_CHECKED]]></configKey>
-
-
   </rule>
+
   <rule key="SR_NOT_CHECKED">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Method ignores results of InputStream.skip()]]></name>
     <configKey><![CDATA[SR_NOT_CHECKED]]></configKey>
-
-
   </rule>
+
   <rule key="SE_READ_RESOLVE_IS_STATIC">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - The readResolve method must not be declared as a static method.  ]]></name>
     <configKey><![CDATA[SE_READ_RESOLVE_IS_STATIC]]></configKey>
-
-
   </rule>
+
   <rule key="SE_PRIVATE_READ_RESOLVE_NOT_INHERITED">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - private readResolve method not inherited by subclasses]]></name>
     <configKey><![CDATA[SE_PRIVATE_READ_RESOLVE_NOT_INHERITED]]></configKey>
-
-
   </rule>
+
   <rule key="SE_READ_RESOLVE_MUST_RETURN_OBJECT">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - The readResolve method must be declared with a return type of Object. ]]></name>
     <configKey><![CDATA[SE_READ_RESOLVE_MUST_RETURN_OBJECT]]></configKey>
-
-
   </rule>
+
   <rule key="SE_TRANSIENT_FIELD_OF_NONSERIALIZABLE_CLASS">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Transient field of class that isn't Serializable. ]]></name>
     <configKey><![CDATA[SE_TRANSIENT_FIELD_OF_NONSERIALIZABLE_CLASS]]></configKey>
-
-
   </rule>
+
   <rule key="SE_TRANSIENT_FIELD_NOT_RESTORED">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Transient field that isn't set by deserialization. ]]></name>
     <configKey><![CDATA[SE_TRANSIENT_FIELD_NOT_RESTORED]]></configKey>
-
-
   </rule>
+
   <rule key="SE_METHOD_MUST_BE_PRIVATE">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Method must be private in order for serialization to work]]></name>
     <configKey><![CDATA[SE_METHOD_MUST_BE_PRIVATE]]></configKey>
-
-
   </rule>
+
   <rule key="SE_NO_SUITABLE_CONSTRUCTOR_FOR_EXTERNALIZATION">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Class is Externalizable but doesn't define a void constructor]]></name>
     <configKey><![CDATA[SE_NO_SUITABLE_CONSTRUCTOR_FOR_EXTERNALIZATION]]></configKey>
-
-
   </rule>
+
   <rule key="SE_NO_SUITABLE_CONSTRUCTOR">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Class is Serializable but its superclass doesn't define a void constructor]]></name>
     <configKey><![CDATA[SE_NO_SUITABLE_CONSTRUCTOR]]></configKey>
-
-
   </rule>
+
   <rule key="SE_NO_SERIALVERSIONID">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Class is Serializable, but doesn't define serialVersionUID]]></name>
     <configKey><![CDATA[SE_NO_SERIALVERSIONID]]></configKey>
-
-
   </rule>
+
   <rule key="SE_COMPARATOR_SHOULD_BE_SERIALIZABLE">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Comparator doesn't implement Serializable]]></name>
     <configKey><![CDATA[SE_COMPARATOR_SHOULD_BE_SERIALIZABLE]]></configKey>
-
-
   </rule>
+
   <rule key="WS_WRITEOBJECT_SYNC">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Multithreaded correctness - Class's writeObject() method is synchronized but nothing else is]]></name>
+    <name><![CDATA[Multithreaded correctness - Class's writeObject() method is synchronized but nothing else is]]></name>
     <configKey><![CDATA[WS_WRITEOBJECT_SYNC]]></configKey>
-
-
   </rule>
+
   <rule key="RS_READOBJECT_SYNC">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Class's readObject() method is synchronized]]></name>
     <configKey><![CDATA[RS_READOBJECT_SYNC]]></configKey>
-
-
   </rule>
+
   <rule key="SE_NONSTATIC_SERIALVERSIONID">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - serialVersionUID isn't static]]></name>
     <configKey><![CDATA[SE_NONSTATIC_SERIALVERSIONID]]></configKey>
-
-
   </rule>
+
   <rule key="SE_NONFINAL_SERIALVERSIONID">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - serialVersionUID isn't final]]></name>
     <configKey><![CDATA[SE_NONFINAL_SERIALVERSIONID]]></configKey>
-
-
   </rule>
+
   <rule key="SE_NONLONG_SERIALVERSIONID">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - serialVersionUID isn't long]]></name>
     <configKey><![CDATA[SE_NONLONG_SERIALVERSIONID]]></configKey>
-
-
   </rule>
+
   <rule key="SE_BAD_FIELD_INNER_CLASS">
     <priority>MINOR</priority>
     <name><![CDATA[Bad practice - Non-serializable class has a serializable inner class]]></name>
     <configKey><![CDATA[SE_BAD_FIELD_INNER_CLASS]]></configKey>
-
-
   </rule>
+
   <rule key="SE_INNER_CLASS">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Serializable inner class]]></name>
     <configKey><![CDATA[SE_INNER_CLASS]]></configKey>
-
-
   </rule>
+
   <rule key="SE_BAD_FIELD_STORE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Non-serializable value stored into instance field of a serializable class]]></name>
     <configKey><![CDATA[SE_BAD_FIELD_STORE]]></configKey>
-
-
   </rule>
+
   <rule key="SC_START_IN_CTOR">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Constructor invokes Thread.start()]]></name>
     <configKey><![CDATA[SC_START_IN_CTOR]]></configKey>
-
-
   </rule>
+
   <rule key="SS_SHOULD_BE_STATIC">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Unread field: should this field be static?]]></name>
     <configKey><![CDATA[SS_SHOULD_BE_STATIC]]></configKey>
-
-
   </rule>
+
   <rule key="UUF_UNUSED_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Unused field]]></name>
     <configKey><![CDATA[UUF_UNUSED_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="URF_UNREAD_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Unread field]]></name>
     <configKey><![CDATA[URF_UNREAD_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="QF_QUESTIONABLE_FOR_LOOP">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Complicated, subtle or wrong increment in for-loop ]]></name>
     <configKey><![CDATA[QF_QUESTIONABLE_FOR_LOOP]]></configKey>
-
-
   </rule>
+
   <rule key="UWF_NULL_FIELD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Field only ever set to null]]></name>
     <configKey><![CDATA[UWF_NULL_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="ST_WRITE_TO_STATIC_FROM_INSTANCE_METHOD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Write to static field from instance method]]></name>
     <configKey><![CDATA[ST_WRITE_TO_STATIC_FROM_INSTANCE_METHOD]]></configKey>
-
-
   </rule>
+
   <rule key="NP_LOAD_OF_KNOWN_NULL_VALUE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Load of known null value]]></name>
     <configKey><![CDATA[NP_LOAD_OF_KNOWN_NULL_VALUE]]></configKey>
-
-
   </rule>
+
   <rule key="NP_DEREFERENCE_OF_READLINE_VALUE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Dereference of the result of readLine() without nullcheck]]></name>
     <configKey><![CDATA[NP_DEREFERENCE_OF_READLINE_VALUE]]></configKey>
-
-
   </rule>
+
   <rule key="NP_IMMEDIATE_DEREFERENCE_OF_READLINE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Immediate dereference of the result of readLine()]]></name>
     <configKey><![CDATA[NP_IMMEDIATE_DEREFERENCE_OF_READLINE]]></configKey>
-
-
   </rule>
+
   <rule key="SIC_INNER_SHOULD_BE_STATIC">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Should be a static inner class]]></name>
     <configKey><![CDATA[SIC_INNER_SHOULD_BE_STATIC]]></configKey>
-
-
   </rule>
+
   <rule key="SIC_INNER_SHOULD_BE_STATIC_ANON">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Could be refactored into a named static inner class]]></name>
     <configKey><![CDATA[SIC_INNER_SHOULD_BE_STATIC_ANON]]></configKey>
-
-
   </rule>
+
   <rule key="SIC_INNER_SHOULD_BE_STATIC_NEEDS_THIS">
     <priority>MAJOR</priority>
     <name><![CDATA[Performance - Could be refactored into a static inner class]]></name>
     <configKey><![CDATA[SIC_INNER_SHOULD_BE_STATIC_NEEDS_THIS]]></configKey>
-
-
   </rule>
+
   <rule key="WA_NOT_IN_LOOP">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Wait not in loop ]]></name>
     <configKey><![CDATA[WA_NOT_IN_LOOP]]></configKey>
-
-
   </rule>
+
   <rule key="WA_AWAIT_NOT_IN_LOOP">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Condition.await() not in loop ]]></name>
     <configKey><![CDATA[WA_AWAIT_NOT_IN_LOOP]]></configKey>
-
-
   </rule>
+
   <rule key="NO_NOTIFY_NOT_NOTIFYALL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Using notify() rather than notifyAll()]]></name>
     <configKey><![CDATA[NO_NOTIFY_NOT_NOTIFYALL]]></configKey>
-
-
   </rule>
+
   <rule key="RV_CHECK_FOR_POSITIVE_INDEXOF">
     <priority>MINOR</priority>
     <name><![CDATA[Dodgy - Method checks to see if result of String.indexOf is positive]]></name>
     <configKey><![CDATA[RV_CHECK_FOR_POSITIVE_INDEXOF]]></configKey>
-
-
   </rule>
+
   <rule key="RV_DONT_JUST_NULL_CHECK_READLINE">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Method discards result of readLine after checking if it is nonnull]]></name>
     <configKey><![CDATA[RV_DONT_JUST_NULL_CHECK_READLINE]]></configKey>
-
-
   </rule>
+
   <rule key="RV_RETURN_VALUE_IGNORED">
     <priority>MINOR</priority>
     <name><![CDATA[Correctness - Method ignores return value]]></name>
     <configKey><![CDATA[RV_RETURN_VALUE_IGNORED]]></configKey>
-
-
   </rule>
+
   <rule key="RV_RETURN_VALUE_IGNORED_BAD_PRACTICE">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Method ignores exceptional return value]]></name>
     <configKey><![CDATA[RV_RETURN_VALUE_IGNORED_BAD_PRACTICE]]></configKey>
-
-
   </rule>
+
   <rule key="RV_EXCEPTION_NOT_THROWN">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Exception created and dropped rather than thrown]]></name>
     <configKey><![CDATA[RV_EXCEPTION_NOT_THROWN]]></configKey>
-
-
   </rule>
+
   <rule key="RV_RETURN_VALUE_IGNORED2">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Method ignores return value]]></name>
     <configKey><![CDATA[RV_RETURN_VALUE_IGNORED2]]></configKey>
-
-
   </rule>
+
   <rule key="NP_ALWAYS_NULL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Null pointer dereference]]></name>
     <configKey><![CDATA[NP_ALWAYS_NULL]]></configKey>
-
-
   </rule>
+
   <rule key="NP_STORE_INTO_NONNULL_FIELD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Store of null value into field annotated NonNull]]></name>
     <configKey><![CDATA[NP_STORE_INTO_NONNULL_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="NP_ALWAYS_NULL_EXCEPTION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Null pointer dereference in method on exception path]]></name>
     <configKey><![CDATA[NP_ALWAYS_NULL_EXCEPTION]]></configKey>
-
-
   </rule>
+
   <rule key="NP_PARAMETER_MUST_BE_NONNULL_BUT_MARKED_AS_NULLABLE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Parameter must be nonnull but is marked as nullable]]></name>
     <configKey><![CDATA[NP_PARAMETER_MUST_BE_NONNULL_BUT_MARKED_AS_NULLABLE]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NULL_ON_SOME_PATH">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Possible null pointer dereference]]></name>
     <configKey><![CDATA[NP_NULL_ON_SOME_PATH]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NULL_ON_SOME_PATH_MIGHT_BE_INFEASIBLE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Possible null pointer dereference on path that might be infeasible]]></name>
     <configKey><![CDATA[NP_NULL_ON_SOME_PATH_MIGHT_BE_INFEASIBLE]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NULL_ON_SOME_PATH_EXCEPTION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Possible null pointer dereference in method on exception path]]></name>
     <configKey><![CDATA[NP_NULL_ON_SOME_PATH_EXCEPTION]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NULL_ON_SOME_PATH_FROM_RETURN_VALUE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Possible null pointer dereference due to return value of called method]]></name>
     <configKey><![CDATA[NP_NULL_ON_SOME_PATH_FROM_RETURN_VALUE]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NULL_PARAM_DEREF_NONVIRTUAL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Non-virtual method call passes null for nonnull parameter]]></name>
     <configKey><![CDATA[NP_NULL_PARAM_DEREF_NONVIRTUAL]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NULL_PARAM_DEREF_ALL_TARGETS_DANGEROUS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Method call passes null for nonnull parameter (ALL_TARGETS_DANGEROUS)]]></name>
     <configKey><![CDATA[NP_NULL_PARAM_DEREF_ALL_TARGETS_DANGEROUS]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NULL_PARAM_DEREF">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Method call passes null for nonnull parameter]]></name>
     <configKey><![CDATA[NP_NULL_PARAM_DEREF]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NONNULL_PARAM_VIOLATION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Method call passes null to a nonnull parameter ]]></name>
     <configKey><![CDATA[NP_NONNULL_PARAM_VIOLATION]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NONNULL_RETURN_VIOLATION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Method may return null, but is declared @NonNull]]></name>
     <configKey><![CDATA[NP_NONNULL_RETURN_VIOLATION]]></configKey>
-
-
   </rule>
+
   <rule key="NP_CLONE_COULD_RETURN_NULL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Clone method may return null]]></name>
     <configKey><![CDATA[NP_CLONE_COULD_RETURN_NULL]]></configKey>
-
-
   </rule>
+
   <rule key="NP_TOSTRING_COULD_RETURN_NULL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - toString method may return null]]></name>
     <configKey><![CDATA[NP_TOSTRING_COULD_RETURN_NULL]]></configKey>
-
-
   </rule>
+
   <rule key="NP_GUARANTEED_DEREF">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - Null value is guaranteed to be dereferenced]]></name>
     <configKey><![CDATA[NP_GUARANTEED_DEREF]]></configKey>
-
-
   </rule>
+
   <rule key="NP_GUARANTEED_DEREF_ON_EXCEPTION_PATH">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Value is null and guaranteed to be dereferenced on exception path]]></name>
     <configKey><![CDATA[NP_GUARANTEED_DEREF_ON_EXCEPTION_PATH]]></configKey>
-
-
   </rule>
+
   <rule key="SI_INSTANCE_BEFORE_FINALS_ASSIGNED">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Static initializer creates instance before all static final fields assigned]]></name>
     <configKey><![CDATA[SI_INSTANCE_BEFORE_FINALS_ASSIGNED]]></configKey>
-
-
   </rule>
+
   <rule key="OS_OPEN_STREAM">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Method may fail to close stream]]></name>
     <configKey><![CDATA[OS_OPEN_STREAM]]></configKey>
-
-
   </rule>
+
   <rule key="OS_OPEN_STREAM_EXCEPTION_PATH">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Method may fail to close stream on exception]]></name>
     <configKey><![CDATA[OS_OPEN_STREAM_EXCEPTION_PATH]]></configKey>
-
-
   </rule>
+
   <rule key="PZLA_PREFER_ZERO_LENGTH_ARRAYS">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Consider returning a zero length array rather than null]]></name>
     <configKey><![CDATA[PZLA_PREFER_ZERO_LENGTH_ARRAYS]]></configKey>
-
-
   </rule>
+
   <rule key="UCF_USELESS_CONTROL_FLOW">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Useless control flow]]></name>
-    <configKey><![CDATA[UCF_USELESS_CONTROL_FLOW]]></configKey>
-
-
+    <configKey><![CDATA[UCF_USELESS_CONTROL_FLOW]]></configKey>
   </rule>
+
   <rule key="UCF_USELESS_CONTROL_FLOW_NEXT_LINE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Useless control flow to next line]]></name>
     <configKey><![CDATA[UCF_USELESS_CONTROL_FLOW_NEXT_LINE]]></configKey>
-
-
   </rule>
+
   <rule key="RCN_REDUNDANT_NULLCHECK_WOULD_HAVE_BEEN_A_NPE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Nullcheck of value previously dereferenced]]></name>
     <configKey><![CDATA[RCN_REDUNDANT_NULLCHECK_WOULD_HAVE_BEEN_A_NPE]]></configKey>
-
-
   </rule>
+
   <rule key="RCN_REDUNDANT_NULLCHECK_OF_NULL_VALUE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Redundant nullcheck of value known to be null]]></name>
     <configKey><![CDATA[RCN_REDUNDANT_NULLCHECK_OF_NULL_VALUE]]></configKey>
-
-
   </rule>
+
   <rule key="RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Redundant nullcheck of value known to be non-null]]></name>
     <configKey><![CDATA[RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE]]></configKey>
-
-
   </rule>
+
   <rule key="RCN_REDUNDANT_COMPARISON_TWO_NULL_VALUES">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Redundant comparison of two null values]]></name>
     <configKey><![CDATA[RCN_REDUNDANT_COMPARISON_TWO_NULL_VALUES]]></configKey>
-
-
   </rule>
+
   <rule key="RCN_REDUNDANT_COMPARISON_OF_NULL_AND_NONNULL_VALUE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Redundant comparison of non-null value to null]]></name>
     <configKey><![CDATA[RCN_REDUNDANT_COMPARISON_OF_NULL_AND_NONNULL_VALUE]]></configKey>
-
-
   </rule>
+
   <rule key="UL_UNRELEASED_LOCK">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Method does not release lock on all paths]]></name>
     <configKey><![CDATA[UL_UNRELEASED_LOCK]]></configKey>
-
-
   </rule>
+
   <rule key="UL_UNRELEASED_LOCK_EXCEPTION_PATH">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Method does not release lock on all exception paths]]></name>
     <configKey><![CDATA[UL_UNRELEASED_LOCK_EXCEPTION_PATH]]></configKey>
-
-
   </rule>
+
   <rule key="RC_REF_COMPARISON">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Suspicious reference comparison]]></name>
     <configKey><![CDATA[RC_REF_COMPARISON]]></configKey>
-
-
   </rule>
+
   <rule key="EC_UNRELATED_TYPES_USING_POINTER_EQUALITY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Using pointer equality to compare different types]]></name>
     <configKey><![CDATA[EC_UNRELATED_TYPES_USING_POINTER_EQUALITY]]></configKey>
-
-
   </rule>
+
   <rule key="EC_UNRELATED_TYPES">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Call to equals() comparing different types]]></name>
     <configKey><![CDATA[EC_UNRELATED_TYPES]]></configKey>
-
-
   </rule>
+
   <rule key="EC_UNRELATED_INTERFACES">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Call to equals() comparing different interface types]]></name>
     <configKey><![CDATA[EC_UNRELATED_INTERFACES]]></configKey>
-
-
   </rule>
+
   <rule key="EC_UNRELATED_CLASS_AND_INTERFACE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Call to equals() comparing unrelated class and interface]]></name>
     <configKey><![CDATA[EC_UNRELATED_CLASS_AND_INTERFACE]]></configKey>
-
-
   </rule>
+
   <rule key="EC_NULL_ARG">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Call to equals() with null argument]]></name>
     <configKey><![CDATA[EC_NULL_ARG]]></configKey>
-
-
   </rule>
+
   <rule key="MWN_MISMATCHED_WAIT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Mismatched wait()]]></name>
     <configKey><![CDATA[MWN_MISMATCHED_WAIT]]></configKey>
-
-
   </rule>
+
   <rule key="MWN_MISMATCHED_NOTIFY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Mismatched notify()]]></name>
     <configKey><![CDATA[MWN_MISMATCHED_NOTIFY]]></configKey>
-
-
   </rule>
+
   <rule key="SA_LOCAL_SELF_ASSIGNMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Self assignment of local variable]]></name>
     <configKey><![CDATA[SA_LOCAL_SELF_ASSIGNMENT]]></configKey>
-
-
   </rule>
+
   <rule key="SA_FIELD_SELF_ASSIGNMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Self assignment of field]]></name>
     <configKey><![CDATA[SA_FIELD_SELF_ASSIGNMENT]]></configKey>
-
-
   </rule>
+
   <rule key="SA_FIELD_DOUBLE_ASSIGNMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Double assignment of field]]></name>
     <configKey><![CDATA[SA_FIELD_DOUBLE_ASSIGNMENT]]></configKey>
-
-
   </rule>
+
   <rule key="SA_LOCAL_DOUBLE_ASSIGNMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Double assignment of local variable ]]></name>
     <configKey><![CDATA[SA_LOCAL_DOUBLE_ASSIGNMENT]]></configKey>
-
-
   </rule>
+
   <rule key="SA_FIELD_SELF_COMPUTATION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Nonsensical self computation involving a field (e.g., x & x)]]></name>
     <configKey><![CDATA[SA_FIELD_SELF_COMPUTATION]]></configKey>
-
-
   </rule>
+
   <rule key="SA_LOCAL_SELF_COMPUTATION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Nonsensical self computation involving a variable (e.g., x & x)]]></name>
     <configKey><![CDATA[SA_LOCAL_SELF_COMPUTATION]]></configKey>
-
-
   </rule>
+
   <rule key="SA_FIELD_SELF_COMPARISON">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Self comparison of field with itself]]></name>
     <configKey><![CDATA[SA_FIELD_SELF_COMPARISON]]></configKey>
-
-
   </rule>
+
   <rule key="SA_LOCAL_SELF_COMPARISON">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Self comparison of value with itself]]></name>
     <configKey><![CDATA[SA_LOCAL_SELF_COMPARISON]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_LONG_BITS_TO_DOUBLE_INVOKED_ON_INT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Double.longBitsToDouble invoked on an int]]></name>
     <configKey><![CDATA[DMI_LONG_BITS_TO_DOUBLE_INVOKED_ON_INT]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_RANDOM_USED_ONLY_ONCE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Random object created and used only once]]></name>
     <configKey><![CDATA[DMI_RANDOM_USED_ONLY_ONCE]]></configKey>
-
-
   </rule>
+
   <rule key="RV_ABSOLUTE_VALUE_OF_RANDOM_INT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Bad attempt to compute absolute value of signed 32-bit random integer]]></name>
     <configKey><![CDATA[RV_ABSOLUTE_VALUE_OF_RANDOM_INT]]></configKey>
-
-
   </rule>
+
   <rule key="RV_ABSOLUTE_VALUE_OF_HASHCODE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Bad attempt to compute absolute value of signed 32-bit hashcode ]]></name>
     <configKey><![CDATA[RV_ABSOLUTE_VALUE_OF_HASHCODE]]></configKey>
-
-
   </rule>
+
   <rule key="RV_REM_OF_RANDOM_INT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Remainder of 32-bit signed random integer]]></name>
     <configKey><![CDATA[RV_REM_OF_RANDOM_INT]]></configKey>
-
-
   </rule>
+
   <rule key="RV_REM_OF_HASHCODE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Remainder of hashCode could be negative]]></name>
     <configKey><![CDATA[RV_REM_OF_HASHCODE]]></configKey>
-
-
   </rule>
+
   <rule key="INT_BAD_COMPARISON_WITH_NONNEGATIVE_VALUE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Bad comparison of nonnegative value with negative constant]]></name>
     <configKey><![CDATA[INT_BAD_COMPARISON_WITH_NONNEGATIVE_VALUE]]></configKey>
-
-
   </rule>
+
   <rule key="INT_BAD_COMPARISON_WITH_SIGNED_BYTE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Bad comparison of signed byte]]></name>
     <configKey><![CDATA[INT_BAD_COMPARISON_WITH_SIGNED_BYTE]]></configKey>
-
-
   </rule>
+
   <rule key="INT_VACUOUS_BIT_OPERATION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Vacuous bit mask operation on integer value]]></name>
     <configKey><![CDATA[INT_VACUOUS_BIT_OPERATION]]></configKey>
-
-
   </rule>
+
   <rule key="INT_VACUOUS_COMPARISON">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Vacuous comparison of integer value]]></name>
     <configKey><![CDATA[INT_VACUOUS_COMPARISON]]></configKey>
-
-
   </rule>
+
   <rule key="INT_BAD_REM_BY_1">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Integer remainder modulo 1]]></name>
     <configKey><![CDATA[INT_BAD_REM_BY_1]]></configKey>
-
-
   </rule>
+
   <rule key="BIT_IOR_OF_SIGNED_BYTE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Bitwise OR of signed byte value]]></name>
     <configKey><![CDATA[BIT_IOR_OF_SIGNED_BYTE]]></configKey>
-
-
   </rule>
+
   <rule key="BIT_ADD_OF_SIGNED_BYTE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Bitwise add of signed byte value]]></name>
     <configKey><![CDATA[BIT_ADD_OF_SIGNED_BYTE]]></configKey>
-
-
   </rule>
+
   <rule key="BIT_AND">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Incompatible bit masks (BIT_AND)]]></name>
     <configKey><![CDATA[BIT_AND]]></configKey>
-
-
   </rule>
+
   <rule key="BIT_SIGNED_CHECK">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Check for sign of bitwise operation]]></name>
     <configKey><![CDATA[BIT_SIGNED_CHECK]]></configKey>
-
-
   </rule>
+
   <rule key="BIT_SIGNED_CHECK_HIGH_BIT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Check for sign of bitwise operation]]></name>
     <configKey><![CDATA[BIT_SIGNED_CHECK_HIGH_BIT]]></configKey>
-
-
   </rule>
+
   <rule key="BIT_AND_ZZ">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Check to see if ((...) & 0) == 0]]></name>
     <configKey><![CDATA[BIT_AND_ZZ]]></configKey>
-
-
   </rule>
+
   <rule key="BIT_IOR">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Incompatible bit masks (BIT_IOR)]]></name>
     <configKey><![CDATA[BIT_IOR]]></configKey>
-
-
   </rule>
+
   <rule key="LI_LAZY_INIT_STATIC">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Incorrect lazy initialization of static field]]></name>
     <configKey><![CDATA[LI_LAZY_INIT_STATIC]]></configKey>
-
-
   </rule>
+
   <rule key="LI_LAZY_INIT_UPDATE_STATIC">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Incorrect lazy initialization and update of static field]]></name>
     <configKey><![CDATA[LI_LAZY_INIT_UPDATE_STATIC]]></configKey>
-
-
   </rule>
+
   <rule key="JLM_JSR166_LOCK_MONITORENTER">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Synchronization performed on java.util.concurrent Lock]]></name>
     <configKey><![CDATA[JLM_JSR166_LOCK_MONITORENTER]]></configKey>
-
-
   </rule>
+
   <rule key="UPM_UNCALLED_PRIVATE_METHOD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Performance - Private method is never called]]></name>
     <configKey><![CDATA[UPM_UNCALLED_PRIVATE_METHOD]]></configKey>
-
-
   </rule>
+
   <rule key="UMAC_UNCALLABLE_METHOD_OF_ANONYMOUS_CLASS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Uncallable method defined in anonymous class]]></name>
     <configKey><![CDATA[UMAC_UNCALLABLE_METHOD_OF_ANONYMOUS_CLASS]]></configKey>
-
-
   </rule>
+
   <rule key="ODR_OPEN_DATABASE_RESOURCE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Method may fail to close database resource]]></name>
     <configKey><![CDATA[ODR_OPEN_DATABASE_RESOURCE]]></configKey>
-
-
   </rule>
+
   <rule key="ODR_OPEN_DATABASE_RESOURCE_EXCEPTION_PATH">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Method may fail to close database resource on exception]]></name>
     <configKey><![CDATA[ODR_OPEN_DATABASE_RESOURCE_EXCEPTION_PATH]]></configKey>
-
-
   </rule>
+
   <rule key="SBSC_USE_STRINGBUFFER_CONCATENATION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Performance - Method concatenates strings using + in a loop]]></name>
     <configKey><![CDATA[SBSC_USE_STRINGBUFFER_CONCATENATION]]></configKey>
-
-
   </rule>
+
   <rule key="ITA_INEFFICIENT_TO_ARRAY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Performance - Method uses toArray() with zero-length array argument]]></name>
     <configKey><![CDATA[ITA_INEFFICIENT_TO_ARRAY]]></configKey>
-
-
   </rule>
+
   <rule key="IJU_ASSERT_METHOD_INVOKED_FROM_RUN_METHOD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - JUnit assertion in run method will not be noticed by JUnit]]></name>
     <configKey><![CDATA[IJU_ASSERT_METHOD_INVOKED_FROM_RUN_METHOD]]></configKey>
-
-
   </rule>
+
   <rule key="IJU_SETUP_NO_SUPER">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - TestCase defines setUp that doesn't call super.setUp()]]></name>
     <configKey><![CDATA[IJU_SETUP_NO_SUPER]]></configKey>
-
-
   </rule>
+
   <rule key="IJU_TEARDOWN_NO_SUPER">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - TestCase defines tearDown that doesn't call super.tearDown()]]></name>
     <configKey><![CDATA[IJU_TEARDOWN_NO_SUPER]]></configKey>
-
-
   </rule>
+
   <rule key="IJU_SUITE_NOT_STATIC">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - TestCase implements a non-static suite method ]]></name>
     <configKey><![CDATA[IJU_SUITE_NOT_STATIC]]></configKey>
-
-
   </rule>
+
   <rule key="IJU_BAD_SUITE_METHOD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - TestCase declares a bad suite method ]]></name>
     <configKey><![CDATA[IJU_BAD_SUITE_METHOD]]></configKey>
-
-
   </rule>
+
   <rule key="IJU_NO_TESTS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - TestCase has no tests]]></name>
     <configKey><![CDATA[IJU_NO_TESTS]]></configKey>
-
-
   </rule>
+
   <rule key="BOA_BADLY_OVERRIDDEN_ADAPTER">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Class overrides a method implemented in super class Adapter wrongly]]></name>
     <configKey><![CDATA[BOA_BADLY_OVERRIDDEN_ADAPTER]]></configKey>
-
-
   </rule>
+
   <rule key="SQL_BAD_RESULTSET_ACCESS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Method attempts to access a result set field with index 0]]></name>
     <configKey><![CDATA[SQL_BAD_RESULTSET_ACCESS]]></configKey>
-
-
   </rule>
+
   <rule key="SQL_BAD_PREPARED_STATEMENT_ACCESS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Method attempts to access a prepared statement parameter with index 0]]></name>
     <configKey><![CDATA[SQL_BAD_PREPARED_STATEMENT_ACCESS]]></configKey>
-
-
   </rule>
+
   <rule key="SIO_SUPERFLUOUS_INSTANCEOF">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Unnecessary type check done using instanceof operator]]></name>
     <configKey><![CDATA[SIO_SUPERFLUOUS_INSTANCEOF]]></configKey>
-
-
   </rule>
+
   <rule key="EC_ARRAY_AND_NONARRAY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - equals() used to compare array and nonarray]]></name>
     <configKey><![CDATA[EC_ARRAY_AND_NONARRAY]]></configKey>
-
-
   </rule>
+
   <rule key="EC_BAD_ARRAY_COMPARE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Invocation of equals() on an array, which is equivalent to ==]]></name>
     <configKey><![CDATA[EC_BAD_ARRAY_COMPARE]]></configKey>
-
-
   </rule>
+
   <rule key="STI_INTERRUPTED_ON_CURRENTTHREAD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Unneeded use of currentThread() call, to call interrupted() ]]></name>
     <configKey><![CDATA[STI_INTERRUPTED_ON_CURRENTTHREAD]]></configKey>
-
-
   </rule>
+
   <rule key="STI_INTERRUPTED_ON_UNKNOWNTHREAD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Static Thread.interrupted() method invoked on thread instance]]></name>
     <configKey><![CDATA[STI_INTERRUPTED_ON_UNKNOWNTHREAD]]></configKey>
-
-
   </rule>
+
   <rule key="IP_PARAMETER_IS_DEAD_BUT_OVERWRITTEN">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - A parameter is dead upon entry to a method but overwritten]]></name>
     <configKey><![CDATA[IP_PARAMETER_IS_DEAD_BUT_OVERWRITTEN]]></configKey>
-
-
   </rule>
+
   <rule key="DLS_DEAD_LOCAL_STORE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Dead store to local variable]]></name>
     <configKey><![CDATA[DLS_DEAD_LOCAL_STORE]]></configKey>
-
-
   </rule>
+
   <rule key="DLS_DEAD_LOCAL_STORE_IN_RETURN">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Useless assignment in return statement]]></name>
     <configKey><![CDATA[DLS_DEAD_LOCAL_STORE_IN_RETURN]]></configKey>
-
-
   </rule>
+
   <rule key="DLS_DEAD_STORE_OF_CLASS_LITERAL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Dead store of class literal]]></name>
     <configKey><![CDATA[DLS_DEAD_STORE_OF_CLASS_LITERAL]]></configKey>
-
-
   </rule>
+
   <rule key="DLS_DEAD_LOCAL_STORE_OF_NULL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Dead store of null to local variable]]></name>
     <configKey><![CDATA[DLS_DEAD_LOCAL_STORE_OF_NULL]]></configKey>
-
-
   </rule>
+
   <rule key="MF_METHOD_MASKS_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Method defines a variable that obscures a field]]></name>
     <configKey><![CDATA[MF_METHOD_MASKS_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="MF_CLASS_MASKS_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Class defines field that masks a superclass field]]></name>
     <configKey><![CDATA[MF_CLASS_MASKS_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="WMI_WRONG_MAP_ITERATOR">
     <priority>CRITICAL</priority>
     <name><![CDATA[Performance - Inefficient use of keySet iterator instead of entrySet iterator]]></name>
     <configKey><![CDATA[WMI_WRONG_MAP_ITERATOR]]></configKey>
-
-
   </rule>
+
   <rule key="ISC_INSTANTIATE_STATIC_CLASS">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad practice - Needless instantiation of class that only supplies static methods]]></name>
     <configKey><![CDATA[ISC_INSTANTIATE_STATIC_CLASS]]></configKey>
-
-
   </rule>
+
   <rule key="REC_CATCH_EXCEPTION">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Exception is caught when Exception is not thrown]]></name>
     <configKey><![CDATA[REC_CATCH_EXCEPTION]]></configKey>
-
-
   </rule>
+
   <rule key="FE_TEST_IF_EQUAL_TO_NOT_A_NUMBER">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Doomed test for equality to NaN]]></name>
     <configKey><![CDATA[FE_TEST_IF_EQUAL_TO_NOT_A_NUMBER]]></configKey>
-
-
   </rule>
+
   <rule key="FE_FLOATING_POINT_EQUALITY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Test for floating point equality]]></name>
     <configKey><![CDATA[FE_FLOATING_POINT_EQUALITY]]></configKey>
-
-
   </rule>
+
   <rule key="UM_UNNECESSARY_MATH">
     <priority>CRITICAL</priority>
     <name><![CDATA[Performance - Method calls static Math class method on a constant value]]></name>
     <configKey><![CDATA[UM_UNNECESSARY_MATH]]></configKey>
-
-
   </rule>
+
   <rule key="RI_REDUNDANT_INTERFACES">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Class implements same interface as superclass]]></name>
     <configKey><![CDATA[RI_REDUNDANT_INTERFACES]]></configKey>
-
-
   </rule>
+
   <rule key="MTIA_SUSPECT_STRUTS_INSTANCE_FIELD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Class extends Struts Action class and uses instance variables]]></name>
     <configKey><![CDATA[MTIA_SUSPECT_STRUTS_INSTANCE_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="MTIA_SUSPECT_SERVLET_INSTANCE_FIELD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Class extends Servlet class and uses instance variables]]></name>
     <configKey><![CDATA[MTIA_SUSPECT_SERVLET_INSTANCE_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="PS_PUBLIC_SEMAPHORES">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Class exposes synchronization and semaphores in its public interface]]></name>
     <configKey><![CDATA[PS_PUBLIC_SEMAPHORES]]></configKey>
-
-
   </rule>
+
   <rule key="ICAST_INTEGER_MULTIPLY_CAST_TO_LONG">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Result of integer multiplication cast to long]]></name>
     <configKey><![CDATA[ICAST_INTEGER_MULTIPLY_CAST_TO_LONG]]></configKey>
-
-
   </rule>
+
   <rule key="ICAST_INT_CAST_TO_FLOAT_PASSED_TO_ROUND">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - int value cast to float and then passed to Math.round]]></name>
     <configKey><![CDATA[ICAST_INT_CAST_TO_FLOAT_PASSED_TO_ROUND]]></configKey>
-
-
   </rule>
+
   <rule key="ICAST_INT_CAST_TO_DOUBLE_PASSED_TO_CEIL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - int value cast to double and then passed to Math.ceil]]></name>
     <configKey><![CDATA[ICAST_INT_CAST_TO_DOUBLE_PASSED_TO_CEIL]]></configKey>
-
-
   </rule>
+
   <rule key="ICAST_IDIV_CAST_TO_DOUBLE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - int division result cast to double or float]]></name>
     <configKey><![CDATA[ICAST_IDIV_CAST_TO_DOUBLE]]></configKey>
-
-
   </rule>
+
   <rule key="J2EE_STORE_OF_NON_SERIALIZABLE_OBJECT_INTO_SESSION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Store of non serializable object into HttpSession]]></name>
     <configKey><![CDATA[J2EE_STORE_OF_NON_SERIALIZABLE_OBJECT_INTO_SESSION]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_NONSERIALIZABLE_OBJECT_WRITTEN">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Non serializable object written to ObjectOutput]]></name>
     <configKey><![CDATA[DMI_NONSERIALIZABLE_OBJECT_WRITTEN]]></configKey>
-
-
   </rule>
+
   <rule key="VA_FORMAT_STRING_NO_PREVIOUS_ARGUMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - No previous argument for format string]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_NO_PREVIOUS_ARGUMENT]]></configKey>
-
-
   </rule>
+
   <rule key="VA_FORMAT_STRING_BAD_CONVERSION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - The type of a supplied argument doesn't match format specifier]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_BAD_CONVERSION]]></configKey>
-
-
   </rule>
+
   <rule key="VA_FORMAT_STRING_BAD_CONVERSION_TO_BOOLEAN">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Non-Boolean argument formatted using %b format specifier]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_BAD_CONVERSION_TO_BOOLEAN]]></configKey>
-
-
   </rule>
+
   <rule key="VA_FORMAT_STRING_BAD_CONVERSION_FROM_ARRAY">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - Array formatted in useless way using format string]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_BAD_CONVERSION_FROM_ARRAY]]></configKey>
-
-
   </rule>
+
   <rule key="VA_FORMAT_STRING_ARG_MISMATCH">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Correctness - Number of format-string arguments does not correspond to number of placeholders]]></name>
+    <name><![CDATA[Correctness - Number of format-string arguments does not correspond to number of placeholders]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_ARG_MISMATCH]]></configKey>
-
-
   </rule>
+
   <rule key="VA_FORMAT_STRING_EXTRA_ARGUMENTS_PASSED">
     <priority>MAJOR</priority>
     <name><![CDATA[Correctness - More arguments are passed that are actually used in the format string]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_EXTRA_ARGUMENTS_PASSED]]></configKey>
-
-
   </rule>
+
   <rule key="VA_FORMAT_STRING_ILLEGAL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Illegal format string]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_ILLEGAL]]></configKey>
-
-
   </rule>
+
   <rule key="VA_FORMAT_STRING_MISSING_ARGUMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Format string references missing argument]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_MISSING_ARGUMENT]]></configKey>
-
-
   </rule>
+
   <rule key="VA_FORMAT_STRING_BAD_ARGUMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Format string placeholder incompatible with passed argument]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_BAD_ARGUMENT]]></configKey>
-
-
   </rule>
+
   <rule key="VA_PRIMITIVE_ARRAY_PASSED_TO_OBJECT_VARARG">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Correctness - Primitive array passed to function expecting a variable number of object arguments]]></name>
+    <name><![CDATA[Correctness - Primitive array passed to function expecting a variable number of object arguments]]></name>
     <configKey><![CDATA[VA_PRIMITIVE_ARRAY_PASSED_TO_OBJECT_VARARG]]></configKey>
-
-
   </rule>
+
   <rule key="BC_EQUALS_METHOD_SHOULD_WORK_FOR_ALL_OBJECTS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Equals method should not assume anything about the type of its argument]]></name>
     <configKey><![CDATA[BC_EQUALS_METHOD_SHOULD_WORK_FOR_ALL_OBJECTS]]></configKey>
-
-
   </rule>
+
   <rule key="BC_BAD_CAST_TO_ABSTRACT_COLLECTION">
     <priority>MAJOR</priority>
     <name><![CDATA[Dodgy - Questionable cast to abstract collection ]]></name>
     <configKey><![CDATA[BC_BAD_CAST_TO_ABSTRACT_COLLECTION]]></configKey>
-
-
   </rule>
+
   <rule key="BC_IMPOSSIBLE_CAST">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - Impossible cast]]></name>
     <configKey><![CDATA[BC_IMPOSSIBLE_CAST]]></configKey>
-
-
   </rule>
+
   <rule key="NP_NULL_INSTANCEOF">
     <priority>BLOCKER</priority>
     <name><![CDATA[Correctness - A known null value is checked to see if it is an instance of a type]]></name>
     <configKey><![CDATA[NP_NULL_INSTANCEOF]]></configKey>
-
-
   </rule>
+
   <rule key="BC_IMPOSSIBLE_INSTANCEOF">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - instanceof will always return false]]></name>
     <configKey><![CDATA[BC_IMPOSSIBLE_INSTANCEOF]]></configKey>
-
-
   </rule>
+
   <rule key="BC_VACUOUS_INSTANCEOF">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - instanceof will always return true]]></name>
     <configKey><![CDATA[BC_VACUOUS_INSTANCEOF]]></configKey>
-
-
   </rule>
+
   <rule key="BC_UNCONFIRMED_CAST">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Unchecked/unconfirmed cast]]></name>
     <configKey><![CDATA[BC_UNCONFIRMED_CAST]]></configKey>
-
-
   </rule>
+
   <rule key="BC_BAD_CAST_TO_CONCRETE_COLLECTION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Questionable cast to concrete collection]]></name>
     <configKey><![CDATA[BC_BAD_CAST_TO_CONCRETE_COLLECTION]]></configKey>
-
-
   </rule>
+
   <rule key="RE_POSSIBLE_UNINTENDED_PATTERN">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - "." used for regular expression]]></name>
     <configKey><![CDATA[RE_POSSIBLE_UNINTENDED_PATTERN]]></configKey>
-
-
   </rule>
+
   <rule key="RE_BAD_SYNTAX_FOR_REGULAR_EXPRESSION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Invalid syntax for regular expression]]></name>
     <configKey><![CDATA[RE_BAD_SYNTAX_FOR_REGULAR_EXPRESSION]]></configKey>
-
-
   </rule>
+
   <rule key="RE_CANT_USE_FILE_SEPARATOR_AS_REGULAR_EXPRESSION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - File.separator used for regular expression]]></name>
     <configKey><![CDATA[RE_CANT_USE_FILE_SEPARATOR_AS_REGULAR_EXPRESSION]]></configKey>
-
-
   </rule>
+
   <rule key="DLS_OVERWRITTEN_INCREMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Overwritten increment]]></name>
     <configKey><![CDATA[DLS_OVERWRITTEN_INCREMENT]]></configKey>
-
-
   </rule>
+
   <rule key="ICAST_QUESTIONABLE_UNSIGNED_RIGHT_SHIFT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Unsigned right shift cast to short/byte]]></name>
     <configKey><![CDATA[ICAST_QUESTIONABLE_UNSIGNED_RIGHT_SHIFT]]></configKey>
-
-
   </rule>
+
   <rule key="ICAST_BAD_SHIFT_AMOUNT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Integer shift by an amount not in the range 0..31]]></name>
     <configKey><![CDATA[ICAST_BAD_SHIFT_AMOUNT]]></configKey>
-
-
   </rule>
+
   <rule key="IM_MULTIPLYING_RESULT_OF_IREM">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Integer multiply of result of integer remainder]]></name>
     <configKey><![CDATA[IM_MULTIPLYING_RESULT_OF_IREM]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_INVOKING_HASHCODE_ON_ARRAY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Invocation of hashCode on an array]]></name>
     <configKey><![CDATA[DMI_INVOKING_HASHCODE_ON_ARRAY]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_INVOKING_TOSTRING_ON_ARRAY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Invocation of toString on an array]]></name>
     <configKey><![CDATA[DMI_INVOKING_TOSTRING_ON_ARRAY]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_INVOKING_TOSTRING_ON_ANONYMOUS_ARRAY">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Invocation of toString on an anonymous array]]></name>
     <configKey><![CDATA[DMI_INVOKING_TOSTRING_ON_ANONYMOUS_ARRAY]]></configKey>
-
-
   </rule>
+
   <rule key="IM_AVERAGE_COMPUTATION_COULD_OVERFLOW">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Computation of average could overflow]]></name>
     <configKey><![CDATA[IM_AVERAGE_COMPUTATION_COULD_OVERFLOW]]></configKey>
-
-
   </rule>
+
   <rule key="IM_BAD_CHECK_FOR_ODD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Check for oddness that won't work for negative numbers ]]></name>
     <configKey><![CDATA[IM_BAD_CHECK_FOR_ODD]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_HARDCODED_ABSOLUTE_FILENAME">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Code contains a hard coded reference to an absolute pathname]]></name>
     <configKey><![CDATA[DMI_HARDCODED_ABSOLUTE_FILENAME]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_BAD_MONTH">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Bad constant value for month]]></name>
     <configKey><![CDATA[DMI_BAD_MONTH]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_USELESS_SUBSTRING">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Invocation of substring(0), which returns the original value]]></name>
     <configKey><![CDATA[DMI_USELESS_SUBSTRING]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_CALLING_NEXT_FROM_HASNEXT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - hasNext method invokes next]]></name>
     <configKey><![CDATA[DMI_CALLING_NEXT_FROM_HASNEXT]]></configKey>
-
-
   </rule>
+
   <rule key="SWL_SLEEP_WITH_LOCK_HELD">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Method calls Thread.sleep() with a lock held]]></name>
     <configKey><![CDATA[SWL_SLEEP_WITH_LOCK_HELD]]></configKey>
-
-
   </rule>
+
   <rule key="DB_DUPLICATE_BRANCHES">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Method uses the same code for two branches]]></name>
     <configKey><![CDATA[DB_DUPLICATE_BRANCHES]]></configKey>
-
-
   </rule>
+
   <rule key="DB_DUPLICATE_SWITCH_CLAUSES">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Method uses the same code for two switch clauses]]></name>
     <configKey><![CDATA[DB_DUPLICATE_SWITCH_CLAUSES]]></configKey>
-
-
   </rule>
+
   <rule key="XFB_XML_FACTORY_BYPASS">
     <priority>CRITICAL</priority>
     <name><![CDATA[Dodgy - Method directly allocates a specific implementation of xml interfaces]]></name>
     <configKey><![CDATA[XFB_XML_FACTORY_BYPASS]]></configKey>
-
-
   </rule>
+
   <rule key="CI_CONFUSED_INHERITANCE">
     <priority>MINOR</priority>
     <name><![CDATA[Dodgy - Class is final but declares protected field]]></name>
     <configKey><![CDATA[CI_CONFUSED_INHERITANCE]]></configKey>
-
-
   </rule>
+
   <rule key="QBA_QUESTIONABLE_BOOLEAN_ASSIGNMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Method assigns boolean literal in boolean expression]]></name>
     <configKey><![CDATA[QBA_QUESTIONABLE_BOOLEAN_ASSIGNMENT]]></configKey>
-
-
   </rule>
+
   <rule key="GC_UNCHECKED_TYPE_IN_GENERIC_CALL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Bad practice - Unchecked type in generic call]]></name>
     <configKey><![CDATA[GC_UNCHECKED_TYPE_IN_GENERIC_CALL]]></configKey>
-
-
   </rule>
+
   <rule key="GC_UNRELATED_TYPES">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - No relationship between generic parameter and method argument]]></name>
     <configKey><![CDATA[GC_UNRELATED_TYPES]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_COLLECTIONS_SHOULD_NOT_CONTAIN_THEMSELVES">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Collections should not contain themselves]]></name>
     <configKey><![CDATA[DMI_COLLECTIONS_SHOULD_NOT_CONTAIN_THEMSELVES]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_VACUOUS_SELF_COLLECTION_CALL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Vacuous call to collections]]></name>
     <configKey><![CDATA[DMI_VACUOUS_SELF_COLLECTION_CALL]]></configKey>
-
-
   </rule>
+
   <rule key="DMI_USING_REMOVEALL_TO_CLEAR_COLLECTION">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Don't use removeAll to clear a collection]]></name>
     <configKey><![CDATA[DMI_USING_REMOVEALL_TO_CLEAR_COLLECTION]]></configKey>
-
-
   </rule>
+
   <rule key="STCAL_STATIC_CALENDAR_INSTANCE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Static Calendar]]></name>
     <configKey><![CDATA[STCAL_STATIC_CALENDAR_INSTANCE]]></configKey>
-
-
   </rule>
+
   <rule key="STCAL_INVOKE_ON_STATIC_CALENDAR_INSTANCE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Call to static Calendar]]></name>
     <configKey><![CDATA[STCAL_INVOKE_ON_STATIC_CALENDAR_INSTANCE]]></configKey>
-
-
   </rule>
+
   <rule key="STCAL_STATIC_SIMPLE_DATE_FORMAT_INSTANCE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Static DateFormat]]></name>
     <configKey><![CDATA[STCAL_STATIC_SIMPLE_DATE_FORMAT_INSTANCE]]></configKey>
-
-
   </rule>
+
   <rule key="STCAL_INVOKE_ON_STATIC_DATE_FORMAT_INSTANCE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Call to static DateFormat]]></name>
     <configKey><![CDATA[STCAL_INVOKE_ON_STATIC_DATE_FORMAT_INSTANCE]]></configKey>
-
-
   </rule>
+
   <rule key="TQ_ALWAYS_VALUE_USED_WHERE_NEVER_REQUIRED">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Correctness - Value annotated as carrying a type qualifier used where a value that must not carry that qualifier is required]]></name>
+    <name><![CDATA[Correctness - Value annotated as carrying a type qualifier used where a value that must not carry that qualifier is required]]></name>
     <configKey><![CDATA[TQ_ALWAYS_VALUE_USED_WHERE_NEVER_REQUIRED]]></configKey>
-
-
   </rule>
+
   <rule key="TQ_NEVER_VALUE_USED_WHERE_ALWAYS_REQUIRED">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Correctness - Value annotated as never carrying a type qualifier used where value carrying that qualifier is required]]></name>
+    <name><![CDATA[Correctness - Value annotated as never carrying a type qualifier used where value carrying that qualifier is required]]></name>
     <configKey><![CDATA[TQ_NEVER_VALUE_USED_WHERE_ALWAYS_REQUIRED]]></configKey>
-
-
   </rule>
+
   <rule key="TQ_MAYBE_SOURCE_VALUE_REACHES_ALWAYS_SINK">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Correctness - Value that might not carry a type qualifier is always used in a way requires that type qualifier]]></name>
+    <name><![CDATA[Correctness - Value that might not carry a type qualifier is always used in a way requires that type qualifier]]></name>
     <configKey><![CDATA[TQ_MAYBE_SOURCE_VALUE_REACHES_ALWAYS_SINK]]></configKey>
-
-
   </rule>
+
   <rule key="TQ_MAYBE_SOURCE_VALUE_REACHES_NEVER_SINK">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Correctness - Value that might carry a type qualifier is always used in a way prohibits it from having that type qualifier]]></name>
+    <name><![CDATA[Correctness - Value that might carry a type qualifier is always used in a way prohibits it from having that type qualifier]]></name>
     <configKey><![CDATA[TQ_MAYBE_SOURCE_VALUE_REACHES_NEVER_SINK]]></configKey>
-
-
   </rule>
+
   <rule key="TQ_EXPLICIT_UNKNOWN_SOURCE_VALUE_REACHES_NEVER_SINK">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness -  Value required to not have type qualifier, but marked as unknown]]></name>
     <configKey><![CDATA[TQ_EXPLICIT_UNKNOWN_SOURCE_VALUE_REACHES_NEVER_SINK]]></configKey>
-
-
   </rule>
+
   <rule key="TQ_EXPLICIT_UNKNOWN_SOURCE_VALUE_REACHES_ALWAYS_SINK">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Value required to have type qualifier, but marked as unknown]]></name>
     <configKey><![CDATA[TQ_EXPLICIT_UNKNOWN_SOURCE_VALUE_REACHES_ALWAYS_SINK]]></configKey>
-
-
   </rule>
+
   <rule key="IO_APPENDING_TO_OBJECT_OUTPUT_STREAM">
     <priority>CRITICAL</priority>
     <name><![CDATA[Correctness - Doomed attempt to append to an object output stream]]></name>
     <configKey><![CDATA[IO_APPENDING_TO_OBJECT_OUTPUT_STREAM]]></configKey>
-
-
   </rule>
+
   <rule key="WL_USING_GETCLASS_RATHER_THAN_CLASS_LITERAL">
     <priority>CRITICAL</priority>
     <name><![CDATA[Multithreaded correctness - Sychronization on getClass rather than class literal]]></name>
     <configKey><![CDATA[WL_USING_GETCLASS_RATHER_THAN_CLASS_LITERAL]]></configKey>
-
-
   </rule>
+
   <rule key="SF_SWITCH_FALLTHROUGH">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Switch statement found where one case falls through to the next case]]></name>
+    <name><![CDATA[Switch statement found where one case falls through to the next case]]></name>
     <configKey><![CDATA[SF_SWITCH_FALLTHROUGH]]></configKey>
-
-
   </rule>
+
   <rule key="SF_SWITCH_NO_DEFAULT">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Switch statement found where default case is missing]]></name>
+    <name><![CDATA[Switch statement found where default case is missing]]></name>
     <configKey><![CDATA[SF_SWITCH_NO_DEFAULT]]></configKey>
-
-
   </rule>
+
   <rule key="SF_DEAD_STORE_DUE_TO_SWITCH_FALLTHROUGH">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Dead store due to switch statement fall through]]></name>
+    <name><![CDATA[Dead store due to switch statement fall through]]></name>
     <configKey><![CDATA[SF_DEAD_STORE_DUE_TO_SWITCH_FALLTHROUGH]]></configKey>
-
-
   </rule>
+
   <rule key="SF_DEAD_STORE_DUE_TO_SWITCH_FALLTHROUGH_TO_THROW">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Dead store due to switch statement fall through to throw]]></name>
+    <name><![CDATA[Dead store due to switch statement fall through to throw]]></name>
     <configKey><![CDATA[SF_DEAD_STORE_DUE_TO_SWITCH_FALLTHROUGH_TO_THROW]]></configKey>
-
-
   </rule>
+
   <rule key="NM_CLASS_NAMING_CONVENTION">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Class names should start with an upper case letter]]></name>
+    <name><![CDATA[Class names should start with an upper case letter]]></name>
     <configKey><![CDATA[NM_CLASS_NAMING_CONVENTION]]></configKey>
-
-
   </rule>
+
   <rule key="NM_FIELD_NAMING_CONVENTION">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Field names should start with a lower case letter]]></name>
+    <name><![CDATA[Field names should start with a lower case letter]]></name>
     <configKey><![CDATA[NM_FIELD_NAMING_CONVENTION]]></configKey>
-
-
   </rule>
+
   <rule key="NM_METHOD_NAMING_CONVENTION">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Method names should start with a lower case letter]]></name>
+    <name><![CDATA[Method names should start with a lower case letter]]></name>
     <configKey><![CDATA[NM_METHOD_NAMING_CONVENTION]]></configKey>
-
-
   </rule>
+
   <rule key="SE_BAD_FIELD">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Non-transient non-serializable instance field in serializable class]]></name>
+    <name><![CDATA[Non-transient non-serializable instance field in serializable class]]></name>
     <configKey><![CDATA[SE_BAD_FIELD]]></configKey>
-
-
   </rule>
+
   <rule key="NM_BAD_EQUAL">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Class defines equal(Object); should it be equals(Object)?]]></name>
+    <name><![CDATA[Class defines equal(Object); should it be equals(Object)?]]></name>
     <configKey><![CDATA[NM_BAD_EQUAL]]></configKey>
-
-
   </rule>
+
   <rule key="NM_LCASE_HASHCODE">
     <priority>CRITICAL</priority>
-    <name>
-      <![CDATA[Class defines hashcode(); should it be hashCode()?]]></name>
+    <name><![CDATA[Class defines hashcode(); should it be hashCode()?]]></name>
     <configKey><![CDATA[NM_LCASE_HASHCODE]]></configKey>
-
-
   </rule>
+
   <rule key="NM_LCASE_TOSTRING">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Class defines tostring(); should it be toString()?]]></name>
+    <name><![CDATA[Class defines tostring(); should it be toString()?]]></name>
     <configKey><![CDATA[NM_LCASE_TOSTRING]]></configKey>
-
-
   </rule>
+
   <rule key="NM_LCASE_TOSTRING">
     <priority>MAJOR</priority>
-    <name>
-      <![CDATA[Class defines tostring(); should it be toString()?]]></name>
+    <name><![CDATA[Class defines tostring(); should it be toString()?]]></name>
     <configKey><![CDATA[NM_LCASE_TOSTRING]]></configKey>
-
-
   </rule>
 
   <rule key="BAC_BAD_APPLET_CONSTRUCTOR">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Bad Applet Constructor relies on uninitialized AppletStub]]></name>
     <configKey><![CDATA[BAC_BAD_APPLET_CONSTRUCTOR]]></configKey>
-
   </rule>
 
   <rule key="UOE_USE_OBJECT_EQUALS">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Calls to equals on a final class that doesn't override Object's equals method]]></name>
     <configKey><![CDATA[UOE_USE_OBJECT_EQUALS]]></configKey>
-
   </rule>
 
   <rule key="CD_CIRCULAR_DEPENDENCY">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Test for circular dependencies among classes]]></name>
     <configKey><![CDATA[CD_CIRCULAR_DEPENDENCY]]></configKey>
-
   </rule>
 
   <rule key="IMA_INEFFICIENT_MEMBER_ACCESS">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Method accesses a private member variable of owning class]]></name>
     <configKey><![CDATA[IMA_INEFFICIENT_MEMBER_ACCESS]]></configKey>
-
   </rule>
 
   <rule key="USM_USELESS_SUBCLASS_METHOD">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Method superfluously delegates to parent class method]]></name>
     <configKey><![CDATA[USM_USELESS_SUBCLASS_METHOD]]></configKey>
-
   </rule>
 
   <rule key="USM_USELESS_ABSTRACT_METHOD">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Abstract Method is already defined in implemented interface]]></name>
     <configKey><![CDATA[USM_USELESS_ABSTRACT_METHOD]]></configKey>
-
   </rule>
 
   <rule key="OBL_UNSATISFIED_OBLIGATION">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Method may fail to clean up stream or resource]]></name>
     <configKey><![CDATA[OBL_UNSATISFIED_OBLIGATION]]></configKey>
-
   </rule>
 
   <rule key="FB_UNEXPECTED_WARNING">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Unexpected/undesired warning from FindBugs]]></name>
     <configKey><![CDATA[FB_UNEXPECTED_WARNING]]></configKey>
-
   </rule>
 
   <rule key="FB_MISSING_EXPECTED_WARNING">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Missing expected or desired warning from FindBugs]]></name>
     <configKey><![CDATA[FB_MISSING_EXPECTED_WARNING]]></configKey>
-
   </rule>
 
   <rule key="LG_LOST_LOGGER_DUE_TO_WEAK_REFERENCE">
     <priority>INFO</priority>
     <name><![CDATA[Experimental - Potential lost logger changes due to weak reference in OpenJDK]]></name>
     <configKey><![CDATA[LG_LOST_LOGGER_DUE_TO_WEAK_REFERENCE]]></configKey>
-
   </rule>
 
   <rule key="AT_OPERATION_SEQUENCE_ON_CONCURRENT_ABSTRACTION">
     <priority>MAJOR</priority>
     <name><![CDATA[Sequence of calls to concurrent abstraction may not be atomic]]></name>
     <configKey><![CDATA[AT_OPERATION_SEQUENCE_ON_CONCURRENT_ABSTRACTION]]></configKey>
-
   </rule>
 
   <rule key="BX_UNBOXING_IMMEDIATELY_REBOXED">
     <priority>MAJOR</priority>
     <name><![CDATA[Boxed value is unboxed and then immediately reboxed]]></name>
     <configKey><![CDATA[BX_UNBOXING_IMMEDIATELY_REBOXED]]></configKey>
-
   </rule>
 
   <rule key="CO_COMPARETO_RESULTS_MIN_VALUE">
     <priority>MAJOR</priority>
     <name><![CDATA[compareTo()/compare() returns Integer.MIN_VALUE]]></name>
     <configKey><![CDATA[CO_COMPARETO_RESULTS_MIN_VALUE]]></configKey>
-
   </rule>
 
   <rule key="DLS_DEAD_LOCAL_STORE_SHADOWS_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Dead store to local variable that shadows field]]></name>
     <configKey><![CDATA[DLS_DEAD_LOCAL_STORE_SHADOWS_FIELD]]></configKey>
-
   </rule>
 
   <rule key="DMI_ARGUMENTS_WRONG_ORDER">
     <priority>MINOR</priority>
     <name><![CDATA[Reversed method arguments]]></name>
     <configKey><![CDATA[DMI_ARGUMENTS_WRONG_ORDER]]></configKey>
-
   </rule>
 
   <rule key="DMI_BIGDECIMAL_CONSTRUCTED_FROM_DOUBLE">
     <priority>MAJOR</priority>
     <name><![CDATA[BigDecimal constructed from double that isn't represented precisely]]></name>
     <configKey><![CDATA[DMI_BIGDECIMAL_CONSTRUCTED_FROM_DOUBLE]]></configKey>
-
   </rule>
 
   <rule key="DMI_DOH">
     <priority>MAJOR</priority>
     <name><![CDATA[D'oh! A nonsensical method invocation]]></name>
     <configKey><![CDATA[DMI_DOH]]></configKey>
-
   </rule>
 
   <rule key="DMI_ENTRY_SETS_MAY_REUSE_ENTRY_OBJECTS">
     <priority>MAJOR</priority>
     <name><![CDATA[Adding elements of an entry set may fail due to reuse of Entry objects]]></name>
     <configKey><![CDATA[DMI_ENTRY_SETS_MAY_REUSE_ENTRY_OBJECTS]]></configKey>
-
   </rule>
 
   <rule key="DM_DEFAULT_ENCODING">
     <priority>MAJOR</priority>
     <name><![CDATA[Reliance on default encoding]]></name>
     <configKey><![CDATA[DM_DEFAULT_ENCODING]]></configKey>
-
   </rule>
 
   <rule key="ICAST_INT_2_LONG_AS_INSTANT">
     <priority>MAJOR</priority>
     <name><![CDATA[int value converted to long and used as absolute time]]></name>
     <configKey><![CDATA[ICAST_INT_2_LONG_AS_INSTANT]]></configKey>
-
   </rule>
 
   <rule key="INT_BAD_COMPARISON_WITH_INT_VALUE">
     <priority>MAJOR</priority>
     <name><![CDATA[Bad comparison of int value with long constant]]></name>
     <configKey><![CDATA[INT_BAD_COMPARISON_WITH_INT_VALUE]]></configKey>
-
   </rule>
 
   <rule key="JML_JSR166_CALLING_WAIT_RATHER_THAN_AWAIT">
     <priority>MAJOR</priority>
     <name><![CDATA[Using monitor style wait methods on util.concurrent abstraction]]></name>
     <configKey><![CDATA[JML_JSR166_CALLING_WAIT_RATHER_THAN_AWAIT]]></configKey>
-
   </rule>
 
   <rule key="NP_UNWRITTEN_PUBLIC_OR_PROTECTED_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Read of unwritten public or protected field]]></name>
     <configKey><![CDATA[NP_UNWRITTEN_PUBLIC_OR_PROTECTED_FIELD]]></configKey>
-
   </rule>
 
   <rule key="OBL_UNSATISFIED_OBLIGATION_EXCEPTION_EDGE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Method may fail to clean up stream or resource on checked exception]]></name>
     <configKey><![CDATA[OBL_UNSATISFIED_OBLIGATION_EXCEPTION_EDGE]]></configKey>
-
   </rule>
 
   <rule key="PZ_DONT_REUSE_ENTRY_OBJECTS_IN_ITERATORS">
     <priority>MAJOR</priority>
     <name><![CDATA[Don't reuse entry objects in iterators]]></name>
     <configKey><![CDATA[PZ_DONT_REUSE_ENTRY_OBJECTS_IN_ITERATORS]]></configKey>
-
   </rule>
 
   <rule key="RV_CHECK_COMPARETO_FOR_SPECIFIC_RETURN_VALUE">
     <priority>MAJOR</priority>
     <name><![CDATA[Code checks for specific values returned by compareTo]]></name>
     <configKey><![CDATA[RV_CHECK_COMPARETO_FOR_SPECIFIC_RETURN_VALUE]]></configKey>
-
   </rule>
 
   <rule key="RV_NEGATING_RESULT_OF_COMPARETO">
     <priority>MINOR</priority>
     <name><![CDATA[Negating the result of compareTo()/compare()]]></name>
     <configKey><![CDATA[RV_NEGATING_RESULT_OF_COMPARETO]]></configKey>
-
   </rule>
 
   <rule key="RV_RETURN_VALUE_IGNORED_INFERRED">
     <priority>MINOR</priority>
     <name><![CDATA[Method ignores return value, is this OK?]]></name>
     <configKey><![CDATA[RV_RETURN_VALUE_IGNORED_INFERRED]]></configKey>
-
   </rule>
 
   <rule key="SA_LOCAL_SELF_ASSIGNMENT_INSTEAD_OF_FIELD">
     <priority>MAJOR</priority>
     <name><![CDATA[Self assignment of local rather than assignment to field]]></name>
     <configKey><![CDATA[SA_LOCAL_SELF_ASSIGNMENT_INSTEAD_OF_FIELD]]></configKey>
-
   </rule>
 
   <rule key="URF_UNREAD_PUBLIC_OR_PROTECTED_FIELD">
     <priority>INFO</priority>
     <name><![CDATA[Unread public/protected field]]></name>
     <configKey><![CDATA[URF_UNREAD_PUBLIC_OR_PROTECTED_FIELD]]></configKey>
-
   </rule>
 
   <rule key="UUF_UNUSED_PUBLIC_OR_PROTECTED_FIELD">
     <priority>INFO</priority>
     <name><![CDATA[Unused public or protected field]]></name>
     <configKey><![CDATA[UUF_UNUSED_PUBLIC_OR_PROTECTED_FIELD]]></configKey>
-
   </rule>
 
   <rule key="UWF_UNWRITTEN_PUBLIC_OR_PROTECTED_FIELD">
     <priority>MINOR</priority>
     <name><![CDATA[Unwritten public or protected field]]></name>
     <configKey><![CDATA[UWF_UNWRITTEN_PUBLIC_OR_PROTECTED_FIELD]]></configKey>
-
   </rule>
 
   <rule key="VA_FORMAT_STRING_USES_NEWLINE">
     <priority>MAJOR</priority>
     <name><![CDATA[Format string should use %n rather than \n]]></name>
     <configKey><![CDATA[VA_FORMAT_STRING_USES_NEWLINE]]></configKey>
-
   </rule>
 
   <rule key="VO_VOLATILE_INCREMENT">
     <priority>CRITICAL</priority>
     <name><![CDATA[An increment to a volatile field isn't atomic]]></name>
     <configKey><![CDATA[VO_VOLATILE_INCREMENT]]></configKey>
-
   </rule>
 
   <rule key="PT_ABSOLUTE_PATH_TRAVERSAL">
     <priority>MAJOR</priority>
     <name><![CDATA[Absolute path traversal in servlet]]></name>
     <configKey><![CDATA[PT_ABSOLUTE_PATH_TRAVERSAL]]></configKey>
-
   </rule>
 
   <rule key="PT_RELATIVE_PATH_TRAVERSAL">
     <priority>MAJOR</priority>
     <name><![CDATA[Relative path traversal in servlet]]></name>
     <configKey><![CDATA[PT_RELATIVE_PATH_TRAVERSAL]]></configKey>
-
   </rule>
 
   <rule key="NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR">
     <priority>CRITICAL</priority>
     <name><![CDATA[Nonnull field is not initialized]]></name>
     <configKey><![CDATA[NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR]]></configKey>
-
   </rule>
 
   <rule key="MS_SHOULD_BE_REFACTORED_TO_BE_FINAL">
     <priority>MAJOR</priority>
     <name><![CDATA[Field isn't final but should be refactored to be so]]></name>
     <configKey><![CDATA[MS_SHOULD_BE_REFACTORED_TO_BE_FINAL]]></configKey>
-
   </rule>
 
   <rule key="BC_UNCONFIRMED_CAST_OF_RETURN_VALUE">
     <priority>CRITICAL</priority>
     <name><![CDATA[Unchecked/unconfirmed cast of return value from method]]></name>
     <configKey><![CDATA[BC_UNCONFIRMED_CAST_OF_RETURN_VALUE]]></configKey>
-
   </rule>
 
   <rule key="TQ_COMPARING_VALUES_WITH_INCOMPATIBLE_TYPE_QUALIFIERS">
     <priority>MAJOR</priority>
     <name><![CDATA[Comparing values with incompatible type qualifiers]]></name>
     <configKey><![CDATA[TQ_COMPARING_VALUES_WITH_INCOMPATIBLE_TYPE_QUALIFIERS]]></configKey>
-
   </rule>
 
 </rules>