Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/ValveSoftware/Proton.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/proton
diff options
context:
space:
mode:
authorRĂ©mi Bernon <rbernon@codeweavers.com>2021-12-16 13:49:30 +0300
committerArkadiusz Hiler <ahiler@codeweavers.com>2022-01-19 12:29:54 +0300
commitb3d4aa02a65a6a686aeadcc05d9f58a6029f64c0 (patch)
tree51de845ede8c05401f0c257d2a01537cfa3cb12e /proton
parent16b662a0bfd0613e37ee71876d4518af5e7b64bb (diff)
proton: Add a prefix parameter to try_copy.
Diffstat (limited to 'proton')
-rwxr-xr-xproton77
1 files changed, 42 insertions, 35 deletions
diff --git a/proton b/proton
index 35baffdb..2f481a91 100755
--- a/proton
+++ b/proton
@@ -109,8 +109,12 @@ def merge_user_dir(src, dst):
else:
extant_dirs += dst_dir
-def try_copy(src, dst, add_write_perm=True, copy_metadata=False, optional=False, follow_symlinks=True):
+def try_copy(src, dst, prefix=None, add_write_perm=True, copy_metadata=False, optional=False,
+ follow_symlinks=True):
try:
+ if prefix is not None:
+ dst = os.path.join(prefix, dst)
+
if os.path.isdir(dst):
dst = os.path.join(dst, os.path.basename(src))
@@ -740,7 +744,7 @@ class CompatData:
os.remove(dstfile)
else:
tracked_files.write(steam_dir + tgt + "\n")
- try_copy(srcfile, dstfile)
+ try_copy(srcfile, steam_dir + tgt, prefix=self.prefix_dir)
filestocopy = [("steamclient64.dll", "steamclient64.dll"),
("GameOverlayRenderer.dll", "GameOverlayRenderer.dll"),
@@ -753,25 +757,29 @@ class CompatData:
os.remove(dstfile)
else:
tracked_files.write(steam_dir + tgt + "\n")
- try_copy(srcfile, dstfile)
+ try_copy(srcfile, steam_dir + tgt, prefix=self.prefix_dir)
#copy openvr files into place
- dst = self.prefix_dir + "/drive_c/vrclient/bin/"
- makedirs(dst)
- try_copy(g_proton.lib_dir + "wine/i386-windows/vrclient.dll", dst)
- try_copy(g_proton.lib64_dir + "wine/x86_64-windows/vrclient_x64.dll", dst)
+ makedirs(self.prefix_dir + "/drive_c/vrclient/bin")
+ try_copy(g_proton.lib_dir + "wine/i386-windows/vrclient.dll", "drive_c/vrclient/bin",
+ prefix=self.prefix_dir)
+ try_copy(g_proton.lib64_dir + "wine/x86_64-windows/vrclient_x64.dll", "drive_c/vrclient/bin",
+ prefix=self.prefix_dir)
- try_copy(g_proton.lib_dir + "wine/dxvk/openvr_api_dxvk.dll", self.prefix_dir + "/drive_c/windows/syswow64/")
- try_copy(g_proton.lib64_dir + "wine/dxvk/openvr_api_dxvk.dll", self.prefix_dir + "/drive_c/windows/system32/")
+ try_copy(g_proton.lib_dir + "wine/dxvk/openvr_api_dxvk.dll", "drive_c/windows/syswow64",
+ prefix=self.prefix_dir)
+ try_copy(g_proton.lib64_dir + "wine/dxvk/openvr_api_dxvk.dll", "drive_c/windows/system32",
+ prefix=self.prefix_dir)
- makedirs(self.prefix_dir + "/drive_c/openxr/")
- try_copy(g_proton.default_pfx_dir + "drive_c/openxr/wineopenxr64.json", self.prefix_dir + "/drive_c/openxr/")
+ makedirs(self.prefix_dir + "/drive_c/openxr")
+ try_copy(g_proton.default_pfx_dir + "drive_c/openxr/wineopenxr64.json", "drive_c/openxr",
+ prefix=self.prefix_dir)
#copy vkd3d files into place
- try_copy(g_proton.lib64_dir + "vkd3d/libvkd3d-shader-1.dll",
- self.prefix_dir + "drive_c/windows/system32/libvkd3d-shader-1.dll")
- try_copy(g_proton.lib_dir + "vkd3d/libvkd3d-shader-1.dll",
- self.prefix_dir + "drive_c/windows/syswow64/libvkd3d-shader-1.dll")
+ try_copy(g_proton.lib64_dir + "vkd3d/libvkd3d-shader-1.dll", "drive_c/windows/system32",
+ prefix=self.prefix_dir)
+ try_copy(g_proton.lib_dir + "vkd3d/libvkd3d-shader-1.dll", "drive_c/windows/syswow64",
+ prefix=self.prefix_dir)
if use_wined3d:
dxvkfiles = ["dxvk_config"]
@@ -786,25 +794,25 @@ class CompatData:
wined3dfiles.append("dxgi")
for f in wined3dfiles:
- try_copy(g_proton.default_pfx_dir + "drive_c/windows/system32/" + f + ".dll",
- self.prefix_dir + "drive_c/windows/system32/" + f + ".dll")
- try_copy(g_proton.default_pfx_dir + "drive_c/windows/syswow64/" + f + ".dll",
- self.prefix_dir + "drive_c/windows/syswow64/" + f + ".dll")
+ try_copy(g_proton.default_pfx_dir + "drive_c/windows/system32/" + f + ".dll", "drive_c/windows/system32",
+ prefix=self.prefix_dir)
+ try_copy(g_proton.default_pfx_dir + "drive_c/windows/syswow64/" + f + ".dll", "drive_c/windows/syswow64",
+ prefix=self.prefix_dir)
for f in dxvkfiles:
- try_copy(g_proton.lib64_dir + "wine/dxvk/" + f + ".dll",
- self.prefix_dir + "drive_c/windows/system32/" + f + ".dll")
- try_copy(g_proton.lib_dir + "wine/dxvk/" + f + ".dll",
- self.prefix_dir + "drive_c/windows/syswow64/" + f + ".dll")
+ try_copy(g_proton.lib64_dir + "wine/dxvk/" + f + ".dll", "drive_c/windows/system32",
+ prefix=self.prefix_dir)
+ try_copy(g_proton.lib_dir + "wine/dxvk/" + f + ".dll", "drive_c/windows/syswow64",
+ prefix=self.prefix_dir)
g_session.dlloverrides[f] = "n"
# If the user requested the NVAPI be available, copy it into place.
# If they didn't, clean up any stray nvapi DLLs.
if use_nvapi:
- try_copy(g_proton.lib64_dir + "wine/nvapi/nvapi64.dll",
- self.prefix_dir + "drive_c/windows/system32/nvapi64.dll")
- try_copy(g_proton.lib_dir + "wine/nvapi/nvapi.dll",
- self.prefix_dir + "drive_c/windows/syswow64/nvapi.dll")
+ try_copy(g_proton.lib64_dir + "wine/nvapi/nvapi64.dll", "drive_c/windows/system32",
+ prefix=self.prefix_dir)
+ try_copy(g_proton.lib_dir + "wine/nvapi/nvapi.dll", "drive_c/windows/syswow64",
+ prefix=self.prefix_dir)
g_session.dlloverrides["nvapi64"] = "n"
g_session.dlloverrides["nvapi"] = "n"
g_session.dlloverrides["nvcuda"] = "b"
@@ -821,14 +829,13 @@ class CompatData:
nvidia_wine_dll_dir = find_nvidia_wine_dll_dir()
if nvidia_wine_dll_dir:
for dll in ["_nvngx.dll", "nvngx.dll"]:
- try_copy(nvidia_wine_dll_dir + "/" + dll,
- self.prefix_dir + "drive_c/windows/system32/" + dll,
- optional=True)
-
- try_copy(g_proton.lib64_dir + "wine/vkd3d-proton/d3d12.dll",
- self.prefix_dir + "drive_c/windows/system32/d3d12.dll")
- try_copy(g_proton.lib_dir + "wine/vkd3d-proton/d3d12.dll",
- self.prefix_dir + "drive_c/windows/syswow64/d3d12.dll")
+ try_copy(nvidia_wine_dll_dir + "/" + dll, "drive_c/windows/system32", optional=True,
+ prefix=self.prefix_dir)
+
+ try_copy(g_proton.lib64_dir + "wine/vkd3d-proton/d3d12.dll", "drive_c/windows/system32",
+ prefix=self.prefix_dir)
+ try_copy(g_proton.lib_dir + "wine/vkd3d-proton/d3d12.dll", "drive_c/windows/syswow64",
+ prefix=self.prefix_dir)
gamedrive_path = self.prefix_dir + "dosdevices/s:"
if "gamedrive" in g_session.compat_config: