<?xml version="1.0" encoding="utf-8"?>
<BugCollection sequence='0' release='' analysisTimestamp='1683004670693' version='4.7.3' timestamp='1683003481978'><Project projectName='TheseFoolishThings :: Utilities'><Jar>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace/modules/Utilities/target/classes</Jar><AuxClasspathEntry>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace@tmp/repository/org/slf4j/slf4j-api/2.0.7/slf4j-api-2.0.7.jar</AuxClasspathEntry><AuxClasspathEntry>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace@tmp/repository/javax/inject/javax.inject/1/javax.inject-1.jar</AuxClasspathEntry><AuxClasspathEntry>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace@tmp/repository/jakarta/inject/jakarta.inject-api/2.0.0/jakarta.inject-api-2.0.0.jar</AuxClasspathEntry><AuxClasspathEntry>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace@tmp/repository/javax/annotation/javax.annotation-api/1.3.2/javax.annotation-api-1.3.2.jar</AuxClasspathEntry><AuxClasspathEntry>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace@tmp/repository/com/github/spotbugs/spotbugs-annotations/3.1.9/spotbugs-annotations-3.1.9.jar</AuxClasspathEntry><AuxClasspathEntry>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace@tmp/repository/com/google/code/findbugs/jsr305/3.0.2/jsr305-3.0.2.jar</AuxClasspathEntry><AuxClasspathEntry>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace@tmp/repository/org/projectlombok/lombok/1.18.24/lombok-1.18.24.jar</AuxClasspathEntry><SrcDir>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace/modules/Utilities/src/main/java</SrcDir><WrkDir>/var/jenkins_home/jobs/TheseFoolishThings_Metrics/workspace/modules/Utilities/target</WrkDir></Project><BugInstance instanceOccurrenceNum='0' instanceHash='5d870cc1b5cd713568d6636ef559aae2' rank='20' abbrev='MC' category='MALICIOUS_CODE' priority='3' type='MC_OVERRIDABLE_METHOD_CALL_IN_CONSTRUCTOR' instanceOccurrenceMax='0'><ShortMessage>An overridable method is called from a constructor</ShortMessage><LongMessage>Overridable method createRoleFactory is called from constructor new it.tidalwave.role.impl.AsDelegate().</LongMessage><Class classname='it.tidalwave.role.impl.AsDelegate' primary='true'><SourceLine classname='it.tidalwave.role.impl.AsDelegate' start='60' end='209' sourcepath='it/tidalwave/role/impl/AsDelegate.java' sourcefile='AsDelegate.java'><Message>At AsDelegate.java:[lines 60-209]</Message></SourceLine><Message>In class it.tidalwave.role.impl.AsDelegate</Message></Class><Method isStatic='false' classname='it.tidalwave.role.impl.AsDelegate' signature='()V' name='<init>' primary='true'><SourceLine endBytecode='91' classname='it.tidalwave.role.impl.AsDelegate' start='69' end='72' sourcepath='it/tidalwave/role/impl/AsDelegate.java' sourcefile='AsDelegate.java' startBytecode='0'></SourceLine><Message>In method new it.tidalwave.role.impl.AsDelegate()</Message></Method><String value='createRoleFactory'><Message>Value createRoleFactory</Message></String><SourceLine endBytecode='22' classname='it.tidalwave.role.impl.AsDelegate' start='71' end='71' sourcepath='it/tidalwave/role/impl/AsDelegate.java' sourcefile='AsDelegate.java' startBytecode='22' primary='true'><Message>At AsDelegate.java:[line 71]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='f6f3cc9c2a6211efe0f77ce30776fb4d' rank='20' abbrev='MC' category='MALICIOUS_CODE' priority='3' type='MC_OVERRIDABLE_METHOD_CALL_IN_CONSTRUCTOR' instanceOccurrenceMax='0'><ShortMessage>An overridable method is called from a constructor</ShortMessage><LongMessage>Overridable method createRoleFactory is called from constructor new it.tidalwave.role.impl.AsDelegate(Object, Collection).</LongMessage><Class classname='it.tidalwave.role.impl.AsDelegate' primary='true'><SourceLine classname='it.tidalwave.role.impl.AsDelegate' start='60' end='209' sourcepath='it/tidalwave/role/impl/AsDelegate.java' sourcefile='AsDelegate.java'><Message>At AsDelegate.java:[lines 60-209]</Message></SourceLine><Message>In class it.tidalwave.role.impl.AsDelegate</Message></Class><Method isStatic='false' classname='it.tidalwave.role.impl.AsDelegate' signature='(Ljava/lang/Object;Ljava/util/Collection;)V' name='<init>' primary='true'><SourceLine endBytecode='95' classname='it.tidalwave.role.impl.AsDelegate' start='114' end='115' sourcepath='it/tidalwave/role/impl/AsDelegate.java' sourcefile='AsDelegate.java' startBytecode='0'></SourceLine><Message>In method new it.tidalwave.role.impl.AsDelegate(Object, Collection)</Message></Method><String value='createRoleFactory'><Message>Value createRoleFactory</Message></String><SourceLine endBytecode='1' classname='it.tidalwave.role.impl.AsDelegate' start='114' end='114' sourcepath='it/tidalwave/role/impl/AsDelegate.java' sourcefile='AsDelegate.java' startBytecode='1' primary='true'><Message>At AsDelegate.java:[line 114]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='b2c3aa96765d6f3081cf9ed54dee449c' rank='20' abbrev='SIC' category='PERFORMANCE' priority='3' type='SIC_INNER_SHOULD_BE_STATIC_ANON' instanceOccurrenceMax='0'><ShortMessage>Could be refactored into a named static inner class</ShortMessage><LongMessage>The class it.tidalwave.role.impl.DefaultContextManager$1 could be refactored into a named _static_ inner class</LongMessage><Class role='CLASS_ANONYMOUS' classname='it.tidalwave.role.impl.DefaultContextManager$1'><SourceLine classname='it.tidalwave.role.impl.DefaultContextManager$1' start='57' end='61' sourcepath='it/tidalwave/role/impl/DefaultContextManager.java' sourcefile='DefaultContextManager.java'><Message>At DefaultContextManager.java:[lines 57-61]</Message></SourceLine><Message>Anonymous class it.tidalwave.role.impl.DefaultContextManager$1</Message></Class><Class classname='it.tidalwave.role.impl.DefaultContextManager' primary='true'><SourceLine classname='it.tidalwave.role.impl.DefaultContextManager' start='45' end='183' sourcepath='it/tidalwave/role/impl/DefaultContextManager.java' sourcefile='DefaultContextManager.java'><Message>At DefaultContextManager.java:[lines 45-183]</Message></SourceLine><Message>In class it.tidalwave.role.impl.DefaultContextManager</Message></Class><Method isStatic='false' classname='it.tidalwave.role.impl.DefaultContextManager' signature='()V' name='<init>' primary='true'><SourceLine endBytecode='170' classname='it.tidalwave.role.impl.DefaultContextManager' start='71' end='83' sourcepath='it/tidalwave/role/impl/DefaultContextManager.java' sourcefile='DefaultContextManager.java' startBytecode='0'></SourceLine><Message>In method new it.tidalwave.role.impl.DefaultContextManager()</Message></Method><SourceLine endBytecode='24' classname='it.tidalwave.role.impl.DefaultContextManager' start='56' end='56' sourcepath='it/tidalwave/role/impl/DefaultContextManager.java' sourcefile='DefaultContextManager.java' startBytecode='24' primary='true'><Message>At DefaultContextManager.java:[line 56]</Message></SourceLine><Field isStatic='false' classname='it.tidalwave.role.impl.DefaultContextManager' signature='Ljava/lang/ThreadLocal;' name='localContexts' primary='true'><SourceLine classname='it.tidalwave.role.impl.DefaultContextManager' sourcepath='it/tidalwave/role/impl/DefaultContextManager.java' sourcefile='DefaultContextManager.java'><Message>In DefaultContextManager.java</Message></SourceLine><Message>Field it.tidalwave.role.impl.DefaultContextManager.localContexts</Message></Field></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='1808ed7b2ded2037f426d6180915ab8d' rank='20' abbrev='FS' category='BAD_PRACTICE' priority='2' type='VA_FORMAT_STRING_USES_NEWLINE' instanceOccurrenceMax='0'><ShortMessage>Format string should use %n rather than \n</ShortMessage><LongMessage>Format string should use %n rather than \n in it.tidalwave.role.impl.ServiceLoaderLocator.findService(Class)</LongMessage><Class classname='it.tidalwave.role.impl.ServiceLoaderLocator' primary='true'><SourceLine classname='it.tidalwave.role.impl.ServiceLoaderLocator' start='47' end='110' sourcepath='it/tidalwave/role/impl/ServiceLoaderLocator.java' sourcefile='ServiceLoaderLocator.java'><Message>At ServiceLoaderLocator.java:[lines 47-110]</Message></SourceLine><Message>In class it.tidalwave.role.impl.ServiceLoaderLocator</Message></Class><Method isStatic='true' classname='it.tidalwave.role.impl.ServiceLoaderLocator' signature='(Ljava/lang/Class;)Ljava/lang/Object;' name='findService' primary='true'><SourceLine endBytecode='496' classname='it.tidalwave.role.impl.ServiceLoaderLocator' start='62' end='98' sourcepath='it/tidalwave/role/impl/ServiceLoaderLocator.java' sourcefile='ServiceLoaderLocator.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.role.impl.ServiceLoaderLocator.findService(Class)</Message></Method><Method isStatic='false' role='METHOD_CALLED' classname='java.io.PrintStream' signature='(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;' name='printf'><SourceLine endBytecode='68' classname='java.io.PrintStream' start='949' end='949' sourcepath='java/io/PrintStream.java' sourcefile='PrintStream.java' startBytecode='0'></SourceLine><Message>Called method java.io.PrintStream.printf(String, Object[])</Message></Method><String role='STRING_FORMAT_STRING' value='%s instantiated from META-INF/services: %s\n'><Message>Format string "%s instantiated from META-INF/services: %s\n"</Message></String><SourceLine endBytecode='212' classname='it.tidalwave.role.impl.ServiceLoaderLocator' start='95' end='95' sourcepath='it/tidalwave/role/impl/ServiceLoaderLocator.java' sourcefile='ServiceLoaderLocator.java' startBytecode='212' primary='true'><Message>At ServiceLoaderLocator.java:[line 95]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='77d808d30e81a0e03d34e00d01193a5b' rank='20' abbrev='DP' category='MALICIOUS_CODE' priority='3' type='DP_DO_INSIDE_DO_PRIVILEGED' instanceOccurrenceMax='0'><ShortMessage>Method invoked that should be only be invoked inside a doPrivileged block</ShortMessage><LongMessage>Invocation of reflect.Field.setAccessible(boolean), which should be invoked from within a doPrivileged block, in it.tidalwave.util.ReflectionUtils.injectDependencies(Object, Map)</LongMessage><Class classname='it.tidalwave.util.ReflectionUtils' primary='true'><SourceLine classname='it.tidalwave.util.ReflectionUtils' start='55' end='233' sourcepath='it/tidalwave/util/ReflectionUtils.java' sourcefile='ReflectionUtils.java'><Message>At ReflectionUtils.java:[lines 55-233]</Message></SourceLine><Message>In class it.tidalwave.util.ReflectionUtils</Message></Class><Method isStatic='true' classname='it.tidalwave.util.ReflectionUtils' signature='(Ljava/lang/Object;Ljava/util/Map;)V' name='injectDependencies' primary='true'><SourceLine endBytecode='351' classname='it.tidalwave.util.ReflectionUtils' start='174' end='198' sourcepath='it/tidalwave/util/ReflectionUtils.java' sourcefile='ReflectionUtils.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.ReflectionUtils.injectDependencies(Object, Map)</Message></Method><Method isStatic='false' role='METHOD_CALLED' classname='java.lang.reflect.Field' signature='(Z)V' name='setAccessible'><SourceLine endBytecode='93' classname='java.lang.reflect.Field' start='169' end='172' sourcepath='java/lang/reflect/Field.java' sourcefile='Field.java' startBytecode='0'></SourceLine><Message>Called method reflect.Field.setAccessible(boolean)</Message></Method><SourceLine endBytecode='49' classname='it.tidalwave.util.ReflectionUtils' start='179' end='179' sourcepath='it/tidalwave/util/ReflectionUtils.java' sourcefile='ReflectionUtils.java' startBytecode='49' primary='true'><Message>At ReflectionUtils.java:[line 179]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='10b6c30d77fba5e675929d6fadf1a5d' cweid='476' rank='13' abbrev='NP' category='STYLE' priority='2' type='NP_NULL_ON_SOME_PATH_FROM_RETURN_VALUE' instanceOccurrenceMax='0'><ShortMessage>Possible null pointer dereference due to return value of called method</ShortMessage><LongMessage>Possible null pointer dereference in it.tidalwave.util.ReflectionUtils.getTypeArguments(Class, Class) due to return value of called method</LongMessage><Class classname='it.tidalwave.util.ReflectionUtils' primary='true'><SourceLine classname='it.tidalwave.util.ReflectionUtils' start='55' end='233' sourcepath='it/tidalwave/util/ReflectionUtils.java' sourcefile='ReflectionUtils.java'><Message>At ReflectionUtils.java:[lines 55-233]</Message></SourceLine><Message>In class it.tidalwave.util.ReflectionUtils</Message></Class><Method isStatic='true' classname='it.tidalwave.util.ReflectionUtils' signature='(Ljava/lang/Class;Ljava/lang/Class;)Ljava/util/List;' name='getTypeArguments' primary='true'><SourceLine endBytecode='704' classname='it.tidalwave.util.ReflectionUtils' start='72' end='128' sourcepath='it/tidalwave/util/ReflectionUtils.java' sourcefile='ReflectionUtils.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.ReflectionUtils.getTypeArguments(Class, Class)</Message></Method><LocalVariable role='LOCAL_VARIABLE_UNKNOWN' pc='15' name='?' register='-1'><Message>Local variable stored in JVM register ?</Message></LocalVariable><SourceLine role='SOURCE_LINE_DEREF' endBytecode='15' classname='it.tidalwave.util.ReflectionUtils' start='76' end='76' sourcepath='it/tidalwave/util/ReflectionUtils.java' sourcefile='ReflectionUtils.java' startBytecode='15' primary='true'><Message>Dereferenced at ReflectionUtils.java:[line 76]</Message></SourceLine><SourceLine role='SOURCE_LINE_KNOWN_NULL' endBytecode='11' classname='it.tidalwave.util.ReflectionUtils' start='76' end='76' sourcepath='it/tidalwave/util/ReflectionUtils.java' sourcefile='ReflectionUtils.java' startBytecode='11'><Message>Known null at ReflectionUtils.java:[line 76]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='7be4ca9057d0e00346e79a3f88d4648d' cweid='396' rank='17' abbrev='REC' category='STYLE' priority='2' type='REC_CATCH_EXCEPTION' instanceOccurrenceMax='0'><ShortMessage>Exception is caught when Exception is not thrown</ShortMessage><LongMessage>Exception is caught when Exception is not thrown in it.tidalwave.util.ShortNames.shortId(Object)</LongMessage><Class classname='it.tidalwave.util.ShortNames' primary='true'><SourceLine classname='it.tidalwave.util.ShortNames' start='44' end='197' sourcepath='it/tidalwave/util/ShortNames.java' sourcefile='ShortNames.java'><Message>At ShortNames.java:[lines 44-197]</Message></SourceLine><Message>In class it.tidalwave.util.ShortNames</Message></Class><Method isStatic='true' classname='it.tidalwave.util.ShortNames' signature='(Ljava/lang/Object;)Ljava/lang/String;' name='shortId' primary='true'><SourceLine endBytecode='271' classname='it.tidalwave.util.ShortNames' start='142' end='160' sourcepath='it/tidalwave/util/ShortNames.java' sourcefile='ShortNames.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.ShortNames.shortId(Object)</Message></Method><SourceLine endBytecode='97' classname='it.tidalwave.util.ShortNames' start='155' end='155' sourcepath='it/tidalwave/util/ShortNames.java' sourcefile='ShortNames.java' startBytecode='97' primary='true'><Message>At ShortNames.java:[line 155]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='7fca9fcbc49ac7127f3739fd533f3aa4' cweid='440' rank='14' abbrev='DMI' category='BAD_PRACTICE' priority='1' type='DMI_RANDOM_USED_ONLY_ONCE' instanceOccurrenceMax='0'><ShortMessage>Random object created and used only once</ShortMessage><LongMessage>Random object created and used only once in it.tidalwave.util.StreamUtils.randomLocalDateTimeStream(long, LocalDateTime, LocalDateTime)</LongMessage><Class classname='it.tidalwave.util.StreamUtils' primary='true'><SourceLine classname='it.tidalwave.util.StreamUtils' start='53' end='142' sourcepath='it/tidalwave/util/StreamUtils.java' sourcefile='StreamUtils.java'><Message>At StreamUtils.java:[lines 53-142]</Message></SourceLine><Message>In class it.tidalwave.util.StreamUtils</Message></Class><Method isStatic='true' classname='it.tidalwave.util.StreamUtils' signature='(JLjava/time/LocalDateTime;Ljava/time/LocalDateTime;)Ljava/util/stream/Stream;' name='randomLocalDateTimeStream' primary='true'><SourceLine endBytecode='128' classname='it.tidalwave.util.StreamUtils' start='139' end='140' sourcepath='it/tidalwave/util/StreamUtils.java' sourcefile='StreamUtils.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.StreamUtils.randomLocalDateTimeStream(long, LocalDateTime, LocalDateTime)</Message></Method><Method isStatic='false' role='METHOD_CALLED' classname='java.util.Random' signature='(JJ)Ljava/util/stream/LongStream;' name='longs'><SourceLine endBytecode='121' classname='java.util.Random' start='863' end='865' sourcepath='java/util/Random.java' sourcefile='Random.java' startBytecode='0'></SourceLine><Message>Called method java.util.Random.longs(long, long)</Message></Method><SourceLine endBytecode='25' classname='it.tidalwave.util.StreamUtils' start='141' end='141' sourcepath='it/tidalwave/util/StreamUtils.java' sourcefile='StreamUtils.java' startBytecode='25' primary='true'><Message>At StreamUtils.java:[line 141]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='63bc3860945c376aeb5dd62f353873c6' rank='20' abbrev='Dm' category='I18N' priority='3' type='DM_CONVERT_CASE' instanceOccurrenceMax='0'><ShortMessage>Consider using Locale parameterized version of invoked method</ShortMessage><LongMessage>Use of non-localized String.toUpperCase() or String.toLowerCase() in new it.tidalwave.util.impl.DefaultPreferencesHandler()</LongMessage><Class classname='it.tidalwave.util.impl.DefaultPreferencesHandler' primary='true'><SourceLine classname='it.tidalwave.util.impl.DefaultPreferencesHandler' start='48' end='125' sourcepath='it/tidalwave/util/impl/DefaultPreferencesHandler.java' sourcefile='DefaultPreferencesHandler.java'><Message>At DefaultPreferencesHandler.java:[lines 48-125]</Message></SourceLine><Message>In class it.tidalwave.util.impl.DefaultPreferencesHandler</Message></Class><Method isStatic='false' classname='it.tidalwave.util.impl.DefaultPreferencesHandler' signature='()V' name='<init>' primary='true'><SourceLine endBytecode='573' classname='it.tidalwave.util.impl.DefaultPreferencesHandler' start='61' end='103' sourcepath='it/tidalwave/util/impl/DefaultPreferencesHandler.java' sourcefile='DefaultPreferencesHandler.java' startBytecode='0'></SourceLine><Message>In method new it.tidalwave.util.impl.DefaultPreferencesHandler()</Message></Method><SourceLine endBytecode='34' classname='it.tidalwave.util.impl.DefaultPreferencesHandler' start='67' end='67' sourcepath='it/tidalwave/util/impl/DefaultPreferencesHandler.java' sourcefile='DefaultPreferencesHandler.java' startBytecode='34' primary='true'><Message>At DefaultPreferencesHandler.java:[line 67]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='b0fae63d5097a179c790dd83f24c81c1' rank='20' abbrev='FS' category='BAD_PRACTICE' priority='2' type='VA_FORMAT_STRING_USES_NEWLINE' instanceOccurrenceMax='0'><ShortMessage>Format string should use %n rather than \n</ShortMessage><LongMessage>Format string should use %n rather than \n in new it.tidalwave.util.impl.DefaultPreferencesHandler()</LongMessage><Class classname='it.tidalwave.util.impl.DefaultPreferencesHandler' primary='true'><SourceLine classname='it.tidalwave.util.impl.DefaultPreferencesHandler' start='48' end='125' sourcepath='it/tidalwave/util/impl/DefaultPreferencesHandler.java' sourcefile='DefaultPreferencesHandler.java'><Message>At DefaultPreferencesHandler.java:[lines 48-125]</Message></SourceLine><Message>In class it.tidalwave.util.impl.DefaultPreferencesHandler</Message></Class><Method isStatic='false' classname='it.tidalwave.util.impl.DefaultPreferencesHandler' signature='()V' name='<init>' primary='true'><SourceLine endBytecode='573' classname='it.tidalwave.util.impl.DefaultPreferencesHandler' start='61' end='103' sourcepath='it/tidalwave/util/impl/DefaultPreferencesHandler.java' sourcefile='DefaultPreferencesHandler.java' startBytecode='0'></SourceLine><Message>In method new it.tidalwave.util.impl.DefaultPreferencesHandler()</Message></Method><Method isStatic='false' role='METHOD_CALLED' classname='java.io.PrintStream' signature='(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;' name='printf'><SourceLine endBytecode='68' classname='java.io.PrintStream' start='949' end='949' sourcepath='java/io/PrintStream.java' sourcefile='PrintStream.java' startBytecode='0'></SourceLine><Message>Called method java.io.PrintStream.printf(String, Object[])</Message></Method><String role='STRING_FORMAT_STRING' value='App folder: %s\n'><Message>Format string "App folder: %s\n"</Message></String><SourceLine endBytecode='291' classname='it.tidalwave.util.impl.DefaultPreferencesHandler' start='95' end='95' sourcepath='it/tidalwave/util/impl/DefaultPreferencesHandler.java' sourcefile='DefaultPreferencesHandler.java' startBytecode='291' primary='true'><Message>At DefaultPreferencesHandler.java:[line 95]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='4a8025d870b311a2d7060fd305f32c1d' rank='20' abbrev='FS' category='BAD_PRACTICE' priority='2' type='VA_FORMAT_STRING_USES_NEWLINE' instanceOccurrenceMax='0'><ShortMessage>Format string should use %n rather than \n</ShortMessage><LongMessage>Format string should use %n rather than \n in new it.tidalwave.util.impl.DefaultPreferencesHandler()</LongMessage><Class classname='it.tidalwave.util.impl.DefaultPreferencesHandler' primary='true'><SourceLine classname='it.tidalwave.util.impl.DefaultPreferencesHandler' start='48' end='125' sourcepath='it/tidalwave/util/impl/DefaultPreferencesHandler.java' sourcefile='DefaultPreferencesHandler.java'><Message>At DefaultPreferencesHandler.java:[lines 48-125]</Message></SourceLine><Message>In class it.tidalwave.util.impl.DefaultPreferencesHandler</Message></Class><Method isStatic='false' classname='it.tidalwave.util.impl.DefaultPreferencesHandler' signature='()V' name='<init>' primary='true'><SourceLine endBytecode='573' classname='it.tidalwave.util.impl.DefaultPreferencesHandler' start='61' end='103' sourcepath='it/tidalwave/util/impl/DefaultPreferencesHandler.java' sourcefile='DefaultPreferencesHandler.java' startBytecode='0'></SourceLine><Message>In method new it.tidalwave.util.impl.DefaultPreferencesHandler()</Message></Method><Method isStatic='false' role='METHOD_CALLED' classname='java.io.PrintStream' signature='(Ljava/lang/String;[Ljava/lang/Object;)Ljava/io/PrintStream;' name='printf'><SourceLine endBytecode='68' classname='java.io.PrintStream' start='949' end='949' sourcepath='java/io/PrintStream.java' sourcefile='PrintStream.java' startBytecode='0'></SourceLine><Message>Called method java.io.PrintStream.printf(String, Object[])</Message></Method><String role='STRING_FORMAT_STRING' value='Logging folder: %s\n'><Message>Format string "Logging folder: %s\n"</Message></String><SourceLine endBytecode='311' classname='it.tidalwave.util.impl.DefaultPreferencesHandler' start='96' end='96' sourcepath='it/tidalwave/util/impl/DefaultPreferencesHandler.java' sourcefile='DefaultPreferencesHandler.java' startBytecode='311' primary='true'><Message>At DefaultPreferencesHandler.java:[line 96]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='fa2ffc2350e5e3e7dc76ba596541a746' rank='16' abbrev='Se' category='BAD_PRACTICE' priority='2' type='SE_TRANSIENT_FIELD_NOT_RESTORED' instanceOccurrenceMax='0'><ShortMessage>Transient field that isn't set by deserialization.</ShortMessage><LongMessage>The field it.tidalwave.util.impl.finder.MappingFinder.delegate is transient but isn't set by deserialization</LongMessage><Class classname='it.tidalwave.util.impl.finder.MappingFinder' primary='true'><SourceLine classname='it.tidalwave.util.impl.finder.MappingFinder' start='57' end='73' sourcepath='it/tidalwave/util/impl/finder/MappingFinder.java' sourcefile='MappingFinder.java'><Message>At MappingFinder.java:[lines 57-73]</Message></SourceLine><Message>In class it.tidalwave.util.impl.finder.MappingFinder</Message></Class><Field isStatic='false' classname='it.tidalwave.util.impl.finder.MappingFinder' signature='Lit/tidalwave/util/Finder;' name='delegate' primary='true'><SourceLine classname='it.tidalwave.util.impl.finder.MappingFinder' sourcepath='it/tidalwave/util/impl/finder/MappingFinder.java' sourcefile='MappingFinder.java'><Message>In MappingFinder.java</Message></SourceLine><Message>Field it.tidalwave.util.impl.finder.MappingFinder.delegate</Message></Field><SourceLine synthetic='true' classname='it.tidalwave.util.impl.finder.MappingFinder' sourcepath='it/tidalwave/util/impl/finder/MappingFinder.java' sourcefile='MappingFinder.java'><Message>In MappingFinder.java</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='2ee9b4e52312d8a5f7e746397b358738' rank='19' abbrev='Se' category='BAD_PRACTICE' priority='3' type='SE_TRANSIENT_FIELD_NOT_RESTORED' instanceOccurrenceMax='0'><ShortMessage>Transient field that isn't set by deserialization.</ShortMessage><LongMessage>The field it.tidalwave.util.impl.finder.MappingFinder.decorator is transient but isn't set by deserialization</LongMessage><Class classname='it.tidalwave.util.impl.finder.MappingFinder' primary='true'><SourceLine classname='it.tidalwave.util.impl.finder.MappingFinder' start='57' end='73' sourcepath='it/tidalwave/util/impl/finder/MappingFinder.java' sourcefile='MappingFinder.java'><Message>At MappingFinder.java:[lines 57-73]</Message></SourceLine><Message>In class it.tidalwave.util.impl.finder.MappingFinder</Message></Class><Field isStatic='false' classname='it.tidalwave.util.impl.finder.MappingFinder' signature='Ljava/util/function/Function;' name='decorator' primary='true'><SourceLine classname='it.tidalwave.util.impl.finder.MappingFinder' sourcepath='it/tidalwave/util/impl/finder/MappingFinder.java' sourcefile='MappingFinder.java'><Message>In MappingFinder.java</Message></SourceLine><Message>Field it.tidalwave.util.impl.finder.MappingFinder.decorator</Message></Field><SourceLine synthetic='true' classname='it.tidalwave.util.impl.finder.MappingFinder' sourcepath='it/tidalwave/util/impl/finder/MappingFinder.java' sourcefile='MappingFinder.java'><Message>In MappingFinder.java</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='78620ceffac5909bda9cff745c7c2707' rank='16' abbrev='Se' category='BAD_PRACTICE' priority='2' type='SE_BAD_FIELD' instanceOccurrenceMax='0'><ShortMessage>Non-transient non-serializable instance field in serializable class</ShortMessage><LongMessage>Class it.tidalwave.util.impl.finder.ProviderFinder defines non-transient non-serializable instance field supplier</LongMessage><Class classname='it.tidalwave.util.impl.finder.ProviderFinder' primary='true'><SourceLine classname='it.tidalwave.util.impl.finder.ProviderFinder' start='56' end='70' sourcepath='it/tidalwave/util/impl/finder/ProviderFinder.java' sourcefile='ProviderFinder.java'><Message>At ProviderFinder.java:[lines 56-70]</Message></SourceLine><Message>In class it.tidalwave.util.impl.finder.ProviderFinder</Message></Class><Field isStatic='false' classname='it.tidalwave.util.impl.finder.ProviderFinder' signature='Ljava/util/function/BiFunction;' name='supplier' primary='true'><SourceLine classname='it.tidalwave.util.impl.finder.ProviderFinder' sourcepath='it/tidalwave/util/impl/finder/ProviderFinder.java' sourcefile='ProviderFinder.java'><Message>In ProviderFinder.java</Message></SourceLine><Message>Field it.tidalwave.util.impl.finder.ProviderFinder.supplier</Message></Field><Type role='TYPE_FOUND' descriptor='Ljava/util/function/BiFunction;' typeParameters='<java.lang.Integer,java.lang.Integer,? extends java.util.Collection<? extends T>>'><SourceLine classname='java.util.function.BiFunction' start='69' end='70' sourcepath='java/util/function/BiFunction.java' sourcefile='BiFunction.java'><Message>At BiFunction.java:[lines 69-70]</Message></SourceLine><Message>Actual type java.util.function.BiFunction<java.lang.Integer,java.lang.Integer,? extends java.util.Collection<? extends T>></Message></Type><SourceLine synthetic='true' classname='it.tidalwave.util.impl.finder.ProviderFinder' sourcepath='it/tidalwave/util/impl/finder/ProviderFinder.java' sourcefile='ProviderFinder.java'><Message>In ProviderFinder.java</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='d7ee15815c14bcc4a339b6f44da62359' rank='16' abbrev='Se' category='BAD_PRACTICE' priority='2' type='SE_BAD_FIELD' instanceOccurrenceMax='0'><ShortMessage>Non-transient non-serializable instance field in serializable class</ShortMessage><LongMessage>Class it.tidalwave.util.impl.finder.SupplierFinder defines non-transient non-serializable instance field supplier</LongMessage><Class classname='it.tidalwave.util.impl.finder.SupplierFinder' primary='true'><SourceLine classname='it.tidalwave.util.impl.finder.SupplierFinder' start='54' end='68' sourcepath='it/tidalwave/util/impl/finder/SupplierFinder.java' sourcefile='SupplierFinder.java'><Message>At SupplierFinder.java:[lines 54-68]</Message></SourceLine><Message>In class it.tidalwave.util.impl.finder.SupplierFinder</Message></Class><Field isStatic='false' classname='it.tidalwave.util.impl.finder.SupplierFinder' signature='Ljava/util/function/Supplier;' name='supplier' primary='true'><SourceLine classname='it.tidalwave.util.impl.finder.SupplierFinder' sourcepath='it/tidalwave/util/impl/finder/SupplierFinder.java' sourcefile='SupplierFinder.java'><Message>In SupplierFinder.java</Message></SourceLine><Message>Field it.tidalwave.util.impl.finder.SupplierFinder.supplier</Message></Field><Type role='TYPE_FOUND' descriptor='Ljava/util/function/Supplier;' typeParameters='<? extends java.util.Collection<? extends T>>'><SourceLine classname='java.util.function.Supplier' sourcepath='java/util/function/Supplier.java' sourcefile='Supplier.java'><Message>In Supplier.java</Message></SourceLine><Message>Actual type java.util.function.Supplier<? extends java.util.Collection<? extends T>></Message></Type><SourceLine synthetic='true' classname='it.tidalwave.util.impl.finder.SupplierFinder' sourcepath='it/tidalwave/util/impl/finder/SupplierFinder.java' sourcefile='SupplierFinder.java'><Message>In SupplierFinder.java</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='22a61a349131452fc20a230179a88cee' rank='20' abbrev='Dm' category='I18N' priority='3' type='DM_CONVERT_CASE' instanceOccurrenceMax='0'><ShortMessage>Consider using Locale parameterized version of invoked method</ShortMessage><LongMessage>Use of non-localized String.toUpperCase() or String.toLowerCase() in it.tidalwave.util.spi.DefaultProcessExecutor.isWindows()</LongMessage><Class classname='it.tidalwave.util.spi.DefaultProcessExecutor' primary='true'><SourceLine classname='it.tidalwave.util.spi.DefaultProcessExecutor' start='60' end='483' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java'><Message>At DefaultProcessExecutor.java:[lines 60-483]</Message></SourceLine><Message>In class it.tidalwave.util.spi.DefaultProcessExecutor</Message></Class><Method isStatic='true' classname='it.tidalwave.util.spi.DefaultProcessExecutor' signature='()Z' name='isWindows' primary='true'><SourceLine endBytecode='37' classname='it.tidalwave.util.spi.DefaultProcessExecutor' start='483' end='483' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.spi.DefaultProcessExecutor.isWindows()</Message></Method><SourceLine endBytecode='5' classname='it.tidalwave.util.spi.DefaultProcessExecutor' start='483' end='483' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='5' primary='true'><Message>At DefaultProcessExecutor.java:[line 483]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='546fcec2f3fc51e896f3a93765e3b9a9' rank='19' abbrev='Dm' category='I18N' priority='1' type='DM_DEFAULT_ENCODING' instanceOccurrenceMax='0'><ShortMessage>Reliance on default encoding</ShortMessage><LongMessage>Found reliance on default encoding in it.tidalwave.util.spi.DefaultProcessExecutor.start(): new java.io.PrintWriter(OutputStream, boolean)</LongMessage><Class classname='it.tidalwave.util.spi.DefaultProcessExecutor' primary='true'><SourceLine classname='it.tidalwave.util.spi.DefaultProcessExecutor' start='60' end='483' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java'><Message>At DefaultProcessExecutor.java:[lines 60-483]</Message></SourceLine><Message>In class it.tidalwave.util.spi.DefaultProcessExecutor</Message></Class><Method isStatic='false' classname='it.tidalwave.util.spi.DefaultProcessExecutor' signature='()Lit/tidalwave/util/spi/DefaultProcessExecutor;' name='start' primary='true'><SourceLine endBytecode='368' classname='it.tidalwave.util.spi.DefaultProcessExecutor' start='413' end='430' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.spi.DefaultProcessExecutor.start()</Message></Method><Method isStatic='false' role='METHOD_CALLED' classname='java.io.PrintWriter' signature='(Ljava/io/OutputStream;Z)V' name='<init>'><SourceLine endBytecode='75' classname='java.io.PrintWriter' start='145' end='146' sourcepath='java/io/PrintWriter.java' sourcefile='PrintWriter.java' startBytecode='0'></SourceLine><Message>Called method new java.io.PrintWriter(OutputStream, boolean)</Message></Method><SourceLine endBytecode='203' classname='it.tidalwave.util.spi.DefaultProcessExecutor' start='428' end='428' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='203' primary='true'><Message>At DefaultProcessExecutor.java:[line 428]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='cf72bf19c353afd0d889c0f512a33b98' rank='20' abbrev='UCF' category='STYLE' priority='3' type='UCF_USELESS_CONTROL_FLOW' instanceOccurrenceMax='0'><ShortMessage>Useless control flow</ShortMessage><LongMessage>Useless control flow in it.tidalwave.util.spi.DefaultProcessExecutor.waitForCompletion()</LongMessage><Class classname='it.tidalwave.util.spi.DefaultProcessExecutor' primary='true'><SourceLine classname='it.tidalwave.util.spi.DefaultProcessExecutor' start='60' end='483' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java'><Message>At DefaultProcessExecutor.java:[lines 60-483]</Message></SourceLine><Message>In class it.tidalwave.util.spi.DefaultProcessExecutor</Message></Class><Method isStatic='false' classname='it.tidalwave.util.spi.DefaultProcessExecutor' signature='()Lit/tidalwave/util/spi/DefaultProcessExecutor;' name='waitForCompletion' primary='true'><SourceLine endBytecode='66' classname='it.tidalwave.util.spi.DefaultProcessExecutor' start='455' end='460' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.spi.DefaultProcessExecutor.waitForCompletion()</Message></Method><SourceLine endBytecode='7' classname='it.tidalwave.util.spi.DefaultProcessExecutor' start='455' end='455' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='7' primary='true'><Message>At DefaultProcessExecutor.java:[line 455]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='282979a34723be2e2509ea3ef5ab71c6' rank='19' abbrev='Dm' category='I18N' priority='1' type='DM_DEFAULT_ENCODING' instanceOccurrenceMax='0'><ShortMessage>Reliance on default encoding</ShortMessage><LongMessage>Found reliance on default encoding in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read(): new java.io.InputStreamReader(InputStream)</LongMessage><Class classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' primary='true'><SourceLine classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='69' end='325' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java'><Message>At DefaultProcessExecutor.java:[lines 69-325]</Message></SourceLine><Message>In class it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput</Message></Class><Method isStatic='false' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' signature='()V' name='read' primary='true'><SourceLine endBytecode='497' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='279' end='325' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read()</Message></Method><Method isStatic='false' role='METHOD_CALLED' classname='java.io.InputStreamReader' signature='(Ljava/io/InputStream;)V' name='<init>'><SourceLine endBytecode='85' classname='java.io.InputStreamReader' start='72' end='75' sourcepath='java/io/InputStreamReader.java' sourcefile='InputStreamReader.java' startBytecode='0'></SourceLine><Message>Called method new java.io.InputStreamReader(InputStream)</Message></Method><SourceLine endBytecode='8' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='279' end='279' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='8' primary='true'><Message>At DefaultProcessExecutor.java:[line 279]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='a4ff01756de9ea4b0bf187d6935c6579' rank='14' abbrev='NN' category='MT_CORRECTNESS' priority='2' type='NN_NAKED_NOTIFY' instanceOccurrenceMax='0'><ShortMessage>Naked notify</ShortMessage><LongMessage>Naked notify in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read()</LongMessage><Class classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' primary='true'><SourceLine classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='69' end='325' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java'><Message>At DefaultProcessExecutor.java:[lines 69-325]</Message></SourceLine><Message>In class it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput</Message></Class><Method isStatic='false' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' signature='()V' name='read' primary='true'><SourceLine endBytecode='497' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='279' end='325' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.read()</Message></Method><SourceLine endBytecode='152' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='319' end='319' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='152' primary='true'><Message>At DefaultProcessExecutor.java:[line 319]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='f53c819baaf66f7ccd0135a0b88105ee' cweid='253' rank='19' abbrev='RV' category='BAD_PRACTICE' priority='3' type='RV_RETURN_VALUE_IGNORED_BAD_PRACTICE' instanceOccurrenceMax='0'><ShortMessage>Method ignores exceptional return value</ShortMessage><LongMessage>Exceptional return value of java.util.concurrent.ExecutorService.submit(Runnable) ignored in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.start()</LongMessage><Class classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' primary='true'><SourceLine classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='69' end='325' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java'><Message>At DefaultProcessExecutor.java:[lines 69-325]</Message></SourceLine><Message>In class it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput</Message></Class><Method isStatic='false' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' signature='()Lit/tidalwave/util/ProcessExecutor$ConsoleOutput;' name='start' primary='true'><SourceLine endBytecode='141' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='151' end='159' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.start()</Message></Method><Method isStatic='false' role='METHOD_CALLED' classname='java.util.concurrent.ExecutorService' signature='(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;' name='submit'><SourceLine classname='java.util.concurrent.ExecutorService' sourcepath='java/util/concurrent/ExecutorService.java' sourcefile='ExecutorService.java'></SourceLine><Message>Called method java.util.concurrent.ExecutorService.submit(Runnable)</Message></Method><SourceLine endBytecode='46' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='157' end='157' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='46' primary='true'><Message>At DefaultProcessExecutor.java:[line 157]</Message></SourceLine><SourceLine role='SOURCE_LINE_ANOTHER_INSTANCE' endBytecode='63' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='158' end='158' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='63'><Message>Another occurrence at DefaultProcessExecutor.java:[line 158]</Message></SourceLine></BugInstance><BugInstance instanceOccurrenceNum='0' instanceHash='45757508fede6ce813179388b36a1e30' rank='17' abbrev='UW' category='MT_CORRECTNESS' priority='3' type='UW_UNCOND_WAIT' instanceOccurrenceMax='0'><ShortMessage>Unconditional wait</ShortMessage><LongMessage>Unconditional wait in it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.waitFor(String)</LongMessage><Class classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' primary='true'><SourceLine classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='69' end='325' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java'><Message>At DefaultProcessExecutor.java:[lines 69-325]</Message></SourceLine><Message>In class it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput</Message></Class><Method isStatic='false' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' signature='(Ljava/lang/String;)Lit/tidalwave/util/ProcessExecutor$ConsoleOutput;' name='waitFor' primary='true'><SourceLine endBytecode='252' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='239' end='257' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='0'></SourceLine><Message>In method it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput.waitFor(String)</Message></Method><SourceLine endBytecode='62' classname='it.tidalwave.util.spi.DefaultProcessExecutor$DefaultConsoleOutput' start='252' end='252' sourcepath='it/tidalwave/util/spi/DefaultProcessExecutor.java' sourcefile='DefaultProcessExecutor.java' startBytecode='62' primary='true'><Message>At DefaultProcessExecutor.java:[line 252]</Message></SourceLine></BugInstance><BugCategory category='BAD_PRACTICE'><Description>Bad practice</Description></BugCategory><BugCategory category='MALICIOUS_CODE'><Description>Malicious code vulnerability</Description></BugCategory><BugCategory category='PERFORMANCE'><Description>Performance</Description></BugCategory><BugCategory category='STYLE'><Description>Dodgy code</Description></BugCategory><BugCategory category='MT_CORRECTNESS'><Description>Multithreaded correctness</Description></BugCategory><BugCategory category='I18N'><Description>Internationalization</Description></BugCategory><BugPattern abbrev='DP' category='MALICIOUS_CODE' type='DP_DO_INSIDE_DO_PRIVILEGED'><ShortDescription>Method invoked that should be only be invoked inside a doPrivileged block</ShortDescription><Details>
<p> This code invokes a method that requires a security permission check.
If this code will be granted security permissions, but might be invoked by code that does not
have security permissions, then the invocation needs to occur inside a doPrivileged block.</p>
</Details></BugPattern><BugPattern abbrev='NP' category='STYLE' type='NP_NULL_ON_SOME_PATH_FROM_RETURN_VALUE'><ShortDescription>Possible null pointer dereference due to return value of called method</ShortDescription><Details>
<p> The return value from a method is dereferenced without a null check,
and the return value of that method is one that should generally be checked
for null. This may lead to a <code>NullPointerException</code> when the code is executed.
</p>
</Details></BugPattern><BugPattern cweid='396' abbrev='REC' category='STYLE' type='REC_CATCH_EXCEPTION'><ShortDescription>Exception is caught when Exception is not thrown</ShortDescription><Details>
<p>
This method uses a try-catch block that catches Exception objects, but Exception is not
thrown within the try block, and RuntimeException is not explicitly caught. It is a common bug pattern to
say try { ... } catch (Exception e) { something } as a shorthand for catching a number of types of exception
each of whose catch blocks is identical, but this construct also accidentally catches RuntimeException as well,
masking potential bugs.
</p>
<p>A better approach is to either explicitly catch the specific exceptions that are thrown,
or to explicitly catch RuntimeException exception, rethrow it, and then catch all non-Runtime Exceptions, as shown below:</p>
<pre><code>try {
...
} catch (RuntimeException e) {
throw e;
} catch (Exception e) {
... deal with all non-runtime exceptions ...
}
</code></pre>
</Details></BugPattern><BugPattern abbrev='FS' category='BAD_PRACTICE' type='VA_FORMAT_STRING_USES_NEWLINE'><ShortDescription>Format string should use %n rather than \n</ShortDescription><Details>
<p>
This format string includes a newline character (\n). In format strings, it is generally
preferable to use %n, which will produce the platform-specific line separator.
</p>
</Details></BugPattern><BugPattern abbrev='DMI' category='BAD_PRACTICE' type='DMI_RANDOM_USED_ONLY_ONCE'><ShortDescription>Random object created and used only once</ShortDescription><Details>
<p> This code creates a java.util.Random object, uses it to generate one random number, and then discards
the Random object. This produces mediocre quality random numbers and is inefficient.
If possible, rewrite the code so that the Random object is created once and saved, and each time a new random number
is required invoke a method on the existing Random object to obtain it.
</p>
<p>If it is important that the generated Random numbers not be guessable, you <em>must</em> not create a new Random for each random
number; the values are too easily guessable. You should strongly consider using a java.security.SecureRandom instead
(and avoid allocating a new SecureRandom for each random number needed).
</p>
</Details></BugPattern><BugPattern abbrev='SIC' category='PERFORMANCE' type='SIC_INNER_SHOULD_BE_STATIC_ANON'><ShortDescription>Could be refactored into a named static inner class</ShortDescription><Details>
<p> This class is an inner class, but does not use its embedded reference
to the object which created it.&nbsp; This reference makes the instances
of the class larger, and may keep the reference to the creator object
alive longer than necessary.&nbsp; If possible, the class should be
made into a <em>static</em> inner class. Since anonymous inner
classes cannot be marked as static, doing this will require refactoring
the inner class so that it is a named inner class.</p>
</Details></BugPattern><BugPattern abbrev='MC' category='MALICIOUS_CODE' type='MC_OVERRIDABLE_METHOD_CALL_IN_CONSTRUCTOR'><ShortDescription>An overridable method is called from a constructor</ShortDescription><Details>
<p>
Calling an overridable method during in a constructor may result in the use of uninitialized data. It may also
leak the this reference of the partially constructed object. Only static, final or private methods should be
invoked from a constructor.</p>
<p>
See SEI CERT rule <a href="https://wiki.sei.cmu.edu/confluence/display/java/MET05-J.+Ensure+that+constructors+do+not+call+overridable+methods">MET05-J. Ensure that constructors do not call overridable methods</a>.
</p>
</Details></BugPattern><BugPattern abbrev='Dm' category='I18N' type='DM_DEFAULT_ENCODING'><ShortDescription>Reliance on default encoding</ShortDescription><Details>
<p> Found a call to a method which will perform a byte to String (or String to byte) conversion,
and will assume that the default platform encoding is suitable. This will cause the application
behavior to vary between platforms. Use an alternative API and specify a charset name or Charset
object explicitly.</p>
</Details></BugPattern><BugPattern abbrev='Se' category='BAD_PRACTICE' type='SE_TRANSIENT_FIELD_NOT_RESTORED'><ShortDescription>Transient field that isn't set by deserialization.</ShortDescription><Details>
<p> This class contains a field that is updated at multiple places in the class, thus it seems to be part of the state of the class. However, since the field is marked as transient and not set in readObject or readResolve, it will contain the default value in any
deserialized instance of the class.
</p>
</Details></BugPattern><BugPattern abbrev='Se' category='BAD_PRACTICE' type='SE_BAD_FIELD'><ShortDescription>Non-transient non-serializable instance field in serializable class</ShortDescription><Details>
<p> This Serializable class defines a non-primitive instance field which is neither transient,
Serializable, or <code>java.lang.Object</code>, and does not appear to implement
the <code>Externalizable</code> interface or the
<code>readObject()</code> and <code>writeObject()</code> methods.&nbsp;
Objects of this class will not be deserialized correctly if a non-Serializable
object is stored in this field.</p>
</Details></BugPattern><BugPattern abbrev='UW' category='MT_CORRECTNESS' type='UW_UNCOND_WAIT'><ShortDescription>Unconditional wait</ShortDescription><Details>
<p> This method contains a call to <code>java.lang.Object.wait()</code> which
is not guarded by conditional control flow. The code should
verify that condition it intends to wait for is not already satisfied
before calling wait; any previous notifications will be ignored.
</p>
</Details></BugPattern><BugPattern abbrev='UCF' category='STYLE' type='UCF_USELESS_CONTROL_FLOW'><ShortDescription>Useless control flow</ShortDescription><Details>
<p> This method contains a useless control flow statement, where
control flow continues onto the same place regardless of whether or not
the branch is taken. For example,
this is caused by having an empty statement
block for an <code>if</code> statement:</p>
<pre><code>if (argv.length == 0) {
// TODO: handle this case