Author: schor
Date: Fri Apr 26 20:23:23 2013
New Revision: 1476384

URL: http://svn.apache.org/r1476384
Log:
[UIMA-2844] findbugs issues: have skipped bytes calls be cognizant of number of 
bytes skipped; prepare pom (commented out for now) for supporting selective 
overrides of particular findbug rules, Reduce large static final identical 
string replication in multiple classes, use Integer.valueOf

Modified:
    
uima/uimaj/trunk/jVinci/src/main/java/org/apache/vinci/transport/document/XMLToXTalk.java
    uima/uimaj/trunk/uimaj-core/pom.xml
    
uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLang.java
    
uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLangs.java
    
uima/uimaj/trunk/uimaj-ep-configurator/src/main/java/org/apache/uima/taeconfigurator/wizards/AbstractNewWizard.java
    
uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPlugin.java
    
uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPluginRunner.java

Modified: 
uima/uimaj/trunk/jVinci/src/main/java/org/apache/vinci/transport/document/XMLToXTalk.java
URL: 
http://svn.apache.org/viewvc/uima/uimaj/trunk/jVinci/src/main/java/org/apache/vinci/transport/document/XMLToXTalk.java?rev=1476384&r1=1476383&r2=1476384&view=diff
==============================================================================
--- 
uima/uimaj/trunk/jVinci/src/main/java/org/apache/vinci/transport/document/XMLToXTalk.java
 (original)
+++ 
uima/uimaj/trunk/jVinci/src/main/java/org/apache/vinci/transport/document/XMLToXTalk.java
 Fri Apr 26 20:23:23 2013
@@ -279,9 +279,13 @@ public class XMLToXTalk {
   }
 
   static private void skipString(RandomAccessFile raf) throws IOException {
-    int count = raf.readInt();
+    final int count = raf.readInt();
     // Debug.p("Skipping string of size: " + count);
-    raf.skipBytes(count);
+    final int skipped = raf.skipBytes(count); 
+    if (count != skipped) {
+      throw new RuntimeException(String.format("%d bytes skipped when %d was 
requested, while reading from stream %s",
+          skipped, count, raf));
+    }
   }
 
   public static void main(String[] args) throws Exception {

Modified: uima/uimaj/trunk/uimaj-core/pom.xml
URL: 
http://svn.apache.org/viewvc/uima/uimaj/trunk/uimaj-core/pom.xml?rev=1476384&r1=1476383&r2=1476384&view=diff
==============================================================================
--- uima/uimaj/trunk/uimaj-core/pom.xml (original)
+++ uima/uimaj/trunk/uimaj-core/pom.xml Fri Apr 26 20:23:23 2013
@@ -73,6 +73,17 @@
                        <version>${project.parent.version}</version>
                        <scope>test</scope>
                </dependency>
+               
+               <!-- This next dependency is used to enable findbug rule 
suppression annotations
+                    Currently commented out - till more thought given to this. 
+                    For instance, we don't want to accidentally distribute 
this dependency in builds
+               <dependency>
+                       <groupId>com.google.code.findbugs</groupId>
+                       <artifactId>annotations</artifactId>
+                       <version>2.0.0</version>
+                       <scope>compile</scope>
+               </dependency>
+                -->
        </dependencies>
        <build>
                <finalName>uima-core</finalName>

Modified: 
uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLang.java
URL: 
http://svn.apache.org/viewvc/uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLang.java?rev=1476384&r1=1476383&r2=1476384&view=diff
==============================================================================
--- 
uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLang.java
 (original)
+++ 
uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLang.java
 Fri Apr 26 20:23:23 2013
@@ -38,7 +38,7 @@ public class RsLang {
    * @param language
    * @return x-unspecified if lang is null or a canonical version of the lang 
string
    */
-  @edu.umd.cs.findbugs.annotations.SuppressWarnings("DM_STRING_CTOR")
+//  @edu.umd.cs.findbugs.annotations.SuppressWarnings("DM_STRING_CTOR")
   static String getCanonicalLanguageString(String language) {
     if (language == null || language.equals(Language.UNSPECIFIED_LANGUAGE)) {  
// represents x-unspecified
       return Language.UNSPECIFIED_LANGUAGE;

Modified: 
uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLangs.java
URL: 
http://svn.apache.org/viewvc/uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLangs.java?rev=1476384&r1=1476383&r2=1476384&view=diff
==============================================================================
--- 
uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLangs.java
 (original)
+++ 
uima/uimaj/trunk/uimaj-core/src/main/java/org/apache/uima/analysis_engine/impl/RsLangs.java
 Fri Apr 26 20:23:23 2013
@@ -121,7 +121,7 @@ public class RsLangs {
    * @return true if any of the rsLangs subsumes the param lang
    */
 
-  
@edu.umd.cs.findbugs.annotations.SuppressWarnings("ES_COMPARING_PARAMETER_STRING_WITH_EQ")
+//  
@edu.umd.cs.findbugs.annotations.SuppressWarnings("ES_COMPARING_PARAMETER_STRING_WITH_EQ")
   static boolean subsumesCanonical(RsLangs rsl, String lang) {
     if (null == rsl || null == rsl.languages) {  // don't test for size() == 0 
- that's used by replace to indicate empty, not x-unspec
       return true;  // x-unspecified subsumes all
@@ -154,7 +154,7 @@ public class RsLangs {
     return false;
   }
   
-  
@edu.umd.cs.findbugs.annotations.SuppressWarnings("ES_COMPARING_PARAMETER_STRING_WITH_EQ")
  
+//  
@edu.umd.cs.findbugs.annotations.SuppressWarnings("ES_COMPARING_PARAMETER_STRING_WITH_EQ")
  
   private static boolean subsumesCanonical(String containingLang, String 
langToTest, String langToTestBase) {
     return containingLang == langToTest || containingLang == langToTestBase; 
   }

Modified: 
uima/uimaj/trunk/uimaj-ep-configurator/src/main/java/org/apache/uima/taeconfigurator/wizards/AbstractNewWizard.java
URL: 
http://svn.apache.org/viewvc/uima/uimaj/trunk/uimaj-ep-configurator/src/main/java/org/apache/uima/taeconfigurator/wizards/AbstractNewWizard.java?rev=1476384&r1=1476383&r2=1476384&view=diff
==============================================================================
--- 
uima/uimaj/trunk/uimaj-ep-configurator/src/main/java/org/apache/uima/taeconfigurator/wizards/AbstractNewWizard.java
 (original)
+++ 
uima/uimaj/trunk/uimaj-ep-configurator/src/main/java/org/apache/uima/taeconfigurator/wizards/AbstractNewWizard.java
 Fri Apr 26 20:23:23 2013
@@ -73,19 +73,24 @@ public abstract class AbstractNewWizard 
   // 4 = implname element name (implementationName or 
annotatorImplementationName
   // 5 = "<primitive>true</primitive>\n"
   
-  public final static String XMLNS_PART = 
"xmlns=\"http://uima.apache.org/resourceSpecifier\"";;
+  // for explanation of this strange code, see JDK bug 6447475   found by 
findbugs
+  public final static String XMLNS_PART;
+  static {XMLNS_PART = "xmlns=\"http://uima.apache.org/resourceSpecifier\"";}
 
-  public final static String COMMON_HEADER = 
+  public final static String COMMON_HEADER;
+  static {COMMON_HEADER = 
     "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\n" 
-    + "<{2} " + XMLNS_PART + ">\n" ;
+    + "<{2} " + XMLNS_PART + ">\n";}
 
-  public final static String COMMON_NDVV = 
+  public final static String COMMON_NDVV;
+  static {COMMON_NDVV = 
       "    <name>{0}</name>\n"    // 1 = name of component (e.g. type name, 
type priority name, ae descriptor name)
     + "    <description></description>\n"
     + "    <version>1.0</version>\n"
-    + "    <vendor></vendor>\n";
+    + "    <vendor></vendor>\n";}
   
-  public final static String COMMON_FULL_DESCRIPTOR =
+  public final static String COMMON_FULL_DESCRIPTOR;
+  static {COMMON_FULL_DESCRIPTOR =
       COMMON_HEADER 
     + "  
<frameworkImplementation>org.apache.uima.java</frameworkImplementation>\n"
     + "{5}"                       // 5 = "" or "<primitive>true</primitive>\n"
@@ -108,13 +113,14 @@ public abstract class AbstractNewWizard 
     + "  <externalResourceDependencies></externalResourceDependencies>\n"
     + "  <resourceManagerConfiguration></resourceManagerConfiguration>\n"
     + "</{2}>"
-    ;
+    ;}
   
-  public static String COMMON_PARTIAL_DESCRIPTOR =
+  public static String COMMON_PARTIAL_DESCRIPTOR;
+  static {COMMON_PARTIAL_DESCRIPTOR =
       COMMON_HEADER 
     + COMMON_NDVV
     + "{1}" 
-    + "</{2}>\n";
+    + "</{2}>\n";}
     
   protected AbstractNewWizardPage page;
 

Modified: 
uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPlugin.java
URL: 
http://svn.apache.org/viewvc/uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPlugin.java?rev=1476384&r1=1476383&r2=1476384&view=diff
==============================================================================
--- 
uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPlugin.java
 (original)
+++ 
uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPlugin.java
 Fri Apr 26 20:23:23 2013
@@ -36,6 +36,7 @@ public class JgPlugin extends Plugin {
   /**
    * The constructor.
    */
+//  
@edu.umd.cs.findbugs.annotations.SuppressWarnings("ST_WRITE_TO_STATIC_FROM_INSTANCE_METHOD")
   public JgPlugin(IPluginDescriptor descriptor) {
     super(descriptor);
     plugin = this;

Modified: 
uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPluginRunner.java
URL: 
http://svn.apache.org/viewvc/uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPluginRunner.java?rev=1476384&r1=1476383&r2=1476384&view=diff
==============================================================================
--- 
uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPluginRunner.java
 (original)
+++ 
uima/uimaj/trunk/uimaj-ep-jcasgen/src/main/java/org/apache/uima/jcas/jcasgenp/JgPluginRunner.java
 Fri Apr 26 20:23:23 2013
@@ -49,12 +49,12 @@ public class JgPluginRunner implements I
         }
       };
       workspace.run(runnable, null);
-      return new Integer(0);
+      return Integer.valueOf(0);
     } catch (Exception exception) {
       exception.printStackTrace();
     }
 
-    return new Integer(1);
+    return Integer.valueOf(1);
 
   }
 


Reply via email to