diff --git a/php/php.editor/src/org/netbeans/modules/php/editor/completion/PHPCodeCompletion.java b/php/php.editor/src/org/netbeans/modules/php/editor/completion/PHPCodeCompletion.java index 93696a8bc4d3..5723150fb008 100644 --- a/php/php.editor/src/org/netbeans/modules/php/editor/completion/PHPCodeCompletion.java +++ b/php/php.editor/src/org/netbeans/modules/php/editor/completion/PHPCodeCompletion.java @@ -273,6 +273,8 @@ private static enum UseType { private static final List INHERITANCE_KEYWORDS = Arrays.asList(new String[]{"extends", "implements"}); //NOI18N private static final String EXCEPTION_CLASS_NAME = "\\Exception"; // NOI18N + private static final String ERROR_CLASS_NAME = "\\Error"; // NOI18N + private static final String THROWABLE_INTERFACE_NAME = "\\Throwable"; // NOI18N private static final List VALID_UNION_TYPE_TOKENS = Arrays.asList( PHPTokenId.WHITESPACE, PHPTokenId.PHP_STRING, PHPTokenId.PHP_NS_SEPARATOR, PHPTokenId.PHP_TYPE_BOOL, PHPTokenId.PHP_TYPE_FLOAT, PHPTokenId.PHP_TYPE_INT, PHPTokenId.PHP_TYPE_STRING, PHPTokenId.PHP_TYPE_VOID, @@ -891,7 +893,8 @@ private void autoCompleteExceptions(final PHPCompletionResult completionResult, if (CancelSupport.getDefault().isCancelled()) { return; } - if (isExceptionClass(classElement)) { + if (isExceptionClass(classElement) + || isErrorClass(classElement)) { completionResult.add(new PHPCompletionItem.ClassItem(classElement, request, false, null)); if (withConstructors) { constructorClassNames.add(classElement.getFullyQualifiedName()); @@ -904,7 +907,8 @@ private void autoCompleteExceptions(final PHPCompletionResult completionResult, if (CancelSupport.getDefault().isCancelled()) { return; } - if (isExceptionClass(inheritedClass)) { + if (isExceptionClass(inheritedClass) + || isErrorClass(inheritedClass)) { completionResult.add(new PHPCompletionItem.ClassItem(classElement, request, false, null)); if (withConstructors) { constructorClassNames.add(classElement.getFullyQualifiedName()); @@ -914,6 +918,13 @@ private void autoCompleteExceptions(final PHPCompletionResult completionResult, } } } + final Set interfaces = request.index.getInterfaces(nameQuery); + for (InterfaceElement interfaceElement : interfaces) { + if (isThrowableInterface(interfaceElement)) { + completionResult.add(new PHPCompletionItem.InterfaceItem(interfaceElement, request, false)); + break; + } + } for (QualifiedName qualifiedName : constructorClassNames) { if (CancelSupport.getDefault().isCancelled()) { return; @@ -926,6 +937,14 @@ private boolean isExceptionClass(ClassElement classElement) { return classElement.getFullyQualifiedName().toString().equals(EXCEPTION_CLASS_NAME); } + private boolean isErrorClass(ClassElement classElement) { + return classElement.getFullyQualifiedName().toString().equals(ERROR_CLASS_NAME); + } + + private boolean isThrowableInterface(InterfaceElement interfaceElement) { + return interfaceElement.getFullyQualifiedName().toString().equals(THROWABLE_INTERFACE_NAME); + } + private void autoCompleteClassNames(final PHPCompletionResult completionResult, PHPCompletionItem.CompletionRequest request, boolean endWithDoubleColon) { autoCompleteClassNames(completionResult, request, endWithDoubleColon, null); diff --git a/php/php.editor/test/unit/data/testfiles/completion/lib/gh7594/gh7594.php b/php/php.editor/test/unit/data/testfiles/completion/lib/gh7594/gh7594.php new file mode 100644 index 000000000000..ca87dd1291b5 --- /dev/null +++ b/php/php.editor/test/unit/data/testfiles/completion/lib/gh7594/gh7594.php @@ -0,0 +1,55 @@ +