diff --git a/app/src/main/java/org/jd/gui/controller/SearchInConstantPoolsController.java b/app/src/main/java/org/jd/gui/controller/SearchInConstantPoolsController.java index d0f9701c..d87182ba 100644 --- a/app/src/main/java/org/jd/gui/controller/SearchInConstantPoolsController.java +++ b/app/src/main/java/org/jd/gui/controller/SearchInConstantPoolsController.java @@ -291,15 +291,17 @@ protected void match(Indexes indexes, String indexName, String pattern, if (matchedEntries == null) { Map index = indexes.getIndex(indexName); - if (patternLength == 1) { - matchedEntries = matchWithCharFunction.apply(pattern.charAt(0), index); - } else { - String lastKey = key.substring(0, key.length() - 1); - Map lastMatchedTypes = cache.get(lastKey); - if (lastMatchedTypes != null) { - matchedEntries = matchWithStringFunction.apply(pattern, lastMatchedTypes); + if (index != null) { + if (patternLength == 1) { + matchedEntries = matchWithCharFunction.apply(pattern.charAt(0), index); } else { - matchedEntries = matchWithStringFunction.apply(pattern, index); + String lastKey = key.substring(0, key.length() - 1); + Map lastMatchedTypes = cache.get(lastKey); + if (lastMatchedTypes != null) { + matchedEntries = matchWithStringFunction.apply(pattern, lastMatchedTypes); + } else { + matchedEntries = matchWithStringFunction.apply(pattern, index); + } } } diff --git a/app/src/main/java/org/jd/gui/view/SearchInConstantPoolsView.java b/app/src/main/java/org/jd/gui/view/SearchInConstantPoolsView.java index d6f4de82..ab9258a2 100644 --- a/app/src/main/java/org/jd/gui/view/SearchInConstantPoolsView.java +++ b/app/src/main/java/org/jd/gui/view/SearchInConstantPoolsView.java @@ -250,7 +250,6 @@ public SearchInConstantPoolsView( if (selectedTreeNode != null) { selectedTypeCallback.accept(selectedTreeNode.getUri(), searchInConstantPoolsEnterTextField.getText(), getFlags()); } - searchInConstantPoolsDialog.setVisible(false); } }; searchInConstantPoolsOpenButton.addActionListener(searchInConstantPoolsOpenActionListener);