KEMBAR78
feat: new mypyc primitive for weakref.ref by BobTheBuidler · Pull Request #19099 · python/mypy · GitHub
Skip to content

Conversation

@BobTheBuidler
Copy link
Contributor

@BobTheBuidler BobTheBuidler commented May 16, 2025

This PR adds a new mypyc primitive for weakref.ref

I wasn't able to figure out what name mypyc expects for weakref.proxy, so I took that out and will keep that for a separate PR later on. ref is more commonly used than proxy anyway.

for later, I tried:

  • weakref.proxy
  • weakref.ProxyType
  • weakref.weakproxy

no luck with those

also for later, I'll need to finish #19145 to add a primitive for weakref.ref.__call__

@BobTheBuidler
Copy link
Contributor Author

BobTheBuidler commented May 17, 2025

Done. This just needs tests now.

  • tests

@BobTheBuidler BobTheBuidler force-pushed the patch-3 branch 3 times, most recently from e4485d1 to 97f9186 Compare May 23, 2025 23:40
@BobTheBuidler BobTheBuidler changed the title feat: mypyc weakref_ops.py feat: new mypyc primitive for weakref.ref May 23, 2025
@BobTheBuidler BobTheBuidler marked this pull request as ready for review May 23, 2025 23:57
@BobTheBuidler
Copy link
Contributor Author

BobTheBuidler commented May 24, 2025

@JukkaL I've cleaned up the commit history and this is now ready for review.

Copy link
Collaborator

@JukkaL JukkaL left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the PR! Left a suggestion about how to make this more general.

@BobTheBuidler
Copy link
Contributor Author

BobTheBuidler commented Jun 2, 2025 via email

@BobTheBuidler
Copy link
Contributor Author

@JukkaL I know I said I'd do it later this week, but I've already finished. This is ready for review.

@JukkaL
Copy link
Collaborator

JukkaL commented Jun 3, 2025

Any thoughts on how I might determine the correct fullname for
weakref.proxy so I can handle that with both cases (1- and 2-arg) at the
same time?

You can look at how it's defined in mypy/typeshed/stdlib/weakref.pyi. You can also print the fullname of the relevant mypy AST node e.g. in some visitor (visit_member_expr).

@BobTheBuidler
Copy link
Contributor Author

hmm. It shows ProxyType in the typeshed though that wasn't working for me before. Let me try this again

@BobTheBuidler
Copy link
Contributor Author

It didn't work. I'll keep working on proxy in #19217 , this one is ready to merge if you agree

@BobTheBuidler
Copy link
Contributor Author

BobTheBuidler commented Jun 3, 2025

I got it to work for weakref.proxy on #19217. The C code generates correctly but I believe I've exposed a bug in mypyc's reference counting as my new pytest cases fail both with the new code and with the original builtin. The weakly-proxied object is being destroyed too early, while there should still be a strong reference to it.

@BobTheBuidler
Copy link
Contributor Author

@JukkaL Any other changes you want to see to this one before merging? Thanks for your assistance helping me figure out the above.

@BobTheBuidler
Copy link
Contributor Author

uh-oh, the tests started to fail after I merged in recent changes to master. Looks like there was a regression of some sort.

@github-actions

This comment has been minimized.

2 similar comments
@github-actions

This comment has been minimized.

@github-actions
Copy link
Contributor

github-actions bot commented Jul 9, 2025

According to mypy_primer, this change doesn't affect type check results on a corpus of open source code. ✅

@BobTheBuidler
Copy link
Contributor Author

Great, I got it working! Merging this will resolve mypyc/mypyc#1116

@BobTheBuidler BobTheBuidler requested a review from JukkaL July 20, 2025 16:51
@BobTheBuidler
Copy link
Contributor Author

@ilevkivskyi Could I trouble you for a review on this one as well? My other weakref PRs build on top of this and would be much easier to finish up / review once this one is merged in

Copy link
Member

@ilevkivskyi ilevkivskyi left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LG, but you should rewrite the run test.

@BobTheBuidler
Copy link
Contributor Author

fixed

@ilevkivskyi ilevkivskyi merged commit 07d4a1b into python:master Jul 31, 2025
13 checks passed
@BobTheBuidler BobTheBuidler deleted the patch-3 branch August 4, 2025 02:33
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants