Close fd/memory leak paths in pg_upgrade file/version probing#1
Draft
Copilot wants to merge 2 commits into
Draft
Close fd/memory leak paths in pg_upgrade file/version probing#1Copilot wants to merge 2 commits into
pg_upgrade file/version probing#1Copilot wants to merge 2 commits into
Conversation
|
Seems you are using me but didn't get OPENAI_API_KEY seted in Variables/Secrets for this repo. you could follow readme for more information |
Co-authored-by: yjhjstz <3832082+yjhjstz@users.noreply.github.com>
|
Seems you are using me but didn't get OPENAI_API_KEY seted in Variables/Secrets for this repo. you could follow readme for more information |
Copilot
AI
changed the title
[WIP] Fix fd leak and memory leak in code
Close fd/memory leak paths in Mar 18, 2026
pg_upgrade file/version probing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
针对“扫描代码中的 fd leak、memory leak”问题,此 PR 聚焦
pg_upgrade的高风险错误路径:在pg_fatal()退出前补齐资源清理,避免在失败分支遗留打开的文件描述符和堆内存。exec.c: hardenget_bin_version()pipe lifecyclepopen()与fgets()失败处理拆分,避免fgets()失败时跳过pclose()errno,保证%m错误信息不被 cleanup 覆盖file.c: close/free on all early-fatal branchescloneFile():dest_fd打开失败时关闭已打开的src_fdioctl(FICLONE)失败时关闭src_fd/dest_fd后再报错copyFile():dest_fd打开失败时关闭src_fdread()/write()失败时释放buffer并关闭src_fd/dest_fdcopyFileByRange():dest_fd打开失败时关闭src_fdcopy_file_range()失败时关闭src_fd/dest_fderrno语义,避免影响%m输出示例(错误路径清理模式)
📱 Kick off Copilot coding agent tasks wherever you are with GitHub Mobile, available on iOS and Android.