{
  "_class" : "io.jenkins.plugins.analysis.core.restapi.ReportApi",
  "issues" : [
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "CollaborationAwareMessageBusAdapter.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Actors/src/main/java/it/tidalwave/actor/impl/CollaborationAwareMessageBusAdapter.java",
      "fingerprint" : "d2d09f575203d58ca6dc11a97fe1ab2f",
      "lineEnd" : 138,
      "lineStart" : 138,
      "message" : "it.tidalwave.actor.impl.CollaborationAwareMessageBusAdapter.registerCollaborationListener(Method) uses the same code for two branches",
      "moduleName" : "TheseFoolishThings :: Actors",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.actor.impl",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "CollaborationAwareMessageBusAdapter.java(138,0): DB_DUPLICATE_BRANCHES: STYLE: it.tidalwave.actor.impl.CollaborationAwareMessageBusAdapter.registerCollaborationListener(Method) uses the same code for two branches",
      "type" : "DB_DUPLICATE_BRANCHES"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "ExecutorWithPriority.java",
      "category" : "PERFORMANCE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Actors/src/main/java/it/tidalwave/actor/impl/ExecutorWithPriority.java",
      "fingerprint" : "47f5fabdcbbf82f7cbc1e7f1edd28992",
      "lineEnd" : 73,
      "lineStart" : 73,
      "message" : "The class it.tidalwave.actor.impl.ExecutorWithPriority$2 could be refactored into a named _static_ inner class",
      "moduleName" : "TheseFoolishThings :: Actors",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.actor.impl",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "ExecutorWithPriority.java(73,0): SIC_INNER_SHOULD_BE_STATIC_ANON: PERFORMANCE: The class it.tidalwave.actor.impl.ExecutorWithPriority$2 could be refactored into a named _static_ inner class",
      "type" : "SIC_INNER_SHOULD_BE_STATIC_ANON"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "ExecutorWithPriority.java",
      "category" : "PERFORMANCE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Actors/src/main/java/it/tidalwave/actor/impl/ExecutorWithPriority.java",
      "fingerprint" : "37846ee1c653c72d8b3a8140d78fb389",
      "lineEnd" : 106,
      "lineStart" : 106,
      "message" : "The class it.tidalwave.actor.impl.ExecutorWithPriority$3 could be refactored into a named _static_ inner class",
      "moduleName" : "TheseFoolishThings :: Actors",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.actor.impl",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "ExecutorWithPriority.java(106,0): SIC_INNER_SHOULD_BE_STATIC_ANON: PERFORMANCE: The class it.tidalwave.actor.impl.ExecutorWithPriority$3 could be refactored into a named _static_ inner class",
      "type" : "SIC_INNER_SHOULD_BE_STATIC_ANON"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "MessageBusAdapterFactory.java",
      "category" : "MALICIOUS_CODE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringMessageBus/src/main/java/it/tidalwave/messagebus/impl/spring/MessageBusAdapterFactory.java",
      "fingerprint" : "913a23124b07942dd9e763261ca3fc84",
      "lineEnd" : 74,
      "lineStart" : 74,
      "message" : "Invocation of reflect.Method.setAccessible(boolean), which should be invoked from within a doPrivileged block, in new it.tidalwave.messagebus.impl.spring.MessageBusAdapterFactory$MessageBusListenerAdapter(MessageBusAdapterFactory, Object, Method, Class)",
      "moduleName" : "TheseFoolishThings :: MessageBus :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.messagebus.impl.spring",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "MessageBusAdapterFactory.java(74,0): DP_DO_INSIDE_DO_PRIVILEGED: MALICIOUS_CODE: Invocation of reflect.Method.setAccessible(boolean), which should be invoked from within a doPrivileged block, in new it.tidalwave.messagebus.impl.spring.MessageBusAdapterFactory$MessageBusListenerAdapter(MessageBusAdapterFactory, Object, Method, Class)",
      "type" : "DP_DO_INSIDE_DO_PRIVILEGED"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SpringSimpleMessageSubscriberAspect.aj",
      "category" : "MALICIOUS_CODE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "it/tidalwave/messagebus/impl/spring/SpringSimpleMessageSubscriberAspect.aj",
      "fingerprint" : "945c612de87a60bfe1c843d80952bb10",
      "lineEnd" : 0,
      "lineStart" : 0,
      "message" : "it.tidalwave.messagebus.impl.spring.SpringSimpleMessageSubscriberAspect.ajc$perSingletonInstance isn't final but should be",
      "moduleName" : "TheseFoolishThings :: MessageBus :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.messagebus.impl.spring",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "SpringSimpleMessageSubscriberAspect.aj(0,0): MS_SHOULD_BE_FINAL: MALICIOUS_CODE: it.tidalwave.messagebus.impl.spring.SpringSimpleMessageSubscriberAspect.ajc$perSingletonInstance isn't final but should be",
      "type" : "MS_SHOULD_BE_FINAL"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SpringSimpleMessageSubscriberSupport.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringMessageBus/src/main/java/it/tidalwave/messagebus/impl/spring/SpringSimpleMessageSubscriberSupport.java",
      "fingerprint" : "c0ed73ccf8503779c71bf94acc367a9a",
      "lineEnd" : 55,
      "lineStart" : 51,
      "message" : "Non-null field beanFactory is not initialized by new it.tidalwave.messagebus.impl.spring.SpringSimpleMessageSubscriberSupport(Object)",
      "moduleName" : "TheseFoolishThings :: MessageBus :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.messagebus.impl.spring",
      "reference" : "247",
      "severity" : "NORMAL",
      "toString" : "SpringSimpleMessageSubscriberSupport.java(51,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field beanFactory is not initialized by new it.tidalwave.messagebus.impl.spring.SpringSimpleMessageSubscriberSupport(Object)",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SpringSimpleMessageSubscriberSupport.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringMessageBus/src/main/java/it/tidalwave/messagebus/impl/spring/SpringSimpleMessageSubscriberSupport.java",
      "fingerprint" : "688c861135187c1691e2fbed36b21fb5",
      "lineEnd" : 51,
      "lineStart" : 51,
      "message" : "Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.messagebus.impl.spring.SpringSimpleMessageSubscriberSupport(Object)",
      "moduleName" : "TheseFoolishThings :: MessageBus :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.messagebus.impl.spring",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "SpringSimpleMessageSubscriberSupport.java(51,0): RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE: STYLE: Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.messagebus.impl.spring.SpringSimpleMessageSubscriberSupport(Object)",
      "type" : "RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "RoundRobinAsyncMessageDelivery.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/MessageBus/src/main/java/it/tidalwave/messagebus/spi/RoundRobinAsyncMessageDelivery.java",
      "fingerprint" : "953ef9ecc082ff2a51996f531d2a8022",
      "lineEnd" : 61,
      "lineStart" : 47,
      "message" : "Non-null field messageBusSupport is not initialized by new it.tidalwave.messagebus.spi.RoundRobinAsyncMessageDelivery()",
      "moduleName" : "TheseFoolishThings :: MessageBus",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.messagebus.spi",
      "reference" : "245",
      "severity" : "NORMAL",
      "toString" : "RoundRobinAsyncMessageDelivery.java(47,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field messageBusSupport is not initialized by new it.tidalwave.messagebus.spi.RoundRobinAsyncMessageDelivery()",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SimpleAsyncMessageDelivery.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/MessageBus/src/main/java/it/tidalwave/messagebus/spi/SimpleAsyncMessageDelivery.java",
      "fingerprint" : "53040b7c3286dd4fc80dba9037472571",
      "lineEnd" : 42,
      "lineStart" : 42,
      "message" : "Non-null field messageBusSupport is not initialized by new it.tidalwave.messagebus.spi.SimpleAsyncMessageDelivery()",
      "moduleName" : "TheseFoolishThings :: MessageBus",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.messagebus.spi",
      "reference" : "245",
      "severity" : "NORMAL",
      "toString" : "SimpleAsyncMessageDelivery.java(42,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field messageBusSupport is not initialized by new it.tidalwave.messagebus.spi.SimpleAsyncMessageDelivery()",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SimpleMessageBus.java",
      "category" : "BAD_PRACTICE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/MessageBus/src/main/java/it/tidalwave/messagebus/spi/SimpleMessageBus.java",
      "fingerprint" : "dedc8406d099b7891eac4112cb475dfa",
      "lineEnd" : 163,
      "lineStart" : 163,
      "message" : "Adding elements of an entry set may fail due to reuse of Map.Entry object in it.tidalwave.messagebus.spi.SimpleMessageBus.dispatchMessage(Class, Object)",
      "moduleName" : "TheseFoolishThings :: MessageBus",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.messagebus.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "SimpleMessageBus.java(163,0): DMI_ENTRY_SETS_MAY_REUSE_ENTRY_OBJECTS: BAD_PRACTICE: Adding elements of an entry set may fail due to reuse of Map.Entry object in it.tidalwave.messagebus.spi.SimpleMessageBus.dispatchMessage(Class, Object)",
      "type" : "DMI_ENTRY_SETS_MAY_REUSE_ENTRY_OBJECTS"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "AsExtensionsBean.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/AsExtensionsBean.java",
      "fingerprint" : "85c95610871f56a489ed45cc878e4603",
      "lineEnd" : 43,
      "lineStart" : 43,
      "message" : "Non-null field roleManager is not initialized by new it.tidalwave.role.AsExtensionsBean()",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role",
      "reference" : "247",
      "severity" : "NORMAL",
      "toString" : "AsExtensionsBean.java(43,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field roleManager is not initialized by new it.tidalwave.role.AsExtensionsBean()",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "AsExtensionsBean.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/AsExtensionsBean.java",
      "fingerprint" : "def6b28b82301bd1734fbe86d9bfd7c8",
      "lineEnd" : 43,
      "lineStart" : 43,
      "message" : "Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.role.AsExtensionsBean()",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "AsExtensionsBean.java(43,0): RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE: STYLE: Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.role.AsExtensionsBean()",
      "type" : "RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "AnnotationSpringRoleManager.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/spring/spi/AnnotationSpringRoleManager.java",
      "fingerprint" : "5d08c3edb7d5acac184e168e21adb0ba",
      "lineEnd" : 57,
      "lineStart" : 55,
      "message" : "Non-null field beanFactory is not initialized by new it.tidalwave.role.spring.spi.AnnotationSpringRoleManager()",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spring.spi",
      "reference" : "247",
      "severity" : "NORMAL",
      "toString" : "AnnotationSpringRoleManager.java(55,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field beanFactory is not initialized by new it.tidalwave.role.spring.spi.AnnotationSpringRoleManager()",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DciContextWithAutoThreadBindingAspect.java",
      "category" : "MALICIOUS_CODE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/spring/spi/DciContextWithAutoThreadBindingAspect.java",
      "fingerprint" : "8221265e527a9496b701f4e3820e171",
      "lineEnd" : 0,
      "lineStart" : 0,
      "message" : "it.tidalwave.role.spring.spi.DciContextWithAutoThreadBindingAspect.ajc$perSingletonInstance isn't final but should be",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spring.spi",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "DciContextWithAutoThreadBindingAspect.java(0,0): MS_SHOULD_BE_FINAL: MALICIOUS_CODE: it.tidalwave.role.spring.spi.DciContextWithAutoThreadBindingAspect.ajc$perSingletonInstance isn't final but should be",
      "type" : "MS_SHOULD_BE_FINAL"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DciContextWithAutoThreadBindingAspect.java",
      "category" : "PERFORMANCE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/spring/spi/DciContextWithAutoThreadBindingAspect.java",
      "fingerprint" : "28d49b7dd74014600bc6b0c1c2d7abc2",
      "lineEnd" : 71,
      "lineStart" : 71,
      "message" : "The class it.tidalwave.role.spring.spi.DciContextWithAutoThreadBindingAspect$1 could be refactored into a named _static_ inner class",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spring.spi",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "DciContextWithAutoThreadBindingAspect.java(71,0): SIC_INNER_SHOULD_BE_STATIC_ANON: PERFORMANCE: The class it.tidalwave.role.spring.spi.DciContextWithAutoThreadBindingAspect$1 could be refactored into a named _static_ inner class",
      "type" : "SIC_INNER_SHOULD_BE_STATIC_ANON"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SpringAsDelegate.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/spring/spi/SpringAsDelegate.java",
      "fingerprint" : "3740f1e0b77f6200eb32775dff2a613b",
      "lineEnd" : 70,
      "lineStart" : 67,
      "message" : "Non-null field roleManager is not initialized by new it.tidalwave.role.spring.spi.SpringAsDelegate()",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spring.spi",
      "reference" : "247",
      "severity" : "NORMAL",
      "toString" : "SpringAsDelegate.java(67,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field roleManager is not initialized by new it.tidalwave.role.spring.spi.SpringAsDelegate()",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SpringAsDelegate.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/spring/spi/SpringAsDelegate.java",
      "fingerprint" : "999379a6711ab178c7d6aecca2d7daa8",
      "lineEnd" : 83,
      "lineStart" : 80,
      "message" : "Non-null field roleManager is not initialized by new it.tidalwave.role.spring.spi.SpringAsDelegate(Object)",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spring.spi",
      "reference" : "247",
      "severity" : "NORMAL",
      "toString" : "SpringAsDelegate.java(80,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field roleManager is not initialized by new it.tidalwave.role.spring.spi.SpringAsDelegate(Object)",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SpringAsDelegate.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/spring/spi/SpringAsDelegate.java",
      "fingerprint" : "f5a8c91a215190cd69936adfe6d74777",
      "lineEnd" : 67,
      "lineStart" : 67,
      "message" : "Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.role.spring.spi.SpringAsDelegate()",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spring.spi",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "SpringAsDelegate.java(67,0): RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE: STYLE: Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.role.spring.spi.SpringAsDelegate()",
      "type" : "RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SpringAsDelegate.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/spring/spi/SpringAsDelegate.java",
      "fingerprint" : "5bf9eb10bc301b988cac93b49d1bfcad",
      "lineEnd" : 80,
      "lineStart" : 80,
      "message" : "Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.role.spring.spi.SpringAsDelegate(Object)",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spring.spi",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "SpringAsDelegate.java(80,0): RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE: STYLE: Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.role.spring.spi.SpringAsDelegate(Object)",
      "type" : "RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SpringContextManagerProvider.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/spring/spi/SpringContextManagerProvider.java",
      "fingerprint" : "fae4785cd5e065d58537474965973c35",
      "lineEnd" : 43,
      "lineStart" : 43,
      "message" : "Non-null field contextManager is not initialized by new it.tidalwave.role.spring.spi.SpringContextManagerProvider()",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spring.spi",
      "reference" : "247",
      "severity" : "NORMAL",
      "toString" : "SpringContextManagerProvider.java(43,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field contextManager is not initialized by new it.tidalwave.role.spring.spi.SpringContextManagerProvider()",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SpringContextManagerProvider.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/SpringRoles/src/main/java/it/tidalwave/role/spring/spi/SpringContextManagerProvider.java",
      "fingerprint" : "f9caa10f3602ce123bf38bbe83f97fa1",
      "lineEnd" : 43,
      "lineStart" : 43,
      "message" : "Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.role.spring.spi.SpringContextManagerProvider()",
      "moduleName" : "TheseFoolishThings :: Roles :: Spring",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spring.spi",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "SpringContextManagerProvider.java(43,0): RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE: STYLE: Redundant nullcheck of this, which is known to be non-null in new it.tidalwave.role.spring.spi.SpringContextManagerProvider()",
      "type" : "RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "FileTextReadable.java",
      "category" : "I18N",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Roles/src/main/java/it/tidalwave/role/io/spi/FileTextReadable.java",
      "fingerprint" : "d1c95eb8480a65f032bc119bf235227e",
      "lineEnd" : 60,
      "lineStart" : 60,
      "message" : "Found reliance on default encoding in it.tidalwave.role.io.spi.FileTextReadable.openReader(): new java.io.FileReader(File)",
      "moduleName" : "TheseFoolishThings :: Roles",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.io.spi",
      "reference" : "252",
      "severity" : "LOW",
      "toString" : "FileTextReadable.java(60,0): DM_DEFAULT_ENCODING: I18N: Found reliance on default encoding in it.tidalwave.role.io.spi.FileTextReadable.openReader(): new java.io.FileReader(File)",
      "type" : "DM_DEFAULT_ENCODING"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "FileTextWritable.java",
      "category" : "I18N",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Roles/src/main/java/it/tidalwave/role/io/spi/FileTextWritable.java",
      "fingerprint" : "826714ff1b299e900223b463d50993d6",
      "lineEnd" : 60,
      "lineStart" : 60,
      "message" : "Found reliance on default encoding in it.tidalwave.role.io.spi.FileTextWritable.openWriter(): new java.io.FileWriter(File)",
      "moduleName" : "TheseFoolishThings :: Roles",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.io.spi",
      "reference" : "252",
      "severity" : "LOW",
      "toString" : "FileTextWritable.java(60,0): DM_DEFAULT_ENCODING: I18N: Found reliance on default encoding in it.tidalwave.role.io.spi.FileTextWritable.openWriter(): new java.io.FileWriter(File)",
      "type" : "DM_DEFAULT_ENCODING"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultContextManager.java",
      "category" : "PERFORMANCE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Roles/src/main/java/it/tidalwave/role/spi/DefaultContextManager.java",
      "fingerprint" : "f35375e36ab9953bfabfabc0dc61b737",
      "lineEnd" : 56,
      "lineStart" : 56,
      "message" : "The class it.tidalwave.role.spi.DefaultContextManager$1 could be refactored into a named _static_ inner class",
      "moduleName" : "TheseFoolishThings :: Roles",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spi",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "DefaultContextManager.java(56,0): SIC_INNER_SHOULD_BE_STATIC_ANON: PERFORMANCE: The class it.tidalwave.role.spi.DefaultContextManager$1 could be refactored into a named _static_ inner class",
      "type" : "SIC_INNER_SHOULD_BE_STATIC_ANON"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultContextManager.java",
      "category" : "PERFORMANCE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Roles/src/main/java/it/tidalwave/role/spi/DefaultContextManager.java",
      "fingerprint" : "f8c0aad6fce8f899424c809655c08d7b",
      "lineEnd" : 224,
      "lineStart" : 224,
      "message" : "The class it.tidalwave.role.spi.DefaultContextManager$2 could be refactored into a named _static_ inner class",
      "moduleName" : "TheseFoolishThings :: Roles",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spi",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "DefaultContextManager.java(224,0): SIC_INNER_SHOULD_BE_STATIC_ANON: PERFORMANCE: The class it.tidalwave.role.spi.DefaultContextManager$2 could be refactored into a named _static_ inner class",
      "type" : "SIC_INNER_SHOULD_BE_STATIC_ANON"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultContextManager.java",
      "category" : "PERFORMANCE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Roles/src/main/java/it/tidalwave/role/spi/DefaultContextManager.java",
      "fingerprint" : "7e5f5f12b5882452914ebfe4b0a4ed61",
      "lineEnd" : 242,
      "lineStart" : 242,
      "message" : "The class it.tidalwave.role.spi.DefaultContextManager$3 could be refactored into a named _static_ inner class",
      "moduleName" : "TheseFoolishThings :: Roles",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.spi",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "DefaultContextManager.java(242,0): SIC_INNER_SHOULD_BE_STATIC_ANON: PERFORMANCE: The class it.tidalwave.role.spi.DefaultContextManager$3 could be refactored into a named _static_ inner class",
      "type" : "SIC_INNER_SHOULD_BE_STATIC_ANON"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "WeakCopyFunctionSupport.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Roles/src/main/java/it/tidalwave/role/ui/function/WeakCopyFunctionSupport.java",
      "fingerprint" : "a652e9a29a77fcd074d7d6d0e2f671ff",
      "lineEnd" : 50,
      "lineStart" : 49,
      "message" : "Non-null field targetValue is not initialized by new it.tidalwave.role.ui.function.WeakCopyFunctionSupport(ChangingSource)",
      "moduleName" : "TheseFoolishThings :: Roles",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.ui.function",
      "reference" : "247",
      "severity" : "NORMAL",
      "toString" : "WeakCopyFunctionSupport.java(49,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field targetValue is not initialized by new it.tidalwave.role.ui.function.WeakCopyFunctionSupport(ChangingSource)",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "AsDisplayableComparator.java",
      "category" : "BAD_PRACTICE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Roles/src/main/java/it/tidalwave/role/ui/impl/AsDisplayableComparator.java",
      "fingerprint" : "d674a5e33451f39c0618fc9b4a182322",
      "lineEnd" : 59,
      "lineStart" : 44,
      "message" : "it.tidalwave.role.ui.impl.AsDisplayableComparator implements Comparator but not Serializable",
      "moduleName" : "TheseFoolishThings :: Roles",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.ui.impl",
      "reference" : "257",
      "severity" : "LOW",
      "toString" : "AsDisplayableComparator.java(44,0): SE_COMPARATOR_SHOULD_BE_SERIALIZABLE: BAD_PRACTICE: it.tidalwave.role.ui.impl.AsDisplayableComparator implements Comparator but not Serializable",
      "type" : "SE_COMPARATOR_SHOULD_BE_SERIALIZABLE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultPresentationModel.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Roles/src/main/java/it/tidalwave/role/ui/impl/DefaultPresentationModel.java",
      "fingerprint" : "73879f688c67255db4df498ae18fc450",
      "lineEnd" : 109,
      "lineStart" : 109,
      "message" : "Redundant nullcheck of role, which is known to be non-null in it.tidalwave.role.ui.impl.DefaultPresentationModel$1.run(Throwable)",
      "moduleName" : "TheseFoolishThings :: Roles",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.ui.impl",
      "reference" : "252",
      "severity" : "LOW",
      "toString" : "DefaultPresentationModel.java(109,0): RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE: STYLE: Redundant nullcheck of role, which is known to be non-null in it.tidalwave.role.ui.impl.DefaultPresentationModel$1.run(Throwable)",
      "type" : "RCN_REDUNDANT_NULLCHECK_OF_NONNULL_VALUE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DisplayableComparator.java",
      "category" : "BAD_PRACTICE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Roles/src/main/java/it/tidalwave/role/ui/impl/DisplayableComparator.java",
      "fingerprint" : "61f04bbab317a730ab8369e0800d2a3",
      "lineEnd" : 58,
      "lineStart" : 43,
      "message" : "it.tidalwave.role.ui.impl.DisplayableComparator implements Comparator but not Serializable",
      "moduleName" : "TheseFoolishThings :: Roles",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.role.ui.impl",
      "reference" : "257",
      "severity" : "LOW",
      "toString" : "DisplayableComparator.java(43,0): SE_COMPARATOR_SHOULD_BE_SERIALIZABLE: BAD_PRACTICE: it.tidalwave.role.ui.impl.DisplayableComparator implements Comparator but not Serializable",
      "type" : "SE_COMPARATOR_SHOULD_BE_SERIALIZABLE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "AsDelegateProvider.java",
      "category" : "PERFORMANCE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/AsDelegateProvider.java",
      "fingerprint" : "799a0da694fd7b76d6611cda5e02b026",
      "lineEnd" : 141,
      "lineStart" : 141,
      "message" : "The class it.tidalwave.util.spi.AsDelegateProvider$EmptyAsDelegateProvider$1 could be refactored into a named _static_ inner class",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "263",
      "severity" : "LOW",
      "toString" : "AsDelegateProvider.java(141,0): SIC_INNER_SHOULD_BE_STATIC_ANON: PERFORMANCE: The class it.tidalwave.util.spi.AsDelegateProvider$EmptyAsDelegateProvider$1 could be refactored into a named _static_ inner class",
      "type" : "SIC_INNER_SHOULD_BE_STATIC_ANON"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultProcessExecutor.java",
      "category" : "I18N",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/DefaultProcessExecutor.java",
      "fingerprint" : "22a61a349131452fc20a230179a88cee",
      "lineEnd" : 485,
      "lineStart" : 485,
      "message" : "Use of non-localized String.toUpperCase() or String.toLowerCase() in it.tidalwave.util.spi.DefaultProcessExecutor.isWindows()",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "DefaultProcessExecutor.java(485,0): DM_CONVERT_CASE: I18N: Use of non-localized String.toUpperCase() or String.toLowerCase() in it.tidalwave.util.spi.DefaultProcessExecutor.isWindows()",
      "type" : "DM_CONVERT_CASE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultProcessExecutor.java",
      "category" : "I18N",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/DefaultProcessExecutor.java",
      "fingerprint" : "546fcec2f3fc51e896f3a93765e3b9a9",
      "lineEnd" : 430,
      "lineStart" : 430,
      "message" : "Found reliance on default encoding in it.tidalwave.util.spi.DefaultProcessExecutor.start(): new java.io.PrintWriter(OutputStream, boolean)",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "DefaultProcessExecutor.java(430,0): DM_DEFAULT_ENCODING: I18N: Found reliance on default encoding in it.tidalwave.util.spi.DefaultProcessExecutor.start(): new java.io.PrintWriter(OutputStream, boolean)",
      "type" : "DM_DEFAULT_ENCODING"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultProcessExecutor.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/DefaultProcessExecutor.java",
      "fingerprint" : "cf72bf19c353afd0d889c0f512a33b98",
      "lineEnd" : 457,
      "lineStart" : 457,
      "message" : "Useless control flow in it.tidalwave.util.spi.DefaultProcessExecutor.waitForCompletion()",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "DefaultProcessExecutor.java(457,0): UCF_USELESS_CONTROL_FLOW: STYLE: Useless control flow in it.tidalwave.util.spi.DefaultProcessExecutor.waitForCompletion()",
      "type" : "UCF_USELESS_CONTROL_FLOW"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultProcessExecutor.java",
      "category" : "I18N",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/DefaultProcessExecutor.java",
      "fingerprint" : "282979a34723be2e2509ea3ef5ab71c6",
      "lineEnd" : 282,
      "lineStart" : 282,
      "message" : "Found reliance on default encoding in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read(): new java.io.InputStreamReader(InputStream)",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "DefaultProcessExecutor.java(282,0): DM_DEFAULT_ENCODING: I18N: Found reliance on default encoding in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read(): new java.io.InputStreamReader(InputStream)",
      "type" : "DM_DEFAULT_ENCODING"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultProcessExecutor.java",
      "category" : "MT_CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/DefaultProcessExecutor.java",
      "fingerprint" : "a4ff01756de9ea4b0bf187d6935c6579",
      "lineEnd" : 321,
      "lineStart" : 321,
      "message" : "Naked notify in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read()",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "DefaultProcessExecutor.java(321,0): NN_NAKED_NOTIFY: MT_CORRECTNESS: Naked notify in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read()",
      "type" : "NN_NAKED_NOTIFY"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultProcessExecutor.java",
      "category" : "BAD_PRACTICE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/DefaultProcessExecutor.java",
      "fingerprint" : "f53c819baaf66f7ccd0135a0b88105ee",
      "lineEnd" : 160,
      "lineStart" : 160,
      "message" : "Exceptional return value of java.util.concurrent.ExecutorService.submit(Runnable) ignored in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.start()",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "DefaultProcessExecutor.java(160,0): RV_RETURN_VALUE_IGNORED_BAD_PRACTICE: BAD_PRACTICE: Exceptional return value of java.util.concurrent.ExecutorService.submit(Runnable) ignored in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.start()",
      "type" : "RV_RETURN_VALUE_IGNORED_BAD_PRACTICE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultProcessExecutor.java",
      "category" : "MT_CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/DefaultProcessExecutor.java",
      "fingerprint" : "45757508fede6ce813179388b36a1e30",
      "lineEnd" : 255,
      "lineStart" : 255,
      "message" : "Unconditional wait in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.waitFor(String)",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "DefaultProcessExecutor.java(255,0): UW_UNCOND_WAIT: MT_CORRECTNESS: Unconditional wait in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.waitFor(String)",
      "type" : "UW_UNCOND_WAIT"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultProcessExecutor.java",
      "category" : "MT_CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/DefaultProcessExecutor.java",
      "fingerprint" : "7dd36ac3b2d18d0f8ce1e363d50ebef1",
      "lineEnd" : 302,
      "lineStart" : 302,
      "message" : "Increment of volatile field it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.li in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read()",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "DefaultProcessExecutor.java(302,0): VO_VOLATILE_INCREMENT: MT_CORRECTNESS: Increment of volatile field it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.li in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read()",
      "type" : "VO_VOLATILE_INCREMENT"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DefaultProcessExecutor.java",
      "category" : "MT_CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java/it/tidalwave/util/spi/DefaultProcessExecutor.java",
      "fingerprint" : "7dd36ac3b2d18d0f8ce1e363d50ebef1",
      "lineEnd" : 316,
      "lineStart" : 316,
      "message" : "Increment of volatile field it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.li in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read()",
      "moduleName" : "TheseFoolishThings :: Utilities",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.util.spi",
      "reference" : "245",
      "severity" : "LOW",
      "toString" : "DefaultProcessExecutor.java(316,0): VO_VOLATILE_INCREMENT: MT_CORRECTNESS: Increment of volatile field it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.li in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read()",
      "type" : "VO_VOLATILE_INCREMENT"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DisplayableExample.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/examples/DciDisplayableExample/src/main/java/it/tidalwave/thesefoolishthings/examples/dci/displayable/DisplayableExample.java",
      "fingerprint" : "ef9f74a40652b34ef55de3d670754530",
      "lineEnd" : 45,
      "lineStart" : 45,
      "message" : "Non-null field contextManager is not initialized by new it.tidalwave.thesefoolishthings.examples.dci.displayable.DisplayableExample()",
      "moduleName" : "TheseFoolishThings :: Examples :: DCI :: Displayable",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.thesefoolishthings.examples.dci.displayable",
      "reference" : "247",
      "severity" : "NORMAL",
      "toString" : "DisplayableExample.java(45,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field contextManager is not initialized by new it.tidalwave.thesefoolishthings.examples.dci.displayable.DisplayableExample()",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "DciMarshalXStreamExample.java",
      "category" : "CORRECTNESS",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/examples/DciMarshalXStreamExample/src/main/java/it/tidalwave/thesefoolishthings/examples/dci/marshal/xstream/DciMarshalXStreamExample.java",
      "fingerprint" : "b7578c7fe9b3ecd553b67dbaa05b3f76",
      "lineEnd" : 51,
      "lineStart" : 51,
      "message" : "Non-null field contextManager is not initialized by new it.tidalwave.thesefoolishthings.examples.dci.marshal.xstream.DciMarshalXStreamExample()",
      "moduleName" : "TheseFoolishThings :: Examples :: DCI :: Marshal XStream",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.thesefoolishthings.examples.dci.marshal.xstream",
      "reference" : "247",
      "severity" : "NORMAL",
      "toString" : "DciMarshalXStreamExample.java(51,0): NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR: CORRECTNESS: Non-null field contextManager is not initialized by new it.tidalwave.thesefoolishthings.examples.dci.marshal.xstream.DciMarshalXStreamExample()",
      "type" : "NP_NONNULL_FIELD_NOT_INITIALIZED_IN_CONSTRUCTOR"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SwingDciExample.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/examples/DciSwingExample/src/main/java/it/tidalwave/thesefoolishthings/examples/dci/swing/SwingDciExample.java",
      "fingerprint" : "542cf1dfa927099f0a406ab413cabd92",
      "lineEnd" : 46,
      "lineStart" : 46,
      "message" : "Dead store to control in it.tidalwave.thesefoolishthings.examples.dci.swing.SwingDciExample.run()",
      "moduleName" : "TheseFoolishThings :: Examples :: DCI :: Swing",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.thesefoolishthings.examples.dci.swing",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "SwingDciExample.java(46,0): DLS_DEAD_LOCAL_STORE: STYLE: Dead store to control in it.tidalwave.thesefoolishthings.examples.dci.swing.SwingDciExample.run()",
      "type" : "DLS_DEAD_LOCAL_STORE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SwingPersonPresentation.java",
      "category" : "BAD_PRACTICE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/examples/DciSwingExample/src/main/java/it/tidalwave/thesefoolishthings/examples/dci/swing/swing/SwingPersonPresentation.java",
      "fingerprint" : "f131a611fe9c5be4316ede9a29b6067f",
      "lineEnd" : 0,
      "lineStart" : 0,
      "message" : "Class it.tidalwave.thesefoolishthings.examples.dci.swing.swing.SwingPersonPresentation defines non-transient non-serializable instance field bindings",
      "moduleName" : "TheseFoolishThings :: Examples :: DCI :: Swing",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.thesefoolishthings.examples.dci.swing.swing",
      "reference" : "247",
      "severity" : "LOW",
      "toString" : "SwingPersonPresentation.java(0,0): SE_BAD_FIELD: BAD_PRACTICE: Class it.tidalwave.thesefoolishthings.examples.dci.swing.swing.SwingPersonPresentation defines non-transient non-serializable instance field bindings",
      "type" : "SE_BAD_FIELD"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "SwingPersonPresentation.java",
      "category" : "PERFORMANCE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/examples/DciSwingExample/src/main/java/it/tidalwave/thesefoolishthings/examples/dci/swing/swing/SwingPersonPresentation.java",
      "fingerprint" : "39a5e79a90d946719198c934fc95d720",
      "lineEnd" : 123,
      "lineStart" : 123,
      "message" : "The class it.tidalwave.thesefoolishthings.examples.dci.swing.swing.SwingPersonPresentation$1 could be refactored into a named _static_ inner class",
      "moduleName" : "TheseFoolishThings :: Examples :: DCI :: Swing",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.thesefoolishthings.examples.dci.swing.swing",
      "reference" : "256",
      "severity" : "LOW",
      "toString" : "SwingPersonPresentation.java(123,0): SIC_INNER_SHOULD_BE_STATIC_ANON: PERFORMANCE: The class it.tidalwave.thesefoolishthings.examples.dci.swing.swing.SwingPersonPresentation$1 could be refactored into a named _static_ inner class",
      "type" : "SIC_INNER_SHOULD_BE_STATIC_ANON"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "FinderExample2.java",
      "category" : "STYLE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/examples/ExtendedFinderExample/src/main/java/it/tidalwave/thesefoolishthings/examples/extendedfinderexample/FinderExample2.java",
      "fingerprint" : "4e3d9e78d1189a609e6dfa046101e611",
      "lineEnd" : 71,
      "lineStart" : 71,
      "message" : "Dead store to withFirstNameStartingWithB in it.tidalwave.thesefoolishthings.examples.extendedfinderexample.FinderExample2.main(String[])",
      "moduleName" : "TheseFoolishThings :: Examples :: Finder :: Extended Finder",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.thesefoolishthings.examples.extendedfinderexample",
      "reference" : "263",
      "severity" : "LOW",
      "toString" : "FinderExample2.java(71,0): DLS_DEAD_LOCAL_STORE: STYLE: Dead store to withFirstNameStartingWithB in it.tidalwave.thesefoolishthings.examples.extendedfinderexample.FinderExample2.main(String[])",
      "type" : "DLS_DEAD_LOCAL_STORE"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "PersonFinderImpl2.java",
      "category" : "BAD_PRACTICE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/examples/ExtendedFinderExample/src/main/java/it/tidalwave/thesefoolishthings/examples/extendedfinderexample/PersonFinderImpl2.java",
      "fingerprint" : "70bf8396293236a34684388d34ad97a",
      "lineEnd" : 0,
      "lineStart" : 0,
      "message" : "Class it.tidalwave.thesefoolishthings.examples.extendedfinderexample.PersonFinderImpl2 defines non-transient non-serializable instance field persons",
      "moduleName" : "TheseFoolishThings :: Examples :: Finder :: Extended Finder",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.thesefoolishthings.examples.extendedfinderexample",
      "reference" : "263",
      "severity" : "LOW",
      "toString" : "PersonFinderImpl2.java(0,0): SE_BAD_FIELD: BAD_PRACTICE: Class it.tidalwave.thesefoolishthings.examples.extendedfinderexample.PersonFinderImpl2 defines non-transient non-serializable instance field persons",
      "type" : "SE_BAD_FIELD"
    },
    {
      "addedAt" : 0,
      "authorEmail" : "-",
      "authorName" : "-",
      "baseName" : "PersonFinderImpl2.java",
      "category" : "BAD_PRACTICE",
      "columnEnd" : 0,
      "columnStart" : 0,
      "commit" : "-",
      "description" : "",
      "fileName" : "../../TheseFoolishThings_Metrics/workspace/modules/examples/ExtendedFinderExample/src/main/java/it/tidalwave/thesefoolishthings/examples/extendedfinderexample/PersonFinderImpl2.java",
      "fingerprint" : "af48d62957564cf1ab9c97857245c187",
      "lineEnd" : 108,
      "lineStart" : 56,
      "message" : "it.tidalwave.thesefoolishthings.examples.extendedfinderexample.PersonFinderImpl2 is Serializable; consider declaring a serialVersionUID",
      "moduleName" : "TheseFoolishThings :: Examples :: Finder :: Extended Finder",
      "origin" : "spotbugs",
      "originName" : "",
      "packageName" : "it.tidalwave.thesefoolishthings.examples.extendedfinderexample",
      "reference" : "263",
      "severity" : "LOW",
      "toString" : "PersonFinderImpl2.java(56,0): SE_NO_SERIALVERSIONID: BAD_PRACTICE: it.tidalwave.thesefoolishthings.examples.extendedfinderexample.PersonFinderImpl2 is Serializable; consider declaring a serialVersionUID",
      "type" : "SE_NO_SERIALVERSIONID"
    }
  ],
  "size" : 48,
  "toString" : "48 warnings (normal: 11, low: 37)"
}