René's URL Explorer Experiment


Title: Fix exception refcnt by BadSingleton · Pull Request #1402 · pythonnet/pythonnet · GitHub

Open Graph Title: Fix exception refcnt by BadSingleton · Pull Request #1402 · pythonnet/pythonnet

X Title: Fix exception refcnt by BadSingleton · Pull Request #1402 · pythonnet/pythonnet

Description: What does this implement/fix? Explain your changes. Adds a tp_dealloc function to ExceptionClassObject, so we clean the BaseException members the same way as other the derived exceptions in the cpython code does. Does this close any currently open issues? Fixes issue #1371. Any other comments? Fixes a bug where C# Exceptions set as the Inner of another C# Exception, then converted into a Python exception object (and thus having __cause__ set to a valid object) would leak the Inner/__cause__ objects. Simplified diagram : AggregateException.Inner -> ArgumentException(...) ^ ^ | | PyAggregateException.__cause__ -> PyArgumentException In this case, where the AggregateException would be thrown from C# and caught in Python, the AggregateException and PyAggregateException would be freed, but not the ArgumentException set as the cause. Checklist Check all those that are applicable and complete. Make sure to include one or more tests for your change If an enhancement PR, please create docs and at best an example Add yourself to AUTHORS Updated the CHANGELOG

Open Graph Description: What does this implement/fix? Explain your changes. Adds a tp_dealloc function to ExceptionClassObject, so we clean the BaseException members the same way as other the derived exceptions in the cpy...

X Description: What does this implement/fix? Explain your changes. Adds a tp_dealloc function to ExceptionClassObject, so we clean the BaseException members the same way as other the derived exceptions in the cpy...

Opengraph URL: https://github.com/pythonnet/pythonnet/pull/1402

X: @github

direct link

Domain: github.com

route-pattern/:user_id/:repository/pull/:id/files(.:format)
route-controllerpull_requests
route-actionfiles
fetch-noncev2:864e5c16-468d-abaf-38a3-8d0fc5e76ed6
current-catalog-service-hashae870bc5e265a340912cde392f23dad3671a0a881730ffdadd82f2f57d81641b
request-id8098:3AD658:17A2E:1E4CE:69736A8F
html-safe-nonce90cc308258f2f32d74256b4663c64f8296fac8a17c4aba16565955df83c18675
visitor-payloadeyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI4MDk4OjNBRDY1ODoxN0EyRToxRTRDRTo2OTczNkE4RiIsInZpc2l0b3JfaWQiOiIyMDU4MjQyODA2NDA3OTgxNzExIiwicmVnaW9uX2VkZ2UiOiJpYWQiLCJyZWdpb25fcmVuZGVyIjoiaWFkIn0=
visitor-hmac9edf53f6ab28edba4db5adb4ec45d8df3c4ecc79a4345d6fc2b5f198a8835580
hovercard-subject-tagpull_request:582112943
github-keyboard-shortcutsrepository,pull-request-list,pull-request-conversation,pull-request-files-changed,copilot
google-site-verificationApib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I
octolytics-urlhttps://collector.github.com/github/collect
analytics-location///pull_requests/show/files
fb:app_id1401488693436528
apple-itunes-appapp-id=1477376905, app-argument=https://github.com/pythonnet/pythonnet/pull/1402/files
twitter:imagehttps://avatars.githubusercontent.com/u/6788684?s=400&v=4
twitter:cardsummary_large_image
og:imagehttps://avatars.githubusercontent.com/u/6788684?s=400&v=4
og:image:altWhat does this implement/fix? Explain your changes. Adds a tp_dealloc function to ExceptionClassObject, so we clean the BaseException members the same way as other the derived exceptions in the cpy...
og:site_nameGitHub
og:typeobject
hostnamegithub.com
expected-hostnamegithub.com
None4cf879a11b0a28a85543899a36aaee9ec9ca2fb7bedad86c0da5731193c95f01
turbo-cache-controlno-preview
diff-viewunified
go-importgithub.com/pythonnet/pythonnet git https://github.com/pythonnet/pythonnet.git
octolytics-dimension-user_id6050430
octolytics-dimension-user_loginpythonnet
octolytics-dimension-repository_id14748123
octolytics-dimension-repository_nwopythonnet/pythonnet
octolytics-dimension-repository_publictrue
octolytics-dimension-repository_is_forkfalse
octolytics-dimension-repository_network_root_id14748123
octolytics-dimension-repository_network_root_nwopythonnet/pythonnet
turbo-body-classeslogged-out env-production page-responsive full-width
disable-turbotrue
browser-stats-urlhttps://api.github.com/_private/browser/stats
browser-errors-urlhttps://api.github.com/_private/browser/errors
releasefe8be790582ef7a55477ce1918ac0ed16b106d31
ui-targetfull
theme-color#1e2327
color-schemelight dark

Links:

Skip to contenthttps://github.com/pythonnet/pythonnet/pull/1402/files#start-of-content
https://github.com/
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fpythonnet%2Fpythonnet%2Fpull%2F1402%2Ffiles
GitHub CopilotWrite better code with AIhttps://github.com/features/copilot
GitHub SparkBuild and deploy intelligent appshttps://github.com/features/spark
GitHub ModelsManage and compare promptshttps://github.com/features/models
MCP RegistryNewIntegrate external toolshttps://github.com/mcp
ActionsAutomate any workflowhttps://github.com/features/actions
CodespacesInstant dev environmentshttps://github.com/features/codespaces
IssuesPlan and track workhttps://github.com/features/issues
Code ReviewManage code changeshttps://github.com/features/code-review
GitHub Advanced SecurityFind and fix vulnerabilitieshttps://github.com/security/advanced-security
Code securitySecure your code as you buildhttps://github.com/security/advanced-security/code-security
Secret protectionStop leaks before they starthttps://github.com/security/advanced-security/secret-protection
Why GitHubhttps://github.com/why-github
Documentationhttps://docs.github.com
Bloghttps://github.blog
Changeloghttps://github.blog/changelog
Marketplacehttps://github.com/marketplace
View all featureshttps://github.com/features
Enterpriseshttps://github.com/enterprise
Small and medium teamshttps://github.com/team
Startupshttps://github.com/enterprise/startups
Nonprofitshttps://github.com/solutions/industry/nonprofits
App Modernizationhttps://github.com/solutions/use-case/app-modernization
DevSecOpshttps://github.com/solutions/use-case/devsecops
DevOpshttps://github.com/solutions/use-case/devops
CI/CDhttps://github.com/solutions/use-case/ci-cd
View all use caseshttps://github.com/solutions/use-case
Healthcarehttps://github.com/solutions/industry/healthcare
Financial serviceshttps://github.com/solutions/industry/financial-services
Manufacturinghttps://github.com/solutions/industry/manufacturing
Governmenthttps://github.com/solutions/industry/government
View all industrieshttps://github.com/solutions/industry
View all solutionshttps://github.com/solutions
AIhttps://github.com/resources/articles?topic=ai
Software Developmenthttps://github.com/resources/articles?topic=software-development
DevOpshttps://github.com/resources/articles?topic=devops
Securityhttps://github.com/resources/articles?topic=security
View all topicshttps://github.com/resources/articles
Customer storieshttps://github.com/customer-stories
Events & webinarshttps://github.com/resources/events
Ebooks & reportshttps://github.com/resources/whitepapers
Business insightshttps://github.com/solutions/executive-insights
GitHub Skillshttps://skills.github.com
Documentationhttps://docs.github.com
Customer supporthttps://support.github.com
Community forumhttps://github.com/orgs/community/discussions
Trust centerhttps://github.com/trust-center
Partnershttps://github.com/partners
GitHub SponsorsFund open source developershttps://github.com/sponsors
Security Labhttps://securitylab.github.com
Maintainer Communityhttps://maintainers.github.com
Acceleratorhttps://github.com/accelerator
Archive Programhttps://archiveprogram.github.com
Topicshttps://github.com/topics
Trendinghttps://github.com/trending
Collectionshttps://github.com/collections
Enterprise platformAI-powered developer platformhttps://github.com/enterprise
GitHub Advanced SecurityEnterprise-grade security featureshttps://github.com/security/advanced-security
Copilot for BusinessEnterprise-grade AI featureshttps://github.com/features/copilot/copilot-business
Premium SupportEnterprise-grade 24/7 supporthttps://github.com/premium-support
Pricinghttps://github.com/pricing
Search syntax tipshttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
documentationhttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fpythonnet%2Fpythonnet%2Fpull%2F1402%2Ffiles
Sign up https://github.com/signup?ref_cta=Sign+up&ref_loc=header+logged+out&ref_page=%2F%3Cuser-name%3E%2F%3Crepo-name%3E%2Fpull_requests%2Fshow%2Ffiles&source=header-repo&source_repo=pythonnet%2Fpythonnet
Reloadhttps://github.com/pythonnet/pythonnet/pull/1402/files
Reloadhttps://github.com/pythonnet/pythonnet/pull/1402/files
Reloadhttps://github.com/pythonnet/pythonnet/pull/1402/files
pythonnet https://github.com/pythonnet
pythonnethttps://github.com/pythonnet/pythonnet
Notifications https://github.com/login?return_to=%2Fpythonnet%2Fpythonnet
Fork 769 https://github.com/login?return_to=%2Fpythonnet%2Fpythonnet
Star 5.4k https://github.com/login?return_to=%2Fpythonnet%2Fpythonnet
Code https://github.com/pythonnet/pythonnet
Issues 155 https://github.com/pythonnet/pythonnet/issues
Pull requests 18 https://github.com/pythonnet/pythonnet/pulls
Discussions https://github.com/pythonnet/pythonnet/discussions
Actions https://github.com/pythonnet/pythonnet/actions
Projects 0 https://github.com/pythonnet/pythonnet/projects
Wiki https://github.com/pythonnet/pythonnet/wiki
Security 0 https://github.com/pythonnet/pythonnet/security
Insights https://github.com/pythonnet/pythonnet/pulse
Code https://github.com/pythonnet/pythonnet
Issues https://github.com/pythonnet/pythonnet/issues
Pull requests https://github.com/pythonnet/pythonnet/pulls
Discussions https://github.com/pythonnet/pythonnet/discussions
Actions https://github.com/pythonnet/pythonnet/actions
Projects https://github.com/pythonnet/pythonnet/projects
Wiki https://github.com/pythonnet/pythonnet/wiki
Security https://github.com/pythonnet/pythonnet/security
Insights https://github.com/pythonnet/pythonnet/pulse
Sign up for GitHub https://github.com/signup?return_to=%2Fpythonnet%2Fpythonnet%2Fissues%2Fnew%2Fchoose
terms of servicehttps://docs.github.com/terms
privacy statementhttps://docs.github.com/privacy
Sign inhttps://github.com/login?return_to=%2Fpythonnet%2Fpythonnet%2Fissues%2Fnew%2Fchoose
BadSingletonhttps://github.com/BadSingleton
pythonnet:masterhttps://github.com/pythonnet/pythonnet/tree/master
Unity-Technologies:fix-exception-refcnthttps://github.com/Unity-Technologies/pythonnet/tree/fix-exception-refcnt
Conversation 26 https://github.com/pythonnet/pythonnet/pull/1402
Commits 6 https://github.com/pythonnet/pythonnet/pull/1402/commits
Checks 0 https://github.com/pythonnet/pythonnet/pull/1402/checks
Files changed https://github.com/pythonnet/pythonnet/pull/1402/files
Please reload this pagehttps://github.com/pythonnet/pythonnet/pull/1402/files
Fix exception refcnt https://github.com/pythonnet/pythonnet/pull/1402/files#top
Show all changes 6 commits https://github.com/pythonnet/pythonnet/pull/1402/files
ee30c94 Fix a ref count issue in PythonException BadSingleton Feb 11, 2021 https://github.com/pythonnet/pythonnet/pull/1402/commits/ee30c94a5814150fb94d0892f5d909d102dc7b55
480a549 Fixes a leak in ExceptionClassObject BadSingleton Feb 26, 2021 https://github.com/pythonnet/pythonnet/pull/1402/commits/480a5498dd1b518999a183f9ada06e95a6616ec6
5ea9c3c Code review fixes BadSingleton Mar 4, 2021 https://github.com/pythonnet/pythonnet/pull/1402/commits/5ea9c3ca63ecbaf8a6c39142a4d0fb73b006918c
891ad8c code review fixes BadSingleton Mar 5, 2021 https://github.com/pythonnet/pythonnet/pull/1402/commits/891ad8c93afba36499b777b5140a388cb70e9d6a
d180f2a kick the build BadSingleton Mar 8, 2021 https://github.com/pythonnet/pythonnet/pull/1402/commits/d180f2a7977f1a9e4edc1a17defdd06bc283c16d
47290ee kick the build, again BadSingleton Mar 8, 2021 https://github.com/pythonnet/pythonnet/pull/1402/commits/47290ee7e3f84f265e7577eda5719e5cd613cc3f
Clear filters https://github.com/pythonnet/pythonnet/pull/1402/files
Please reload this pagehttps://github.com/pythonnet/pythonnet/pull/1402/files
Please reload this pagehttps://github.com/pythonnet/pythonnet/pull/1402/files
test_domain_reload.py https://github.com/pythonnet/pythonnet/pull/1402/files#diff-b6780a58c4e12c47dbf651598a3f535025062cbc896fef0dadd822a883b85f43
classbase.cs https://github.com/pythonnet/pythonnet/pull/1402/files#diff-32bee523619b42a59c7c60132a7d605f738b74bf85b7288552d57b6dd03c96d0
clrobject.cs https://github.com/pythonnet/pythonnet/pull/1402/files#diff-5d6160b3685501be659d3d53862856535c0548337eb77c5fc4bf2e0a3d552228
exceptions.cs https://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
importhook.cs https://github.com/pythonnet/pythonnet/pull/1402/files#diff-a3519b110d7c58f117c82c3d4d5c1b4de9d1217504801b64a0476ddc50270ea1
exceptiontest.cs https://github.com/pythonnet/pythonnet/pull/1402/files#diff-9fdb2679e27b27f3c52085e2a9670ded7fc7d17bbc6f8d61c4e89491b1a758ab
test_exceptions.py https://github.com/pythonnet/pythonnet/pull/1402/files#diff-f46006e3f43ffb1dd5d6862005427f6620f4dcfb1fa2f883d8482550069eeecc
src/domain_tests/test_domain_reload.pyhttps://github.com/pythonnet/pythonnet/pull/1402/files#diff-b6780a58c4e12c47dbf651598a3f535025062cbc896fef0dadd822a883b85f43
View file https://github.com/Unity-Technologies/pythonnet/blob/47290ee7e3f84f265e7577eda5719e5cd613cc3f/src/domain_tests/test_domain_reload.py
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/pythonnet/pythonnet/pull/1402/{{ revealButtonHref }}
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-b6780a58c4e12c47dbf651598a3f535025062cbc896fef0dadd822a883b85f43
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-b6780a58c4e12c47dbf651598a3f535025062cbc896fef0dadd822a883b85f43
src/runtime/classbase.cshttps://github.com/pythonnet/pythonnet/pull/1402/files#diff-32bee523619b42a59c7c60132a7d605f738b74bf85b7288552d57b6dd03c96d0
View file https://github.com/Unity-Technologies/pythonnet/blob/47290ee7e3f84f265e7577eda5719e5cd613cc3f/src/runtime/classbase.cs
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/pythonnet/pythonnet/pull/1402/{{ revealButtonHref }}
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-32bee523619b42a59c7c60132a7d605f738b74bf85b7288552d57b6dd03c96d0
src/runtime/clrobject.cshttps://github.com/pythonnet/pythonnet/pull/1402/files#diff-5d6160b3685501be659d3d53862856535c0548337eb77c5fc4bf2e0a3d552228
View file https://github.com/Unity-Technologies/pythonnet/blob/47290ee7e3f84f265e7577eda5719e5cd613cc3f/src/runtime/clrobject.cs
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/pythonnet/pythonnet/pull/1402/{{ revealButtonHref }}
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-5d6160b3685501be659d3d53862856535c0548337eb77c5fc4bf2e0a3d552228
src/runtime/exceptions.cshttps://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
View file https://github.com/Unity-Technologies/pythonnet/blob/47290ee7e3f84f265e7577eda5719e5cd613cc3f/src/runtime/exceptions.cs
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/pythonnet/pythonnet/pull/1402/{{ revealButtonHref }}
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-d8671ce7630fc9163c6732cfe4309cc3ccb1089b33d7e9809d516f809fc36eb2
src/runtime/importhook.cshttps://github.com/pythonnet/pythonnet/pull/1402/files#diff-a3519b110d7c58f117c82c3d4d5c1b4de9d1217504801b64a0476ddc50270ea1
View file https://github.com/Unity-Technologies/pythonnet/blob/47290ee7e3f84f265e7577eda5719e5cd613cc3f/src/runtime/importhook.cs
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/pythonnet/pythonnet/pull/1402/{{ revealButtonHref }}
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-a3519b110d7c58f117c82c3d4d5c1b4de9d1217504801b64a0476ddc50270ea1
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-a3519b110d7c58f117c82c3d4d5c1b4de9d1217504801b64a0476ddc50270ea1
src/testing/exceptiontest.cshttps://github.com/pythonnet/pythonnet/pull/1402/files#diff-9fdb2679e27b27f3c52085e2a9670ded7fc7d17bbc6f8d61c4e89491b1a758ab
View file https://github.com/Unity-Technologies/pythonnet/blob/47290ee7e3f84f265e7577eda5719e5cd613cc3f/src/testing/exceptiontest.cs
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/pythonnet/pythonnet/pull/1402/{{ revealButtonHref }}
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-9fdb2679e27b27f3c52085e2a9670ded7fc7d17bbc6f8d61c4e89491b1a758ab
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-9fdb2679e27b27f3c52085e2a9670ded7fc7d17bbc6f8d61c4e89491b1a758ab
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-9fdb2679e27b27f3c52085e2a9670ded7fc7d17bbc6f8d61c4e89491b1a758ab
tests/test_exceptions.pyhttps://github.com/pythonnet/pythonnet/pull/1402/files#diff-f46006e3f43ffb1dd5d6862005427f6620f4dcfb1fa2f883d8482550069eeecc
View file https://github.com/Unity-Technologies/pythonnet/blob/47290ee7e3f84f265e7577eda5719e5cd613cc3f/tests/test_exceptions.py
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/pythonnet/pythonnet/pull/1402/{{ revealButtonHref }}
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-f46006e3f43ffb1dd5d6862005427f6620f4dcfb1fa2f883d8482550069eeecc
Please reload this pagehttps://github.com/pythonnet/pythonnet/pull/1402/files
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-f46006e3f43ffb1dd5d6862005427f6620f4dcfb1fa2f883d8482550069eeecc
https://github.com/pythonnet/pythonnet/pull/1402/files#diff-f46006e3f43ffb1dd5d6862005427f6620f4dcfb1fa2f883d8482550069eeecc
https://github.com
Termshttps://docs.github.com/site-policy/github-terms/github-terms-of-service
Privacyhttps://docs.github.com/site-policy/privacy-policies/github-privacy-statement
Securityhttps://github.com/security
Statushttps://www.githubstatus.com/
Communityhttps://github.community/
Docshttps://docs.github.com/
Contacthttps://support.github.com?tags=dotcom-footer

Viewport: width=device-width


URLs of crawlers that visited me.