You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@uima.apache.org by pk...@apache.org on 2019/11/08 16:18:26 UTC

svn commit: r1869575 - /uima/ruta/trunk/ruta-ep-ide-ui/src/main/java/org/apache/uima/ruta/ide/ui/editor/ReferenceFinder.java

Author: pkluegl
Date: Fri Nov  8 16:18:25 2019
New Revision: 1869575

URL: http://svn.apache.org/viewvc?rev=1869575&view=rev
Log:
UIMA-4676: semantic highlighting ignores implicit features

Modified:
    uima/ruta/trunk/ruta-ep-ide-ui/src/main/java/org/apache/uima/ruta/ide/ui/editor/ReferenceFinder.java

Modified: uima/ruta/trunk/ruta-ep-ide-ui/src/main/java/org/apache/uima/ruta/ide/ui/editor/ReferenceFinder.java
URL: http://svn.apache.org/viewvc/uima/ruta/trunk/ruta-ep-ide-ui/src/main/java/org/apache/uima/ruta/ide/ui/editor/ReferenceFinder.java?rev=1869575&r1=1869574&r2=1869575&view=diff
==============================================================================
--- uima/ruta/trunk/ruta-ep-ide-ui/src/main/java/org/apache/uima/ruta/ide/ui/editor/ReferenceFinder.java (original)
+++ uima/ruta/trunk/ruta-ep-ide-ui/src/main/java/org/apache/uima/ruta/ide/ui/editor/ReferenceFinder.java Fri Nov  8 16:18:25 2019
@@ -22,6 +22,8 @@ package org.apache.uima.ruta.ide.ui.edit
 import java.util.ArrayList;
 import java.util.List;
 
+import org.apache.commons.lang3.StringUtils;
+import org.apache.uima.ruta.UIMAConstants;
 import org.apache.uima.ruta.ide.parser.ast.ActionFactory;
 import org.apache.uima.ruta.ide.parser.ast.ComponentDeclaration;
 import org.apache.uima.ruta.ide.parser.ast.ComponentReference;
@@ -50,7 +52,7 @@ public class ReferenceFinder extends AST
       if (ActionFactory.IMPLICIT.equals(a.getName()) && !a.getChilds().isEmpty()) {
         ASTNode expression = a.getChilds().get(0);
         if (expression != null && !expression.getChilds().isEmpty()) {
-          return (ASTNode) expression.getChilds().get(0);
+          return expression.getChilds().get(0);
         }
       }
     }
@@ -59,7 +61,7 @@ public class ReferenceFinder extends AST
       if (ConditionFactory.IMPLICIT.equals(c.getName()) && !c.getChilds().isEmpty()) {
         ASTNode expression = c.getChilds().get(0);
         if (expression != null && !expression.getChilds().isEmpty()) {
-          return (ASTNode) expression.getChilds().get(0);
+          return expression.getChilds().get(0);
         }
       }
     }
@@ -71,7 +73,7 @@ public class ReferenceFinder extends AST
     if (s instanceof RutaVariableReference && node instanceof RutaVariableReference) {
       RutaVariableReference vr0 = (RutaVariableReference) node;
       RutaVariableReference vr1 = (RutaVariableReference) s;
-      if (vr1.getStringRepresentation().equals(vr0.getStringRepresentation())
+      if (compare(vr1.getStringRepresentation(), vr0.getStringRepresentation())
               && vr1.getType() == vr0.getType()) {
         result.add(s);
       }
@@ -80,19 +82,19 @@ public class ReferenceFinder extends AST
     } else if (s instanceof ComponentReference && node instanceof ComponentReference) {
       ComponentReference cr1 = (ComponentReference) node;
       ComponentReference cr2 = (ComponentReference) s;
-      if (cr1.getName().equals(cr2.getName())) {
+      if (compare(cr1.getName(), cr2.getName())) {
         result.add(s);
       }
     } else if (s instanceof RutaAction && node instanceof RutaAction) {
       RutaAction a1 = (RutaAction) node;
       RutaAction a2 = (RutaAction) s;
-      if (a1.getName().equals(a2.getName())) {
+      if (compare(a1.getName(), a2.getName())) {
         result.add(s);
       }
     } else if (s instanceof RutaCondition && node instanceof RutaCondition) {
       RutaCondition c1 = (RutaCondition) node;
       RutaCondition c2 = (RutaCondition) s;
-      if (c1.getName().equals(c2.getName())) {
+      if (compare(c1.getName(), c2.getName())) {
         result.add(s);
       }
 
@@ -100,6 +102,23 @@ public class ReferenceFinder extends AST
     return super.visit(s);
   }
 
+  private boolean compare(String mention1, String mention2) {
+
+    return StringUtils.equals(reduce(mention1), reduce(mention2));
+  }
+
+  private String reduce(String mention) {
+    if (mention.indexOf('.') > 0) {
+      if (mention.endsWith("." + UIMAConstants.FEATURE_TYPE)
+              || mention.endsWith("." + UIMAConstants.FEATURE_COVERED_TEXT)
+              || mention.endsWith("." + UIMAConstants.FEATURE_COVERED_TEXT_SHORT)) {
+        int lastIndexOf = mention.lastIndexOf('.');
+        mention = mention.substring(0, lastIndexOf);
+      }
+    }
+    return mention;
+  }
+
   public List<ASTNode> getResult() {
     return result;
   }