From 4929ab2c2002f47117c0a516cac0635e76c38237 Mon Sep 17 00:00:00 2001 From: Josh Tynjala Date: Thu, 10 Jan 2019 14:12:36 -0800 Subject: [PATCH] language-server: fixed MXML completion in empty file for Flex projects that failed due to null reference error --- .../vscode/utils/MXMLNamespaceUtils.java | 32 +++++++++++-------- 1 file changed, 18 insertions(+), 14 deletions(-) diff --git a/language-server/src/main/java/com/as3mxml/vscode/utils/MXMLNamespaceUtils.java b/language-server/src/main/java/com/as3mxml/vscode/utils/MXMLNamespaceUtils.java index 2521a6d90..aebc372b3 100644 --- a/language-server/src/main/java/com/as3mxml/vscode/utils/MXMLNamespaceUtils.java +++ b/language-server/src/main/java/com/as3mxml/vscode/utils/MXMLNamespaceUtils.java @@ -173,22 +173,26 @@ private static boolean isPreferredNamespace(String tagNamespace, List ta } if (tagNamespace.equals(IMXMLLanguageConstants.NAMESPACE_MXML_2006)) { - String rootLanguageNamespace = mxmlData.getRootTag().getMXMLDialect().getLanguageNamespace(); - if(!rootLanguageNamespace.equals(tagNamespace)) + IMXMLTagData rootTag = mxmlData.getRootTag(); + if (rootTag != null) { - if(tagNamespaces.contains(IMXMLLibraryConstants.MX)) - { - //if we find the mxml 2006 language namepace, but - //we're using a newer language namespace, and the mx - //library also exists, we prefer the library - return false; - } - if(tagNamespaces.contains(rootLanguageNamespace)) + String rootLanguageNamespace = rootTag.getMXMLDialect().getLanguageNamespace(); + if(!rootLanguageNamespace.equals(tagNamespace)) { - //getTagNamesForClass() may sometimes return the - //mxml 2006 namespace, even if that's not what we're - //using in this file. - return false; + if(tagNamespaces.contains(IMXMLLibraryConstants.MX)) + { + //if we find the mxml 2006 language namepace, but + //we're using a newer language namespace, and the mx + //library also exists, we prefer the library + return false; + } + if(tagNamespaces.contains(rootLanguageNamespace)) + { + //getTagNamesForClass() may sometimes return the + //mxml 2006 namespace, even if that's not what we're + //using in this file. + return false; + } } } }