-
-
Notifications
You must be signed in to change notification settings - Fork 816
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
Cannot move source.tmp when installing package from git #2902
Comments
you can add
|
I don't know, maybe some other process is accessing this directory, you can check it. |
It seems that the problem is associated with Git. I cleared my Git config then reinstalled it, and it's fine. |
Please reopen this issue. I just ran into the same issue; I'm wondering why xmake clone a repository to xmake/xmake/modules/private/action/require/impl/actions/download.lua Lines 78 to 102 in 4139d07
I think it does nothing but making more errors, since git could occupy this folder, and the performance would suffer from the useless copying. |
Moving a folder on the same disk is a very fast operation, it doesn't involve copying. My theory on this error is that git is still using the folder after cloning it on some configs, maybe to index it, so it locks the .tmp folder preventing it to be moved. |
os.mv is very fast, and normally, source.tmp should only be occupied by one git process, and it will stop occupying this directory as soon as git clone finishes. Unless the git process or its child processes have not fully exited after git clone has finished and continue to occupy it. The use of source.tmp is to ensure the integrity of the source directory, so that even if git is killed during the clone process, there will not be an incomplete source directory. |
maybe xmake could try to move it multiple times if it fails, waiting a bit between tries until it reaches a max_tries value. |
But I need to know the root cause, why the git clone process exits and source.tmp continues to be occupied. |
I have tried rebooting and build directly after that, there should be no process occupied, but failed with the same issue. |
if that operation failed xmake will clone it again with git, causing the same issue. If someone successfully reproduces this issue, it would be nice to use a software like https://lockhunter.com to quickly check what processes lock the .tmp folder |
That's weird, it's like a MoveFileExW problem, but I don't know why it's failing if no any process occupied. |
@Cutano You can check that no other process is occupying it, or run |
I can't reproduce after I reinstalled git. Btw, is there anything to do with the Detached HEAD state of the cloned git repo? |
It shouldn't have anything to do with this. |
Git did not exit until xmake exits, even if making xmake sleep for 20s 只要xmake不退出,git也不退出,我在中间加了sleep 20s,git就一直占用了20s |
Where did you add os.sleep? As soon as the git.clone()/os.exec("git clone") call returns, the git process should have exited |
Process Monitor could help understand what's going on here, it's very powerful. |
if the issue cannot be addressed, can xmake provide a way to get around? i.e. force xmake to treat source.tmp as complete |
no way. And if another git process does keep occupying source.tmp, then even cloning directly to the source directory may cause other problems. |
I tried it, it works for me. import("devel.git")
function main()
os.tryrm("testgit")
git.clone("https://github.com/nothings/stb.git", {outputdir = "testgit"})
git.checkout("4af130e86341928e3003ba5657f3e9faec50c1dc", {repodir = "testgit"})
os.tryrm("teststb")
os.mv("testgit", "teststb")
end |
where is your git.exe? my git is but your git process is It is possible that the git process called by xmake has already exited, but an additional git.exe child process has been created inside git, which is associated with the parent process and has not been exited. |
But xmake doesn't know if it's outdated. Theoretically, xmake can use any version of git until it meet this problem and my git is 2.20.0, it works. |
Did you test it on windows? Since now only windows users reported the issue |
yeah, on my win7 |
@Cutano what is your previous git version? |
I tried 2.32.2. it works for me. https://github.com/git-for-windows/git/releases/download/v2.32.0.windows.1/MinGit-2.32.0-64-bit.zip import("devel.git")
function main()
os.tryrm("testgit")
git.clone("https://github.com/nothings/stb.git", {outputdir = "testgit"})
git.checkout("4af130e86341928e3003ba5657f3e9faec50c1dc", {repodir = "testgit"})
os.tryrm("teststb")
os.mv("testgit", "teststb")
end xmake l test.lua |
Probably 2.30, I deleted the package but I remember git was installed around May. |
I had similar problem (could not install sentry-native, because source.tmp was busy), but i remembered git had introduced fsmonitor. So I disabled fsmonitor ( Win11 with latest updates, git version 2.38.1.windows.1 |
@Longxr @xq114 @Cutano Maybe this is the cause of the problem, you can try. |
I have improved it, can you try it?
|
Have you all tested this patch and if it works I plan to merge it. |
I've merged the patch for now, so you can watch it for a while |
Works for me, seems to be the root cause, thanks! |
I have merged into dev. I closed it first and if you have this questions later, you can open it again. |
another tool, handle.exe https://learn.microsoft.com/zh-cn/sysinternals/downloads/handle we can run like this cl.exe pid: 960 ruki-PC\ruki
C: File \Device\Mup\VBoxSvr\projects\personal\tbox
64: File \Device\Mup\VBoxSvr\projects\personal\tbox\log.txt
80: File \Device\Mup\VBoxSvr\projects\personal\tbox\src\tbox\math\random\random.c
84: File \Device\Mup\VBoxSvr\projects\personal\tbox\src\tbox\platform\platform.h
88: File \Device\Mup\VBoxSvr\projects\personal\tbox\src\tbox\platform\cpu.h
8C: File \Device\Mup\VBoxSvr\projects\personal\tbox\src\tbox\platform\windows\prefix.h
90: File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\um\WinSock2.h
94: File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\um\Windows.h
98: File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\um\WinBase.h
9C: File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\um\minwinbase.h
194: File C:\Users\ruki\AppData\Local\Temp\.xmake\221124\_77208C9047E4413089E0BFC612B8D490.i.err
1AC: File C:\Users\ruki\AppData\Local\Temp\.xmake\221124\_E9E9002D13D34D70854D314DA21B47C0.i.out
1BC: File C:\Users\ruki\AppData\Local\Temp\.xmake\221124\_D0AEF6C2663C4A1087E001ADAF0CC180.i.out
1C0: File C:\Users\ruki\AppData\Local\Temp\.xmake\221124\_21D071E92D5B4E208900A55EAFF82A30.i.err |
bInheritHandle = TRUE;
if (!tb_kernel32()->CreateProcessW(tb_null, command, &sap, &sat, bInheritHandle, flags, (LPVOID)environment, attr && attr->curdir? curdir : tb_null, &process->si, &process->pi)) I probably figured out the root cause. xmake creates child processes with inheritance handles enabled by default. If source.tmp has been already opened occupied (os.cd()) when multiple subprocesses are executed in parallel, they will all inherit its handle. Even if the current git/unzip subprocess has exited and no longer accesses it, it will continue to be occupied by other subprocesses that may not have direct access to it. I had a similar problem when I executed the cl.exe sub-process in parallel and I was unable to delete the files accessed by other cl.exe processes. But if I disable the inheritance handle, it works. xmake/xmake/modules/core/tools/cl.lua Line 512 in a6e149f
|
I have improved to spawn process on windows. tboox/tbox@5b62232 |
Xmake Version
v2.7.1
Operating System Version and Architecture
Windows 11 22H2
Describe Bug
error: cannot move source.tmp to source Permission denied
Expected Behavior
Deps installed successfully.
Project Configuration
No response
Additional Information and Error Logs
No response
The text was updated successfully, but these errors were encountered: