mirror of
https://gitee.com/gfdgd-xi/deep-wine-runner
synced 2025-01-27 00:18:09 +08:00
更新依赖和简易打包器
This commit is contained in:
parent
de0a9b13f1
commit
d330c83691
@ -4,7 +4,7 @@ Maintainer: gfdgd xi <3025613752@qq.com>, 为什么您不喜欢熊出没和阿
|
|||||||
Homepage: https://gitee.com/gfdgd-xi/deep-wine-runner, https://github.com/gfdgd-xi/deep-wine-runner, https://gitlink.org.cn/gfdgd_xi/deep-wine-runner
|
Homepage: https://gitee.com/gfdgd-xi/deep-wine-runner, https://github.com/gfdgd-xi/deep-wine-runner, https://gitlink.org.cn/gfdgd_xi/deep-wine-runner
|
||||||
Architecture: all
|
Architecture: all
|
||||||
Priority: optional
|
Priority: optional
|
||||||
Depends: python3, python3-pil, python3-pil.imagetk, python3-pyquery, aria2, curl, unrar, unzip, python3-requests, fakeroot, bash, python3-pyqt5, python3-psutil, deepin-terminal | mate-terminal | gnome-terminal | xfce4-terminal, python3-dbus, python3-pip
|
Depends: python3, python3-pil, python3-pil.imagetk, python3-pyquery, aria2, curl, unrar, unzip, python3-requests, fakeroot, bash, python3-pyqt5, python3-psutil, deepin-terminal | mate-terminal | gnome-terminal | xfce4-terminal, python3-dbus, python3-pip, p7zip-full, sudo
|
||||||
Recommends: winbind, wimtools
|
Recommends: winbind, wimtools
|
||||||
Section: utils
|
Section: utils
|
||||||
Conflicts: spark.deepin-venturi-setter, spark-deepin-wine5-application-packer
|
Conflicts: spark.deepin-venturi-setter, spark-deepin-wine5-application-packer
|
||||||
|
@ -399,17 +399,13 @@ class RunThread(QtCore.QThread):
|
|||||||
############# 后面将全部调用 deepin wine6 stable 进行操作
|
############# 后面将全部调用 deepin wine6 stable 进行操作
|
||||||
exeName = os.path.basename(exePath.text())
|
exeName = os.path.basename(exePath.text())
|
||||||
# 暂定
|
# 暂定
|
||||||
debPackageName = "spark-" + xpinyin.Pinyin().get_pinyin(os.path.splitext(exeName)[0].replace(" ", "")).lower().replace("--", "-").replace(" ", "")
|
debPackageName = "spark-" + xpinyin.Pinyin().get_pinyin(os.path.splitext(exeName)[0].replace(" ", "")).lower().replace("--", "-").replace(" ", "").replace("_", "-")
|
||||||
debPackageVersion = "1.0.0"
|
debPackageVersion = "1.0.0"
|
||||||
programIconPath = f"/opt/apps/{debPackageName}/entries/icons/hicolor/scalable/apps/{debPackageName}.png"
|
programIconPath = f"/opt/apps/{debPackageName}/entries/icons/hicolor/scalable/apps/{debPackageName}.png"
|
||||||
debMaintainer = os.getlogin()
|
debMaintainer = os.getlogin()
|
||||||
debBuildPath = f"/tmp/deepin-wine-packager-builder-{debPackageName}-{random.randint(0, 1000)}"
|
debBuildPath = f"/tmp/deepin-wine-packager-builder-{debPackageName}-{random.randint(0, 1000)}"
|
||||||
bottlePackagePath = f"{debBuildPath}/opt/apps/{debPackageName}/files/files.7z"
|
bottlePackagePath = f"{debBuildPath}/opt/apps/{debPackageName}/files/files.7z"
|
||||||
desktopPath = get_desktop_path()
|
desktopPath = get_desktop_path()
|
||||||
self.RunCommand(f"mkdir -pv '{debBuildPath}/DEBIAN'")
|
|
||||||
self.RunCommand(f"mkdir -pv '{debBuildPath}/opt/apps/{debPackageName}/files'")
|
|
||||||
self.RunCommand(f"mkdir -pv '{debBuildPath}/opt/apps/{debPackageName}/entries/applications'")
|
|
||||||
self.RunCommand(f"mkdir -pv '{debBuildPath}/opt/apps/{debPackageName}/entries/icons/hicolor/scalable/apps/'")
|
|
||||||
############## 运行 EXE
|
############## 运行 EXE
|
||||||
if self.QuestionMsg("请问此可执行文件是安装包还是绿色软件?是安装包请按 Yes,绿色软件按 No"):
|
if self.QuestionMsg("请问此可执行文件是安装包还是绿色软件?是安装包请按 Yes,绿色软件按 No"):
|
||||||
# 清空无益处的 lnk 文件
|
# 清空无益处的 lnk 文件
|
||||||
@ -440,7 +436,8 @@ class RunThread(QtCore.QThread):
|
|||||||
secondChooseList = []
|
secondChooseList = []
|
||||||
for k in lnkList:
|
for k in lnkList:
|
||||||
lnkPath = k[0].lower()
|
lnkPath = k[0].lower()
|
||||||
if "卸载" in lnkPath or "uninstall" in lnkPath or "update" in lnkPath or "网页" in lnkPath or "websize" in lnkPath:
|
lnkExePath = k[1].lower()
|
||||||
|
if "卸载" in lnkPath or "uninstall" in lnkPath or "update" in lnkPath or "网页" in lnkPath or "websize" in lnkPath or not ".exe" in lnkExePath:
|
||||||
continue
|
continue
|
||||||
secondChooseList.append(k)
|
secondChooseList.append(k)
|
||||||
if len(secondChooseList) <= 0:
|
if len(secondChooseList) <= 0:
|
||||||
@ -452,6 +449,10 @@ class RunThread(QtCore.QThread):
|
|||||||
if len(k[1]) < miniLenge:
|
if len(k[1]) < miniLenge:
|
||||||
rightLnk = k
|
rightLnk = k
|
||||||
miniLenge = len(rightLnk[1])
|
miniLenge = len(rightLnk[1])
|
||||||
|
debPackageName = "spark-" + xpinyin.Pinyin().get_pinyin(os.path.splitext(os.path.basename(rightLnk[0]))[0].replace(" ", "")).lower().replace("--", "-").replace(" ", "").replace("_", "-")
|
||||||
|
programIconPath = f"/opt/apps/{debPackageName}/entries/icons/hicolor/scalable/apps/{debPackageName}.png"
|
||||||
|
bottlePackagePath = f"{debBuildPath}/opt/apps/{debPackageName}/files/files.7z"
|
||||||
|
self.RunCommand(f"mkdir -pv '{debBuildPath}/opt/apps/{debPackageName}/entries/icons/hicolor/scalable/apps/'")
|
||||||
folderExePath = os.path.dirname(rightLnk[1].replace("\\", "/").replace("c:/", bottlePath))
|
folderExePath = os.path.dirname(rightLnk[1].replace("\\", "/").replace("c:/", bottlePath))
|
||||||
exePathInBottle = rightLnk[1]
|
exePathInBottle = rightLnk[1]
|
||||||
exeName = os.path.splitext(os.path.basename(folderExePath))[0]
|
exeName = os.path.splitext(os.path.basename(folderExePath))[0]
|
||||||
@ -459,9 +460,10 @@ class RunThread(QtCore.QThread):
|
|||||||
debPackageVersion = self.GetEXEVersion(exePathInBottle)
|
debPackageVersion = self.GetEXEVersion(exePathInBottle)
|
||||||
cpNow = False
|
cpNow = False
|
||||||
for i in iconList:
|
for i in iconList:
|
||||||
path = i.replace("wineBottonPath", bottlePath).lower()
|
path = i[1].replace("wineBottonPath", bottlePath).lower()
|
||||||
if path == exePathInSystem.lower():
|
if path == exePathInSystem.lower():
|
||||||
self.RunCommand(f"cp -rv '{UnUseUpperCharPath(path)}' '{debBuildPath}/{programIconPath}'")
|
self.RunCommand(f"cp -rv '{programPath}/Icon/{i[0]}.svg' '{debBuildPath}/{programIconPath}'")
|
||||||
|
exeName = i[0]
|
||||||
cpNow = True
|
cpNow = True
|
||||||
break
|
break
|
||||||
if not cpNow:
|
if not cpNow:
|
||||||
@ -475,12 +477,17 @@ class RunThread(QtCore.QThread):
|
|||||||
folderExePath = os.path.dirname(exePath.text())
|
folderExePath = os.path.dirname(exePath.text())
|
||||||
exePathInBottle = f"c:/Program Files/{os.path.basename(folderExePath)}/{exeName}"
|
exePathInBottle = f"c:/Program Files/{os.path.basename(folderExePath)}/{exeName}"
|
||||||
exeName = os.path.splitext(os.path.basename(os.path.basename(exePath.text())))[0]
|
exeName = os.path.splitext(os.path.basename(os.path.basename(exePath.text())))[0]
|
||||||
|
self.RunCommand(f"mkdir -pv '{debBuildPath}/opt/apps/{debPackageName}/entries/icons/hicolor/scalable/apps/'")
|
||||||
self.RunCommand(f"'{programPath}/wrestool' '{exePathInBottle}' -x -t 14 > '{debBuildPath}/{programIconPath}'")
|
self.RunCommand(f"'{programPath}/wrestool' '{exePathInBottle}' -x -t 14 > '{debBuildPath}/{programIconPath}'")
|
||||||
debPackageVersion = self.GetEXEVersion(exePathInBottle)
|
debPackageVersion = self.GetEXEVersion(exePathInBottle)
|
||||||
# 拷贝文件到容器
|
# 拷贝文件到容器
|
||||||
self.RunCommand(f"cp -rv '{folderExePath}' '{bottlePath}/drive_c/Program Files'")
|
self.RunCommand(f"cp -rv '{folderExePath}' '{bottlePath}/drive_c/Program Files'")
|
||||||
debDescription = f"{exeName} By Deepin Wine 6 Stable And Build By Wine Runner"
|
debDescription = f"{exeName} By Deepin Wine 6 Stable And Build By Wine Runner"
|
||||||
debDepends = "deepin-wine6-stable, spark-dwine-helper | store.spark-app.spark-dwine-helper, fonts-wqy-microhei, fonts-wqy-zenhei"
|
debDepends = "deepin-wine6-stable, spark-dwine-helper | store.spark-app.spark-dwine-helper, fonts-wqy-microhei, fonts-wqy-zenhei"
|
||||||
|
self.RunCommand(f"mkdir -pv '{debBuildPath}/DEBIAN'")
|
||||||
|
self.RunCommand(f"mkdir -pv '{debBuildPath}/opt/apps/{debPackageName}/files'")
|
||||||
|
self.RunCommand(f"mkdir -pv '{debBuildPath}/opt/apps/{debPackageName}/entries/applications'")
|
||||||
|
#self.RunCommand(f"mkdir -pv '{debBuildPath}/opt/apps/{debPackageName}/entries/icons/hicolor/scalable/apps/'")
|
||||||
############ 处理容器
|
############ 处理容器
|
||||||
# 对用户目录进行处理
|
# 对用户目录进行处理
|
||||||
os.chdir(bottlePath)
|
os.chdir(bottlePath)
|
||||||
@ -535,11 +542,11 @@ class RunThread(QtCore.QThread):
|
|||||||
self.info.emit("打包完成!")
|
self.info.emit("打包完成!")
|
||||||
self.disbledAll.emit(False)
|
self.disbledAll.emit(False)
|
||||||
########### 移除临时文件
|
########### 移除临时文件
|
||||||
#self.RunCommand(f"rm -rfv '{debBuildPath}' > /dev/null")
|
self.RunCommand(f"rm -rfv '{debBuildPath}' > /dev/null")
|
||||||
#self.RunCommand(f"rm -rfv '{bottlePath}' > /dev/null")
|
self.RunCommand(f"rm -rfv '{bottlePath}' > /dev/null")
|
||||||
except:
|
except:
|
||||||
#self.RunCommand(f"rm -rfv '{debBuildPath}' > /dev/null")
|
self.RunCommand(f"rm -rfv '{debBuildPath}' > /dev/null")
|
||||||
#self.RunCommand(f"rm -rfv '{bottlePath}' > /dev/null")
|
self.RunCommand(f"rm -rfv '{bottlePath}' > /dev/null")
|
||||||
# 若打包出现任何错误
|
# 若打包出现任何错误
|
||||||
traceback.print_exc()
|
traceback.print_exc()
|
||||||
self.error.emit(f"打包错误,详细详细如下:{traceback.format_exc()}")
|
self.error.emit(f"打包错误,详细详细如下:{traceback.format_exc()}")
|
||||||
@ -556,6 +563,7 @@ def RunBuildThread():
|
|||||||
buildThread.question.connect(QuestionMessage)
|
buildThread.question.connect(QuestionMessage)
|
||||||
buildThread.disbledAll.connect(DisbledAndEnabledAll)
|
buildThread.disbledAll.connect(DisbledAndEnabledAll)
|
||||||
buildThread.cleanPressState.connect(CleanPressCompleteDownloadState)
|
buildThread.cleanPressState.connect(CleanPressCompleteDownloadState)
|
||||||
|
logText.clear()
|
||||||
buildThread.start()
|
buildThread.start()
|
||||||
|
|
||||||
pressCompleteDownload = False
|
pressCompleteDownload = False
|
||||||
|
@ -1844,6 +1844,8 @@ defultProgramList = {
|
|||||||
"BuildByBottleName": False,
|
"BuildByBottleName": False,
|
||||||
"AutoPath": False
|
"AutoPath": False
|
||||||
}
|
}
|
||||||
|
if not os.path.exists(get_home() + "/.config/"): # 如果没有配置文件夹
|
||||||
|
os.mkdir(get_home() + "/.config/") # 创建配置文件夹
|
||||||
if not os.path.exists(get_home() + "/.config/deepin-wine-runner"): # 如果没有配置文件夹
|
if not os.path.exists(get_home() + "/.config/deepin-wine-runner"): # 如果没有配置文件夹
|
||||||
os.mkdir(get_home() + "/.config/deepin-wine-runner") # 创建配置文件夹
|
os.mkdir(get_home() + "/.config/deepin-wine-runner") # 创建配置文件夹
|
||||||
if not os.path.exists(get_home() + "/.config/deepin-wine-runner/ShellHistory.json"): # 如果没有配置文件
|
if not os.path.exists(get_home() + "/.config/deepin-wine-runner/ShellHistory.json"): # 如果没有配置文件
|
||||||
@ -2034,8 +2036,8 @@ class GetVersionThread(QtCore.QThread):
|
|||||||
}
|
}
|
||||||
# 直接判断是不是 Docker 版本
|
# 直接判断是不是 Docker 版本
|
||||||
if os.path.exists(f"{programPath}/docker.txt") or os.path.exists("/.dockerenv"):
|
if os.path.exists(f"{programPath}/docker.txt") or os.path.exists("/.dockerenv"):
|
||||||
programVersionType = "Docker 内置版本"
|
programVersionType = "Docker/Chroot 内置版本"
|
||||||
window.setWindowTitle(f"{title} (Docker 内置版本)")
|
window.setWindowTitle(f"{title} (Docker/Chroot 内置版本)")
|
||||||
self.signal.emit("")
|
self.signal.emit("")
|
||||||
else:
|
else:
|
||||||
programVersionType = "从源码运行的版本"
|
programVersionType = "从源码运行的版本"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user