-
-
Notifications
You must be signed in to change notification settings - Fork 2.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Refurb crashes on Mypy 1.7.0 #16497
Comments
This issue is also of interest to Debian, so a hack to fix this (here and/or in refurb) would be appreciated! |
I definitely remember we wanted to allow this, but probably this is still not done. Anyway, an idea worth trying is to move |
I'm running into this issue as well - developed a plugin that makes use of |
same here, for https://github.com/pyastrx/pyastrx Have you found any workarounds? @mike-kaoudis-asimov @dosisod @mr-c |
Over at Debian? No, we didn't find any workaround and the refurb package got removed from Debian Testing due to that |
Ivan made a suggestion above (and Mike also suggested simply vendoring the visitor). If someone makes a PR, tag me and I'll review it. |
Sorry for your loss @mr-c 😢 I would recommend Pyre; it is very fast, but I was disappointed because they have now deprecated the only feature that was useful for me. Pyre Query Documentation. |
@hauntsaninja I don't get. The vendoring solution for this issue must be done in the refurb pacakge right? |
Ivan's suggestion above could be done in mypy. |
I ended up writing a new class with a very similar implementation to |
@JelleZijlstra I just made a search here, why this will not create the same issue in InspectionStubGenerator? |
Hmm maybe we could compile stubgen modules, so they wouldn't need to use interpreted subclasses? |
Or alternatively, would it help if we'd stop compiling |
Well, wouldn't it also be possible to have an ugly solution with duplicated code TraverserVisitor (with trait) and TraverserVisitorExt |
@devmessias Yeah, that would work, but some of the other ideas wouldn't require any code duplication. |
FWIW in my answer to this StackOverflow question of Is it possible to get the inferred type information using mypy programmatically?, I've worked around the issue of subclassing mypy classes using a custom meta path finder to skip mypy's C extension and load mypy's Python modules directly: import os
import sys
from importlib.util import spec_from_loader
from importlib.machinery import PathFinder, SourceFileLoader
class MypySourceFinder:
mypy_module_path, = PathFinder().find_spec('mypy').submodule_search_locations
def find_spec(self, fullname, path=None, target=None):
package, *names = fullname.split('.')
if package == 'mypy':
path = self.mypy_module_path
for name in names:
if not os.path.isdir(subpackage_path := os.path.join(path, name)):
break
path = subpackage_path
else:
name = '__init__'
return spec_from_loader(
fullname,
SourceFileLoader(fullname, os.path.join(path, name + '.py'))
)
sys.meta_path.insert(0, MypySourceFinder())
from mypy.nodes import Node
print(type(Node.__init__)) # outputs <class 'function'> rather than <class 'wrapper_descriptor'>
class MyNode(Node): ...
MyNode() # OK, not raising TypeError: interpreted classes cannot inherit from compiled |
The workaround aside, what is the reason, technical or conceptual, behind why these mypy classes have to explicitly disallow inheritance by interpreted subclasses in the first place? It otherwise seems like an unnecessary and artificial limitation to me. |
Bug Report
Refurb is a project that depends on Mypy internals to work properly. Since v1.7.0 of Mypy (specifically since #15770 was merged), Refurb no longer works, and instead emits the following error:
See also: dosisod/refurb#305
To Reproduce
Expected Behavior
Refurb doesn't crash.
Actual Behavior
Refurb is crashing.
Your Environment
Background
#15770 added a
@trait
decorator toTraverserVisitor
, meaning 3rd party (interpreted) programs can no longer inherit fromTraverserVisitor
:mypy/mypy/traverser.py
Lines 97 to 99 in c6cb3c6
I tried a bunch of different workarounds including making a custom
__new__
method, copy-and-pastingTraverserVisitor
into my code and removing the@trait
, but alas nothing is working, and so I had to pin Mypy to <= v1.6.1 in Refurb, which will prevent users from using the newest version of Mypy with Refurb. Using the non-compiled version of Mypy doesn't have this issue, but doing so would be far too slow, especially since Refurb parses/walks the full, fine-grained AST tree (similar to mypyd).My question: How should I get around this? Is there anything I can do on my end, or does something in Mypy have to change? I would think that
allow_interpreted_subclasses=True
would nullify the inheritance restriction imposed by@trait
, but that doesn't seem to be the case.There is also the bigger question of how 3rd parties should safely use Mypy internals (or if they even should in the first place). Currently Mypy internals are not versioned and can change with any release. In addition, certain parts of Mypy are hard/impossible to use outside of Mypy itself, whether that's because they don't work, crash, or require lots of moving parts because they weren't meant to be used in a stand-alone environment. I know that standardizing/stabilizing Mypy's internals so that 3rd parties can use them is probably not a major priority, but I thought I would bring it up to gauge how you all feel about it. I could elaborate more but I want to keep this short. I can open a separate issue for this if need be.
The text was updated successfully, but these errors were encountered: