René's URL Explorer Experiment


Title: [WIP] Cache repository / owner values in persistent handle by srajko · Pull Request #962 · nodegit/nodegit · GitHub

Open Graph Title: [WIP] Cache repository / owner values in persistent handle by srajko · Pull Request #962 · nodegit/nodegit

X Title: [WIP] Cache repository / owner values in persistent handle by srajko · Pull Request #962 · nodegit/nodegit

Description: This works towards #955. Once we free repositories on wrapper GC, any object that can return a repository (for example, a GitCommit) can potentially return a freed repository. This PR adds persistent handles to any object that returns a repository. Once we enforce a 1-1 relationship between git_repository objects and GitRepository wrappers, this will ensure that the wrapper does not get GCd until all objects that can return the repository can get GCed as well. The stand-alone benefit of this PR is just that we don't create a new wrapper each time we return a repository from an object. Also, the caching mechanism might be helpful beyond holding a handle - we can extend it to cache any similar value and avoid calling into the libgit2 layer for sync functions (this can help with thread safety without requiring locking).

Open Graph Description: This works towards #955. Once we free repositories on wrapper GC, any object that can return a repository (for example, a GitCommit) can potentially return a freed repository. This PR adds persis...

X Description: This works towards #955. Once we free repositories on wrapper GC, any object that can return a repository (for example, a GitCommit) can potentially return a freed repository. This PR adds persis...

Opengraph URL: https://github.com/nodegit/nodegit/pull/962

X: @github

direct link

Domain: github.com

route-pattern/:user_id/:repository/pull/:id/files(.:format)
route-controllerpull_requests
route-actionfiles
fetch-noncev2:10255bc9-d12e-192d-2052-071ae676a17c
current-catalog-service-hashae870bc5e265a340912cde392f23dad3671a0a881730ffdadd82f2f57d81641b
request-idE2F0:3F18FE:3A6E911:4C00C91:6975052A
html-safe-noncede08329fdd0ee037f77216c7f8e54ee03199718f42c9546222e8a0844abddd4e
visitor-payloadeyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiJFMkYwOjNGMThGRTozQTZFOTExOjRDMDBDOTE6Njk3NTA1MkEiLCJ2aXNpdG9yX2lkIjoiMzIwNzYxOTI1Nzg5MzcxNzI5MCIsInJlZ2lvbl9lZGdlIjoiaWFkIiwicmVnaW9uX3JlbmRlciI6ImlhZCJ9
visitor-hmac5454df77e4b05b0ac630c0acc6a833d6691809b4bb5bd31439c07ebc97596b92
hovercard-subject-tagpull_request:63814835
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/nodegit/nodegit/pull/962/files
twitter:imagehttps://avatars.githubusercontent.com/u/291007?s=400&v=4
twitter:cardsummary_large_image
og:imagehttps://avatars.githubusercontent.com/u/291007?s=400&v=4
og:image:altThis works towards #955. Once we free repositories on wrapper GC, any object that can return a repository (for example, a GitCommit) can potentially return a freed repository. This PR adds persis...
og:site_nameGitHub
og:typeobject
hostnamegithub.com
expected-hostnamegithub.com
None4a4bf5f4e28041a9d2e5c107d7d20b78b4294ba261cab243b28167c16a623a1f
turbo-cache-controlno-preview
diff-viewunified
go-importgithub.com/nodegit/nodegit git https://github.com/nodegit/nodegit.git
octolytics-dimension-user_id657068
octolytics-dimension-user_loginnodegit
octolytics-dimension-repository_id1383170
octolytics-dimension-repository_nwonodegit/nodegit
octolytics-dimension-repository_publictrue
octolytics-dimension-repository_is_forkfalse
octolytics-dimension-repository_network_root_id1383170
octolytics-dimension-repository_network_root_nwonodegit/nodegit
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
release488b30e96dfd057fbbe44c6665ccbc030b729dde
ui-targetfull
theme-color#1e2327
color-schemelight dark

Links:

Skip to contenthttps://github.com/nodegit/nodegit/pull/962/files#start-of-content
https://github.com/
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fnodegit%2Fnodegit%2Fpull%2F962%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%2Fnodegit%2Fnodegit%2Fpull%2F962%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=nodegit%2Fnodegit
Reloadhttps://github.com/nodegit/nodegit/pull/962/files
Reloadhttps://github.com/nodegit/nodegit/pull/962/files
Reloadhttps://github.com/nodegit/nodegit/pull/962/files
nodegit https://github.com/nodegit
nodegithttps://github.com/nodegit/nodegit
Notifications https://github.com/login?return_to=%2Fnodegit%2Fnodegit
Fork 697 https://github.com/login?return_to=%2Fnodegit%2Fnodegit
Star 5.8k https://github.com/login?return_to=%2Fnodegit%2Fnodegit
Code https://github.com/nodegit/nodegit
Issues 343 https://github.com/nodegit/nodegit/issues
Pull requests 19 https://github.com/nodegit/nodegit/pulls
Actions https://github.com/nodegit/nodegit/actions
Projects 0 https://github.com/nodegit/nodegit/projects
Security 0 https://github.com/nodegit/nodegit/security
Insights https://github.com/nodegit/nodegit/pulse
Code https://github.com/nodegit/nodegit
Issues https://github.com/nodegit/nodegit/issues
Pull requests https://github.com/nodegit/nodegit/pulls
Actions https://github.com/nodegit/nodegit/actions
Projects https://github.com/nodegit/nodegit/projects
Security https://github.com/nodegit/nodegit/security
Insights https://github.com/nodegit/nodegit/pulse
Sign up for GitHub https://github.com/signup?return_to=%2Fnodegit%2Fnodegit%2Fissues%2Fnew%2Fchoose
terms of servicehttps://docs.github.com/terms
privacy statementhttps://docs.github.com/privacy
Sign inhttps://github.com/login?return_to=%2Fnodegit%2Fnodegit%2Fissues%2Fnew%2Fchoose
srajkohttps://github.com/srajko
nodegit:masterhttps://github.com/nodegit/nodegit/tree/master
srajko:cache-repositoryhttps://github.com/srajko/nodegit/tree/cache-repository
Conversation 7 https://github.com/nodegit/nodegit/pull/962
Commits 3 https://github.com/nodegit/nodegit/pull/962/commits
Checks 0 https://github.com/nodegit/nodegit/pull/962/checks
Files changed https://github.com/nodegit/nodegit/pull/962/files
Please reload this pagehttps://github.com/nodegit/nodegit/pull/962/files
[WIP] Cache repository / owner values in persistent handle https://github.com/nodegit/nodegit/pull/962/files#top
Show all changes 3 commits https://github.com/nodegit/nodegit/pull/962/files
b0f333b Cache repository sync return values srajko Mar 23, 2016 https://github.com/nodegit/nodegit/pull/962/commits/b0f333b0340c0b34c014519d9b26901766b2053a
c23d58f Add test for owner caching srajko Mar 23, 2016 https://github.com/nodegit/nodegit/pull/962/commits/c23d58fd62a1429d35bfcc1afdc9cf32879853d2
cd21a0f Pass id instead of object to createBranch srajko Mar 24, 2016 https://github.com/nodegit/nodegit/pull/962/commits/cd21a0f3421eea03821b14c18d2afa27ecf21350
Clear filters https://github.com/nodegit/nodegit/pull/962/files
Please reload this pagehttps://github.com/nodegit/nodegit/pull/962/files
Please reload this pagehttps://github.com/nodegit/nodegit/pull/962/files
descriptor.json https://github.com/nodegit/nodegit/pull/962/files#diff-ff00cd010b7df4b1f1cd901205bce54d2c39c0752d2ab09b09bbe4a2ead48bf2
helpers.js https://github.com/nodegit/nodegit/pull/962/files#diff-87cd1e2c8820a97d7fbc04f1591dff46ace455b38d9417854962707886e557f8
sync_function.cc https://github.com/nodegit/nodegit/pull/962/files#diff-7e46711f90e3a938b09d4bcdae2249b1b8811f3511280569536d86aa8ee250c6
class_content.cc https://github.com/nodegit/nodegit/pull/962/files#diff-28618c5cbab5c17f45ffad773d9ad5486ff9c7b8b31c916d53616c98c751daa1
class_header.h https://github.com/nodegit/nodegit/pull/962/files#diff-25ee49e4f3bdf45b52b23f17fb4fed35cd78702ba9e670d4f51cdfee3ae4296a
commit.js https://github.com/nodegit/nodegit/pull/962/files#diff-3b419ffc8348f4dcf124be8438ac97fb674f372518b8a17bb389d6a30779ac78
submodule.js https://github.com/nodegit/nodegit/pull/962/files#diff-1e09b469a05f822617e288bc8328b0a45489f344fbb76b760f73a0a5e80e0e5f
generate/input/descriptor.jsonhttps://github.com/nodegit/nodegit/pull/962/files#diff-ff00cd010b7df4b1f1cd901205bce54d2c39c0752d2ab09b09bbe4a2ead48bf2
View file https://github.com/srajko/nodegit/blob/cd21a0f3421eea03821b14c18d2afa27ecf21350/generate/input/descriptor.json
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/nodegit/nodegit/pull/962/{{ revealButtonHref }}
https://github.com/nodegit/nodegit/pull/962/files#diff-ff00cd010b7df4b1f1cd901205bce54d2c39c0752d2ab09b09bbe4a2ead48bf2
https://github.com/nodegit/nodegit/pull/962/files#diff-ff00cd010b7df4b1f1cd901205bce54d2c39c0752d2ab09b09bbe4a2ead48bf2
generate/scripts/helpers.jshttps://github.com/nodegit/nodegit/pull/962/files#diff-87cd1e2c8820a97d7fbc04f1591dff46ace455b38d9417854962707886e557f8
View file https://github.com/srajko/nodegit/blob/cd21a0f3421eea03821b14c18d2afa27ecf21350/generate/scripts/helpers.js
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/nodegit/nodegit/pull/962/{{ revealButtonHref }}
https://github.com/nodegit/nodegit/pull/962/files#diff-87cd1e2c8820a97d7fbc04f1591dff46ace455b38d9417854962707886e557f8
https://github.com/nodegit/nodegit/pull/962/files#diff-87cd1e2c8820a97d7fbc04f1591dff46ace455b38d9417854962707886e557f8
generate/templates/partials/sync_function.cchttps://github.com/nodegit/nodegit/pull/962/files#diff-7e46711f90e3a938b09d4bcdae2249b1b8811f3511280569536d86aa8ee250c6
View file https://github.com/srajko/nodegit/blob/cd21a0f3421eea03821b14c18d2afa27ecf21350/generate/templates/partials/sync_function.cc
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/nodegit/nodegit/pull/962/{{ revealButtonHref }}
https://github.com/nodegit/nodegit/pull/962/files#diff-7e46711f90e3a938b09d4bcdae2249b1b8811f3511280569536d86aa8ee250c6
https://github.com/nodegit/nodegit/pull/962/files#diff-7e46711f90e3a938b09d4bcdae2249b1b8811f3511280569536d86aa8ee250c6
https://github.com/nodegit/nodegit/pull/962/files#diff-7e46711f90e3a938b09d4bcdae2249b1b8811f3511280569536d86aa8ee250c6
https://github.com/nodegit/nodegit/pull/962/files#diff-7e46711f90e3a938b09d4bcdae2249b1b8811f3511280569536d86aa8ee250c6
https://github.com/nodegit/nodegit/pull/962/files#diff-7e46711f90e3a938b09d4bcdae2249b1b8811f3511280569536d86aa8ee250c6
generate/templates/templates/class_content.cchttps://github.com/nodegit/nodegit/pull/962/files#diff-28618c5cbab5c17f45ffad773d9ad5486ff9c7b8b31c916d53616c98c751daa1
View file https://github.com/srajko/nodegit/blob/cd21a0f3421eea03821b14c18d2afa27ecf21350/generate/templates/templates/class_content.cc
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/nodegit/nodegit/pull/962/{{ revealButtonHref }}
https://github.com/nodegit/nodegit/pull/962/files#diff-28618c5cbab5c17f45ffad773d9ad5486ff9c7b8b31c916d53616c98c751daa1
https://github.com/nodegit/nodegit/pull/962/files#diff-28618c5cbab5c17f45ffad773d9ad5486ff9c7b8b31c916d53616c98c751daa1
generate/templates/templates/class_header.hhttps://github.com/nodegit/nodegit/pull/962/files#diff-25ee49e4f3bdf45b52b23f17fb4fed35cd78702ba9e670d4f51cdfee3ae4296a
View file https://github.com/srajko/nodegit/blob/cd21a0f3421eea03821b14c18d2afa27ecf21350/generate/templates/templates/class_header.h
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/nodegit/nodegit/pull/962/{{ revealButtonHref }}
https://github.com/nodegit/nodegit/pull/962/files#diff-25ee49e4f3bdf45b52b23f17fb4fed35cd78702ba9e670d4f51cdfee3ae4296a
https://github.com/nodegit/nodegit/pull/962/files#diff-25ee49e4f3bdf45b52b23f17fb4fed35cd78702ba9e670d4f51cdfee3ae4296a
test/tests/commit.jshttps://github.com/nodegit/nodegit/pull/962/files#diff-3b419ffc8348f4dcf124be8438ac97fb674f372518b8a17bb389d6a30779ac78
View file https://github.com/srajko/nodegit/blob/cd21a0f3421eea03821b14c18d2afa27ecf21350/test/tests/commit.js
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/nodegit/nodegit/pull/962/{{ revealButtonHref }}
https://github.com/nodegit/nodegit/pull/962/files#diff-3b419ffc8348f4dcf124be8438ac97fb674f372518b8a17bb389d6a30779ac78
https://github.com/nodegit/nodegit/pull/962/files#diff-3b419ffc8348f4dcf124be8438ac97fb674f372518b8a17bb389d6a30779ac78
test/tests/submodule.jshttps://github.com/nodegit/nodegit/pull/962/files#diff-1e09b469a05f822617e288bc8328b0a45489f344fbb76b760f73a0a5e80e0e5f
View file https://github.com/srajko/nodegit/blob/cd21a0f3421eea03821b14c18d2afa27ecf21350/test/tests/submodule.js
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/nodegit/nodegit/pull/962/{{ revealButtonHref }}
https://github.com/nodegit/nodegit/pull/962/files#diff-1e09b469a05f822617e288bc8328b0a45489f344fbb76b760f73a0a5e80e0e5f
https://github.com/nodegit/nodegit/pull/962/files#diff-1e09b469a05f822617e288bc8328b0a45489f344fbb76b760f73a0a5e80e0e5f
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.