From bed4d635f8220682ad6c1a0029defe74aefef515 Mon Sep 17 00:00:00 2001 From: Stephen Sigwart Date: Thu, 22 Aug 2019 22:38:59 -0400 Subject: [PATCH] Don't let PSR4 CodeIntelError kill a lookup --- src/codeintel/lib/codeintel2/tree_php.py | 33 ++++++++++++++---------- 1 file changed, 20 insertions(+), 13 deletions(-) diff --git a/src/codeintel/lib/codeintel2/tree_php.py b/src/codeintel/lib/codeintel2/tree_php.py index b734b80157..f310814e03 100644 --- a/src/codeintel/lib/codeintel2/tree_php.py +++ b/src/codeintel/lib/codeintel2/tree_php.py @@ -551,7 +551,10 @@ def _classes_from_scope(self, expr, scoperef, allowGlobalClasses=False): and child.get("symbol"): module = "\\%s\\%s" % (child.get("module"), child.get("symbol")) self.attemptingPSR4Autoloading = True - elem, scope = self._hit_from_citdl(module, scoperef) + try: + elem, scope = self._hit_from_citdl(module, scoperef) + except CodeIntelError: + elem = None self.attemptingPSR4Autoloading = False if elem and scope: for subelem in elem: @@ -1268,19 +1271,23 @@ def _hits_from_first_part(self, tokens, scoperef): if expr not in attempted_psr4_exprs: attempted_psr4_exprs[expr] = True self.attemptingPSR4Autoloading = True - hit = self._hit_from_citdl(expr, scoperef) + try: + hit = self._hit_from_citdl(expr, scoperef) + except CodeIntelError: + hit = None self.attemptingPSR4Autoloading = False - found_elem, scope = hit - if found_elem and scope and \ - found_elem.get("ilk") == "class": - # TODO: technically PSR-4 requires only one class - # per file. Ideally we'd check for that here, but - # that's a bit more work that may not be worth it. - class_name = found_elem.get("name") - file_name = scope[0].get("name") - if file_name.endswith(".php") \ - and file_name.startswith(class_name + "."): - return ([hit], 1) + if hit: + found_elem, scope = hit + if found_elem and scope and \ + found_elem.get("ilk") == "class": + # TODO: technically PSR-4 requires only one class + # per file. Ideally we'd check for that here, but + # that's a bit more work that may not be worth it. + class_name = found_elem.get("name") + file_name = scope[0].get("name") + if file_name.endswith(".php") \ + and file_name.startswith(class_name + "."): + return ([hit], 1) else: if "\\" not in first_token and elem.get("ilk") == "namespace": self.log("_hits_from_first_part:: checking for a FQN hit")