mirror of
https://gitee.com/gfdgd-xi/deep-wine-runner
synced 2025-12-16 03:52:04 +08:00
Compare commits
17 Commits
c87218232d
...
4.1.0.0
| Author | SHA1 | Date | |
|---|---|---|---|
| 058f025353 | |||
| d8360c6e59 | |||
| 7fa1edb3f8 | |||
| 82bd073ff8 | |||
| ebed98fd25 | |||
| 1ec62bbf86 | |||
| f79bac9d6c | |||
| 6863e58413 | |||
| 96319869b6 | |||
| bc5aca0fd7 | |||
| bf18411f7a | |||
| 6ce9d63a19 | |||
| 4022c3a17b | |||
| 9ae95d6008 | |||
| 81576681e8 | |||
| aaeb80fde3 | |||
| df95e7d0b0 |
0
ConfigLanguareRunner-help.json
Normal file → Executable file
0
ConfigLanguareRunner-help.json
Normal file → Executable file
0
DefaultSetting.py
Normal file → Executable file
0
DefaultSetting.py
Normal file → Executable file
0
DisabledOpengl.reg
Normal file → Executable file
0
DisabledOpengl.reg
Normal file → Executable file
0
Download.py
Normal file → Executable file
0
Download.py
Normal file → Executable file
0
EnabledOpengl.reg
Normal file → Executable file
0
EnabledOpengl.reg
Normal file → Executable file
0
IconList.json
Normal file → Executable file
0
IconList.json
Normal file → Executable file
0
InstallDeepinWine6OnUbuntu.sh
Normal file → Executable file
0
InstallDeepinWine6OnUbuntu.sh
Normal file → Executable file
0
InstallDeepinWineOnUbuntu.sh
Normal file → Executable file
0
InstallDeepinWineOnUbuntu.sh
Normal file → Executable file
9
Makefile
9
Makefile
@@ -39,6 +39,7 @@ copy-files:
|
|||||||
cp -rv wine/ deb/opt/apps/deepin-wine-runner/
|
cp -rv wine/ deb/opt/apps/deepin-wine-runner/
|
||||||
cp -rv Test/ deb/opt/apps/deepin-wine-runner/
|
cp -rv Test/ deb/opt/apps/deepin-wine-runner/
|
||||||
cp -rv dxvk/ deb/opt/apps/deepin-wine-runner/
|
cp -rv dxvk/ deb/opt/apps/deepin-wine-runner/
|
||||||
|
cp -rv packager-config/ deb/opt/apps/deepin-wine-runner/
|
||||||
cp -rv information.json package-script
|
cp -rv information.json package-script
|
||||||
zip -v -q -r package-script.zip package-script
|
zip -v -q -r package-script.zip package-script
|
||||||
cp -rv InstallBox86-cn.sh deb/opt/apps/deepin-wine-runner/
|
cp -rv InstallBox86-cn.sh deb/opt/apps/deepin-wine-runner/
|
||||||
@@ -97,7 +98,7 @@ copy-files:
|
|||||||
cp -rv InstallVisualCPlusPlus.py deb/opt/apps/deepin-wine-runner
|
cp -rv InstallVisualCPlusPlus.py deb/opt/apps/deepin-wine-runner
|
||||||
cp -rv launch.sh deb/opt/apps/deepin-wine-runner
|
cp -rv launch.sh deb/opt/apps/deepin-wine-runner
|
||||||
cp -rv LICENSE deb/opt/apps/deepin-wine-runner
|
cp -rv LICENSE deb/opt/apps/deepin-wine-runner
|
||||||
cp -rv mainwindow.py deb/opt/apps/deepin-wine-runner/deepin-wine-runner
|
cp -rv mainwindow.py deb/opt/apps/deepin-wine-runner/
|
||||||
cp -rv package-script.zip deb/opt/apps/deepin-wine-runner
|
cp -rv package-script.zip deb/opt/apps/deepin-wine-runner
|
||||||
cp -rv Run.bat deb/opt/apps/deepin-wine-runner
|
cp -rv Run.bat deb/opt/apps/deepin-wine-runner
|
||||||
cp -rv RunVM.sh deb/opt/apps/deepin-wine-runner
|
cp -rv RunVM.sh deb/opt/apps/deepin-wine-runner
|
||||||
@@ -137,6 +138,10 @@ copy-files:
|
|||||||
cp -rv InstallRuntime deb/opt/apps/deepin-wine-runner
|
cp -rv InstallRuntime deb/opt/apps/deepin-wine-runner
|
||||||
cp -rv globalenv.py deb/opt/apps/deepin-wine-runner
|
cp -rv globalenv.py deb/opt/apps/deepin-wine-runner
|
||||||
cp -rv local deb/opt/apps/deepin-wine-runner
|
cp -rv local deb/opt/apps/deepin-wine-runner
|
||||||
|
cp -rv WindowModule.py deb/opt/apps/deepin-wine-runner
|
||||||
|
cp -rv welcome.py deb/opt/apps/deepin-wine-runner
|
||||||
|
#cp -rv main.py deb/opt/apps/deepin-wine-runner/deepin-wine-runner
|
||||||
|
cp -rv mainwindow.py deb/opt/apps/deepin-wine-runner/deepin-wine-runner
|
||||||
mkdir -pv deb/opt/apps/deepin-wine-runner/entries/
|
mkdir -pv deb/opt/apps/deepin-wine-runner/entries/
|
||||||
cp -rv deb/usr/share/applications deb/opt/apps/deepin-wine-runner/entries/applications
|
cp -rv deb/usr/share/applications deb/opt/apps/deepin-wine-runner/entries/applications
|
||||||
python3 UpdateTime.py
|
python3 UpdateTime.py
|
||||||
@@ -203,7 +208,7 @@ package-termux-deb:
|
|||||||
sudo cp -rv deb-termux/usr/share/applications /tmp/spark-deepin-wine-runner-builder/data/data/com.termux/files/usr/share/applications
|
sudo cp -rv deb-termux/usr/share/applications /tmp/spark-deepin-wine-runner-builder/data/data/com.termux/files/usr/share/applications
|
||||||
# 加入 termux loader
|
# 加入 termux loader
|
||||||
sudo cp -rv mainwindow-termux-loader.sh /tmp/spark-deepin-wine-runner-builder/data/data/com.termux/files/usr/opt/apps/deepin-wine-runner/deepin-wine-runner
|
sudo cp -rv mainwindow-termux-loader.sh /tmp/spark-deepin-wine-runner-builder/data/data/com.termux/files/usr/opt/apps/deepin-wine-runner/deepin-wine-runner
|
||||||
sudo cp -rv mainwindow.py /tmp/spark-deepin-wine-runner-builder/data/data/com.termux/files/usr/opt/apps/deepin-wine-runner/mainwindow.py
|
sudo cp -rv main.py /tmp/spark-deepin-wine-runner-builder/data/data/com.termux/files/usr/opt/apps/deepin-wine-runner/mainwindow.py
|
||||||
sudo bash builddeb/ChangeDebVersion.sh
|
sudo bash builddeb/ChangeDebVersion.sh
|
||||||
dpkg-deb -Z xz -z 9 -b /tmp/spark-deepin-wine-runner-builder spark-deepin-wine-runner-termux.deb
|
dpkg-deb -Z xz -z 9 -b /tmp/spark-deepin-wine-runner-builder spark-deepin-wine-runner-termux.deb
|
||||||
make remove-copy-files -j$(nproc)
|
make remove-copy-files -j$(nproc)
|
||||||
|
|||||||
@@ -14,14 +14,14 @@ programPath = os.path.split(os.path.realpath(__file__))[0] # 返回 string
|
|||||||
terminal = ""
|
terminal = ""
|
||||||
terminalList = [
|
terminalList = [
|
||||||
"deepin-terminal",
|
"deepin-terminal",
|
||||||
"deepin-terminal-gtk",
|
"gxde-terminal",
|
||||||
"mate-terminal",
|
"mate-terminal",
|
||||||
"gnome-terminal",
|
"gnome-terminal",
|
||||||
"xfce4-terminal"
|
"xfce4-terminal"
|
||||||
]
|
]
|
||||||
terminalEnd = {
|
terminalEnd = {
|
||||||
f"{programPath}/../launch.sh\" \"deepin-terminal": ["-e", 0],
|
f"{programPath}/../launch.sh\" \"deepin-terminal": ["-e", 0],
|
||||||
f"{programPath}/../launch.sh\" \"deepin-terminal-gtk": ["-e", 0],
|
f"{programPath}/../launch.sh\" \"gxde-terminal": ["-e", 0],
|
||||||
"mate-terminal": ["-e", 1],
|
"mate-terminal": ["-e", 1],
|
||||||
"gnome-terminal": ["--", 0],
|
"gnome-terminal": ["--", 0],
|
||||||
"xfce4-terminal": ["-e", 1]
|
"xfce4-terminal": ["-e", 1]
|
||||||
@@ -31,7 +31,7 @@ for i in terminalList:
|
|||||||
if i == "deepin-terminal":
|
if i == "deepin-terminal":
|
||||||
i = f"{programPath}/../launch.sh\" \"deepin-terminal"
|
i = f"{programPath}/../launch.sh\" \"deepin-terminal"
|
||||||
if i == "deepin-terminal-gtk":
|
if i == "deepin-terminal-gtk":
|
||||||
i = f"{programPath}/../launch.sh\" \"deepin-terminal-gtk"
|
i = f"{programPath}/../launch.sh\" \"gxde-terminal"
|
||||||
terminal = i
|
terminal = i
|
||||||
break
|
break
|
||||||
if terminal == "":
|
if terminal == "":
|
||||||
|
|||||||
22
README.md
22
README.md
@@ -27,7 +27,7 @@ Wine Runner is a program that allows Linux users to run Windows applications mor
|
|||||||
|
|
||||||
打包器视频教程:https://www.bilibili.com/video/BV1Bh4y1Q7nT/
|
打包器视频教程:https://www.bilibili.com/video/BV1Bh4y1Q7nT/
|
||||||
Wine 运行器 QQ 交流群:762985460
|
Wine 运行器 QQ 交流群:762985460
|
||||||
Wine 运行器离线包下载地址:https://www.123pan.com/s/pDSKVv-pAJWv.html
|
|
||||||
|
|
||||||
### Wine 运行器 For Termux 安装方法以及注意事项
|
### Wine 运行器 For Termux 安装方法以及注意事项
|
||||||
Wine 运行器 For Termux 使用的是独立的安装包,详细见:
|
Wine 运行器 For Termux 使用的是独立的安装包,详细见:
|
||||||
@@ -58,7 +58,8 @@ https://gfdgdxi.lanzouw.com/b0plly5cj
|
|||||||
spark-deepin-wine-runner 是普通包,spark-deepin-wine-runner-ace 是使用 ace 兼容环境运行的运行器
|
spark-deepin-wine-runner 是普通包,spark-deepin-wine-runner-ace 是使用 ace 兼容环境运行的运行器
|
||||||
|
|
||||||
## Wine 运行器离线包
|
## Wine 运行器离线包
|
||||||
需要私聊作者定制(有偿服务)
|
见小黄鱼:
|
||||||
|
https://m.tb.cn/h.g93KHpR?tk=KPeR3dH09WM
|
||||||
|
|
||||||
## 软件架构
|
## 软件架构
|
||||||
理论上支持全架构,如果 Python 能运行的话
|
理论上支持全架构,如果 Python 能运行的话
|
||||||
@@ -156,6 +157,21 @@ desktop文件中StartupWMClass字段。用于让桌面组件将窗口类名与de
|
|||||||

|

|
||||||
|
|
||||||
## 更新日志
|
## 更新日志
|
||||||
|
### 4.1.0(2024/09/15)
|
||||||
|
**※1、修复在 GXDE OS 下无法正常调用 gxde-terminal 的问题**
|
||||||
|
**※2、修复部分机器无法打开应用的问题**
|
||||||
|
**※3、修改打包器 wine 集成封装 机制以便可以被 uos 商店正确签名**
|
||||||
|
**※4、打包器支持内置 spark dwine helper**
|
||||||
|
**※5、重构虚拟机安装模块以支持更多机器**
|
||||||
|
**6、修复打包器设置依赖无法生效的问题**
|
||||||
|
**※7、补充图标**
|
||||||
|
**※8、修复 deb 安装过程中可能出现 dpkg 卡死的问题**
|
||||||
|
**※9、优化 Wine 安装器检测机制**
|
||||||
|
**※10、删除部分废弃组件**
|
||||||
|
**※11、修复 AOSC、Termux 无法正常打开 Wine 运行器的问题**
|
||||||
|
12、修改文案
|
||||||
|
13、修复其它 bug 若干
|
||||||
|
|
||||||
### 4.0.0(2024/07/22)
|
### 4.0.0(2024/07/22)
|
||||||
**※1、优化运行器窗口大小机制**
|
**※1、优化运行器窗口大小机制**
|
||||||
**※2、Wine 安装器支持根据机器实际情况自动推荐适合的 Wine**
|
**※2、Wine 安装器支持根据机器实际情况自动推荐适合的 Wine**
|
||||||
@@ -829,8 +845,6 @@ make install -j4
|
|||||||
## 请作者喝杯茶
|
## 请作者喝杯茶
|
||||||
如果您觉得 Wine 运行器对你有帮助,可以请作者喝杯茶
|
如果您觉得 Wine 运行器对你有帮助,可以请作者喝杯茶
|
||||||
<img src="Icon/QR/Wechat.png" width="250" />
|
<img src="Icon/QR/Wechat.png" width="250" />
|
||||||
<img src="Icon/QR/Alipay.jpg" width="250" />
|
|
||||||
<img src="Icon/QR/QQ.png" width="250" >
|
|
||||||
|
|
||||||
### 广告
|
### 广告
|
||||||
支付宝官方活动,扫描获得支付红包!
|
支付宝官方活动,扫描获得支付红包!
|
||||||
|
|||||||
0
README_en.md
Normal file → Executable file
0
README_en.md
Normal file → Executable file
0
RunCommandWithTerminal.py
Normal file → Executable file
0
RunCommandWithTerminal.py
Normal file → Executable file
12
StartVM.sh
12
StartVM.sh
@@ -70,7 +70,7 @@ if [[ $? == 0 ]] && [[ -f "$HOME/Qemu/Windows/Windows.qcow2" ]]; then
|
|||||||
echo X86 架构,使用 kvm 加速
|
echo X86 架构,使用 kvm 加速
|
||||||
$qemuMore qemu-system-x86_64 --enable-kvm -cpu host --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
$qemuMore qemu-system-x86_64 --enable-kvm -cpu host --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
||||||
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
||||||
-m ${use}G -display vnc=:5 -display gtk -nic model=rtl8139 $qemuUEFI \
|
-m ${use}G -display gtk -nic model=rtl8139 $qemuUEFI \
|
||||||
-device AC97 -device ES1370 -device intel-hda -device hda-duplex \
|
-device AC97 -device ES1370 -device intel-hda -device hda-duplex \
|
||||||
--boot 'splash=VM/boot.jpg,menu=on,splash-time=2000' \
|
--boot 'splash=VM/boot.jpg,menu=on,splash-time=2000' \
|
||||||
-usb \
|
-usb \
|
||||||
@@ -100,7 +100,7 @@ if [[ $? == 0 ]] && [[ -f "$HOME/Qemu/Windows/Windows.qcow2" ]]; then
|
|||||||
echo 不使用 kvm 加速
|
echo 不使用 kvm 加速
|
||||||
$qemuPath --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
$qemuPath --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
||||||
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
||||||
-m ${use}G -display vnc=:5 -display gtk -nic model=rtl8139 $qemuUEFI \
|
-m ${use}G -display gtk -nic model=rtl8139 $qemuUEFI \
|
||||||
-device AC97 -device ES1370 -device intel-hda -device hda-duplex \
|
-device AC97 -device ES1370 -device intel-hda -device hda-duplex \
|
||||||
--boot 'splash=VM/boot.jpg,menu=on,splash-time=2000' \
|
--boot 'splash=VM/boot.jpg,menu=on,splash-time=2000' \
|
||||||
> $TMPDIR/tmp/windows-virtual-machine-installer-for-wine-runner-run.log 2>&1 # 最新的 qemu 已经移除参数 -soundhw all
|
> $TMPDIR/tmp/windows-virtual-machine-installer-for-wine-runner-run.log 2>&1 # 最新的 qemu 已经移除参数 -soundhw all
|
||||||
@@ -122,7 +122,7 @@ if [[ $? == 0 ]] && [[ -f "$HOME/Qemu/Windows/Windows.qcow2" ]]; then
|
|||||||
if [[ $? == 0 ]] && [[ `arch` == "aarch64" ]]; then
|
if [[ $? == 0 ]] && [[ `arch` == "aarch64" ]]; then
|
||||||
$qemuMore qemu-system-arm --enable-kvm --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
$qemuMore qemu-system-arm --enable-kvm --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
||||||
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
||||||
-m ${use}G -display vnc=:5 -display gtk -usb -nic model=rtl8139 $qemuUEFI \
|
-m ${use}G -display gtk -usb -nic model=rtl8139 $qemuUEFI \
|
||||||
-cpu max -M virt -device virtio-gpu-pci \
|
-cpu max -M virt -device virtio-gpu-pci \
|
||||||
-device nec-usb-xhci,id=xhci,addr=0x1b \
|
-device nec-usb-xhci,id=xhci,addr=0x1b \
|
||||||
-device usb-tablet,id=tablet,bus=xhci.0,port=1 \
|
-device usb-tablet,id=tablet,bus=xhci.0,port=1 \
|
||||||
@@ -134,7 +134,7 @@ if [[ $? == 0 ]] && [[ -f "$HOME/Qemu/Windows/Windows.qcow2" ]]; then
|
|||||||
fi
|
fi
|
||||||
$qemuMore qemu-system-arm --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
$qemuMore qemu-system-arm --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
||||||
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
||||||
-m ${use}G -display vnc=:5 -display gtk -usb -nic model=rtl8139 $qemuUEFI \
|
-m ${use}G -display gtk -usb -nic model=rtl8139 $qemuUEFI \
|
||||||
-cpu max -M virt -device virtio-gpu-pci \
|
-cpu max -M virt -device virtio-gpu-pci \
|
||||||
-device nec-usb-xhci,id=xhci,addr=0x1b \
|
-device nec-usb-xhci,id=xhci,addr=0x1b \
|
||||||
-device usb-tablet,id=tablet,bus=xhci.0,port=1 \
|
-device usb-tablet,id=tablet,bus=xhci.0,port=1 \
|
||||||
@@ -160,7 +160,7 @@ if [[ $? == 0 ]] && [[ -f "$HOME/Qemu/Windows/Windows.qcow2" ]]; then
|
|||||||
if [[ $? == 0 ]] && [[ `arch` == "aarch64" ]]; then
|
if [[ $? == 0 ]] && [[ `arch` == "aarch64" ]]; then
|
||||||
$qemuMore qemu-system-aarch64 --enable-kvm --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
$qemuMore qemu-system-aarch64 --enable-kvm --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
||||||
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
||||||
-m ${use}G -display vnc=:5 -display gtk -usb -nic model=rtl8139 $qemuUEFI \
|
-m ${use}G -display gtk -usb -nic model=rtl8139 $qemuUEFI \
|
||||||
-cpu max -M virt \
|
-cpu max -M virt \
|
||||||
-device virtio-gpu-pci \
|
-device virtio-gpu-pci \
|
||||||
-device nec-usb-xhci,id=xhci,addr=0x1b \
|
-device nec-usb-xhci,id=xhci,addr=0x1b \
|
||||||
@@ -173,7 +173,7 @@ if [[ $? == 0 ]] && [[ -f "$HOME/Qemu/Windows/Windows.qcow2" ]]; then
|
|||||||
fi
|
fi
|
||||||
$qemuMore qemu-system-aarch64 --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
$qemuMore qemu-system-aarch64 --hda "$HOME/Qemu/Windows/Windows.qcow2" \
|
||||||
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
-smp $CpuCount,sockets=$CpuSocketNum,cores=$(($CpuCoreNum / $CpuSocketNum)),threads=$(($CpuCount / $CpuCoreNum / $CpuSocketNum)) \
|
||||||
-m ${use}G -display vnc=:5 -display gtk -usb -nic model=rtl8139 $qemuUEFI \
|
-m ${use}G -display gtk -usb -nic model=rtl8139 $qemuUEFI \
|
||||||
-cpu max -M virt \
|
-cpu max -M virt \
|
||||||
-device virtio-gpu-pci \
|
-device virtio-gpu-pci \
|
||||||
-device nec-usb-xhci,id=xhci,addr=0x1b \
|
-device nec-usb-xhci,id=xhci,addr=0x1b \
|
||||||
|
|||||||
0
UpdateTime.py
Normal file → Executable file
0
UpdateTime.py
Normal file → Executable file
12
VM/qemu.py
12
VM/qemu.py
@@ -86,9 +86,9 @@ class qemu:
|
|||||||
# 如果存在拓展 Qemu,则调用此
|
# 如果存在拓展 Qemu,则调用此
|
||||||
qemuPath = "/opt/apps/deepin-wine-runner-qemu-system-extra/files/run.sh qemu-system-arm"
|
qemuPath = "/opt/apps/deepin-wine-runner-qemu-system-extra/files/run.sh qemu-system-arm"
|
||||||
if(subprocess.getoutput("arch").replace("\n", "").replace(" ", "") == "aarch64" and not os.system((self.applicationDirPath() + "/kvm-ok"))):
|
if(subprocess.getoutput("arch").replace("\n", "").replace(" ", "") == "aarch64" and not os.system((self.applicationDirPath() + "/kvm-ok"))):
|
||||||
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display vnc=:5 -display gtk --enable-kvm -cpu host -M virt " + self.commandOption + " -device virtio-gpu-pci -device nec-usb-xhci,id=xhci,addr=0x1b -device usb-tablet,id=tablet,bus=xhci.0,port=1 -device usb-kbd,id=keyboard,bus=xhci.0,port=2 > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display gtk --enable-kvm -cpu host -M virt " + self.commandOption + " -device virtio-gpu-pci -device nec-usb-xhci,id=xhci,addr=0x1b -device usb-tablet,id=tablet,bus=xhci.0,port=1 -device usb-kbd,id=keyboard,bus=xhci.0,port=2 > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
||||||
|
|
||||||
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display vnc=:5 -display gtk -cpu max -M virt " + self.commandOption + " -device virtio-gpu-pci -device nec-usb-xhci,id=xhci,addr=0x1b -device usb-tablet,id=tablet,bus=xhci.0,port=1 -device usb-kbd,id=keyboard,bus=xhci.0,port=2 > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display gtk -cpu max -M virt " + self.commandOption + " -device virtio-gpu-pci -device nec-usb-xhci,id=xhci,addr=0x1b -device usb-tablet,id=tablet,bus=xhci.0,port=1 -device usb-kbd,id=keyboard,bus=xhci.0,port=2 > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
||||||
|
|
||||||
def StartAarch64(self):
|
def StartAarch64(self):
|
||||||
bootScreenLogo = ""
|
bootScreenLogo = ""
|
||||||
@@ -107,9 +107,9 @@ class qemu:
|
|||||||
|
|
||||||
print(self.commandOption)
|
print(self.commandOption)
|
||||||
if(subprocess.getoutput("arch").replace("\n", "").replace(" ", "") == "aarch64" and not os.system((self.applicationDirPath() + "/kvm-ok"))):
|
if(subprocess.getoutput("arch").replace("\n", "").replace(" ", "") == "aarch64" and not os.system((self.applicationDirPath() + "/kvm-ok"))):
|
||||||
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display vnc=:5 -display gtk --enable-kvm -cpu host -M virt " + self.commandOption + " -device virtio-gpu-pci -device nec-usb-xhci,id=xhci,addr=0x1b -device usb-tablet,id=tablet,bus=xhci.0,port=1 -device usb-kbd,id=keyboard,bus=xhci.0,port=2 > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display gtk --enable-kvm -cpu host -M virt " + self.commandOption + " -device virtio-gpu-pci -device nec-usb-xhci,id=xhci,addr=0x1b -device usb-tablet,id=tablet,bus=xhci.0,port=1 -device usb-kbd,id=keyboard,bus=xhci.0,port=2 > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
||||||
|
|
||||||
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display vnc=:5 -display gtk -cpu max -M virt " + self.commandOption + " -device virtio-gpu-pci -device nec-usb-xhci,id=xhci,addr=0x1b -device usb-tablet,id=tablet,bus=xhci.0,port=1 -device usb-kbd,id=keyboard,bus=xhci.0,port=2 > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display gtk -cpu max -M virt " + self.commandOption + " -device virtio-gpu-pci -device nec-usb-xhci,id=xhci,addr=0x1b -device usb-tablet,id=tablet,bus=xhci.0,port=1 -device usb-kbd,id=keyboard,bus=xhci.0,port=2 > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
||||||
|
|
||||||
def StartLoong64(self):
|
def StartLoong64(self):
|
||||||
return 1
|
return 1
|
||||||
@@ -134,8 +134,8 @@ class qemu:
|
|||||||
qemuPath = "/opt/apps/deepin-wine-runner-qemu-system-extra/files/run.sh qemu-system-x86_64"
|
qemuPath = "/opt/apps/deepin-wine-runner-qemu-system-extra/files/run.sh qemu-system-x86_64"
|
||||||
print(self.commandOption)
|
print(self.commandOption)
|
||||||
if(subprocess.getoutput("arch").replace("\n", "").replace(" ", "") == "x86_64" and not os.system((self.applicationDirPath() + "/kvm-ok"))):
|
if(subprocess.getoutput("arch").replace("\n", "").replace(" ", "") == "x86_64" and not os.system((self.applicationDirPath() + "/kvm-ok"))):
|
||||||
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display vnc=:5 -display gtk --enable-kvm -cpu host " + newCommandOption + " > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display gtk --enable-kvm -cpu host " + newCommandOption + " > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
||||||
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display vnc=:5 -display gtk -nic model=rtl8139 " + newCommandOption + " > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
return os.system((qemuPath + " --boot 'splash=" + self.GetBootLogoPath() + ",order=d,menu=on,splash-time=2000' -display gtk -nic model=rtl8139 " + newCommandOption + " > /tmp/windows-virtual-machine-installer-for-wine-runner-install.log 2>&1 &"))
|
||||||
|
|
||||||
def Stop(self):
|
def Stop(self):
|
||||||
os.system("killall qemu-system-x86_64 -9")
|
os.system("killall qemu-system-x86_64 -9")
|
||||||
|
|||||||
290
VM/test-kvm.asm
Normal file
290
VM/test-kvm.asm
Normal file
@@ -0,0 +1,290 @@
|
|||||||
|
mov ax,0xb800
|
||||||
|
mov es,ax
|
||||||
|
; 清屏
|
||||||
|
mov cx,80*25
|
||||||
|
clean:
|
||||||
|
mov di,cx
|
||||||
|
add di,di
|
||||||
|
mov byte [es:di],''
|
||||||
|
add di,1
|
||||||
|
mov byte [es:di],0x0F
|
||||||
|
loop clean
|
||||||
|
; 显示上方白条
|
||||||
|
; 移除(0,0)的S字符
|
||||||
|
mov byte [es:0x00],''
|
||||||
|
mov cx,80*2-1
|
||||||
|
mov di,0
|
||||||
|
push cx
|
||||||
|
headtitle:
|
||||||
|
mov di,cx
|
||||||
|
mov byte [es:di],0xF0
|
||||||
|
; 写入空字符
|
||||||
|
add di,di
|
||||||
|
mov byte [es:di],''
|
||||||
|
;inc cx
|
||||||
|
;sub cx,1
|
||||||
|
loop headtitle
|
||||||
|
|
||||||
|
xor di,di
|
||||||
|
pop cx
|
||||||
|
; 显示下方白条
|
||||||
|
tailtitle:
|
||||||
|
mov di,cx
|
||||||
|
add di,80*2*24
|
||||||
|
mov byte [es:di],0xF0
|
||||||
|
; 写入空字符
|
||||||
|
mov di,cx
|
||||||
|
add di,di
|
||||||
|
add di,80*2*24
|
||||||
|
mov byte [es:di],''
|
||||||
|
loop tailtitle
|
||||||
|
; 在第一行写入文本
|
||||||
|
jmp near showHeadText
|
||||||
|
headText: db 'Wine Runner Webiste:http://gitee.com/gfdgd-xi/deep-wine-runner'
|
||||||
|
showHeadText:
|
||||||
|
; 虽然可以简单粗暴的用 movsw,但是会出现问题
|
||||||
|
mov cx,showHeadText-headText
|
||||||
|
mov ax,0x7c0
|
||||||
|
mov ds,ax ; 定位到汇编程序所在的内存地址
|
||||||
|
showHeadTextLoop:
|
||||||
|
mov dx,cx
|
||||||
|
mov di,cx
|
||||||
|
add di,di
|
||||||
|
mov si,headText
|
||||||
|
sub dx,1
|
||||||
|
add si,dx
|
||||||
|
; inc si
|
||||||
|
; mov al,1000
|
||||||
|
mov al,[ds:si]
|
||||||
|
mov byte [es:di],al
|
||||||
|
loop showHeadTextLoop
|
||||||
|
jmp near showTailText
|
||||||
|
tailText: db '2020~Now gfdgd xi'
|
||||||
|
showTailText:
|
||||||
|
mov cx,showTailText-tailText
|
||||||
|
mov ax,0x7c0
|
||||||
|
mov ds,ax
|
||||||
|
showTailTextLoop:
|
||||||
|
mov dx,cx
|
||||||
|
mov di,cx
|
||||||
|
add di,di
|
||||||
|
add di,80*2*24
|
||||||
|
mov si,tailText
|
||||||
|
sub dx,1
|
||||||
|
add si,dx
|
||||||
|
mov al,[ds:si]
|
||||||
|
mov byte [es:di],al
|
||||||
|
loop showTailTextLoop
|
||||||
|
|
||||||
|
; 显示中部提示文本
|
||||||
|
jmp near showCenterText
|
||||||
|
centerTextScreenSize:
|
||||||
|
; 第一位是行数
|
||||||
|
; 第二位是单行偏移量
|
||||||
|
db 1, -1
|
||||||
|
centerText:
|
||||||
|
db 'Mode: Real Mode Demo', 0x0A
|
||||||
|
db 'Bit: 16', 0x0A
|
||||||
|
db 'Virtual Machine: qemu-system-i386'
|
||||||
|
db 0x03 ; 结束符
|
||||||
|
showCenterText:
|
||||||
|
centerTextLong equ showCenterText-centerText
|
||||||
|
mov cx,centerTextLong
|
||||||
|
xor ax,ax
|
||||||
|
loopShowCenterText:
|
||||||
|
jmp near addScreenLineFinish
|
||||||
|
addScreenLine:
|
||||||
|
; 如果检测到换行符
|
||||||
|
mov dx, [centerTextScreenSize]
|
||||||
|
add dx,1
|
||||||
|
mov [centerTextScreenSize], dx
|
||||||
|
dec cx
|
||||||
|
mov al,-1
|
||||||
|
mov [centerTextScreenSize+1],al
|
||||||
|
; 行数+1,偏移量设为 -1(从头开始)
|
||||||
|
;ret
|
||||||
|
addScreenLineFinish:
|
||||||
|
; 偏移量 + 1
|
||||||
|
mov al,[centerTextScreenSize+1]
|
||||||
|
add al,1
|
||||||
|
mov [centerTextScreenSize+1],al
|
||||||
|
mov di,centerText
|
||||||
|
add di,centerTextLong
|
||||||
|
sub di,cx
|
||||||
|
mov bl,[di]
|
||||||
|
|
||||||
|
; 判断是不是结束符
|
||||||
|
cmp bl,0x03
|
||||||
|
je showCenterTextEnd
|
||||||
|
|
||||||
|
; 判断是不是换行符
|
||||||
|
cmp bl,0x0A
|
||||||
|
je addScreenLine ; 换行符检测
|
||||||
|
|
||||||
|
xor ah,ah ; 清空高位
|
||||||
|
add al,al
|
||||||
|
mov di,ax
|
||||||
|
|
||||||
|
; 计算显示位置
|
||||||
|
xor dx,dx
|
||||||
|
mov dl,[centerTextScreenSize]
|
||||||
|
mov ax,80
|
||||||
|
mul dx
|
||||||
|
mov dx,2
|
||||||
|
mul dx
|
||||||
|
add ax,2
|
||||||
|
add di,ax
|
||||||
|
|
||||||
|
; 显示
|
||||||
|
mov byte [es:di], bl
|
||||||
|
loop loopShowCenterText
|
||||||
|
|
||||||
|
showCenterTextEnd:
|
||||||
|
|
||||||
|
;mov ax,[cs:0x100]
|
||||||
|
;mov dx,[cs:0x102]
|
||||||
|
; mov bx,16
|
||||||
|
; div bx
|
||||||
|
; mov ds,ax
|
||||||
|
; mov es,ax
|
||||||
|
;xor di,di
|
||||||
|
;mov si,1
|
||||||
|
;xor ds,ds
|
||||||
|
;mov bx,512
|
||||||
|
;xor bx,bx
|
||||||
|
;call read_hard_disk_0
|
||||||
|
|
||||||
|
|
||||||
|
get_data:
|
||||||
|
mov di,80*2*25-2
|
||||||
|
|
||||||
|
; 读取秒
|
||||||
|
mov al,0x00
|
||||||
|
call read_time
|
||||||
|
mov byte [es:di-4],':'
|
||||||
|
mov byte [es:di-2],ah
|
||||||
|
mov byte [es:di],al
|
||||||
|
; 读取分钟
|
||||||
|
mov al,0x02
|
||||||
|
call read_time
|
||||||
|
mov byte [es:di-10],':'
|
||||||
|
mov byte [es:di-8],ah
|
||||||
|
mov byte [es:di-6],al
|
||||||
|
; 读取小时
|
||||||
|
mov al,0x04
|
||||||
|
call read_time
|
||||||
|
mov byte [es:di-14],ah
|
||||||
|
mov byte [es:di-12],al
|
||||||
|
; 读取日
|
||||||
|
mov al,0x07
|
||||||
|
call read_time
|
||||||
|
mov byte [es:di-22],'.'
|
||||||
|
mov byte [es:di-20],ah
|
||||||
|
mov byte [es:di-18],al
|
||||||
|
; 读取月
|
||||||
|
mov al,0x08
|
||||||
|
call read_time
|
||||||
|
mov byte [es:di-28],'.'
|
||||||
|
mov byte [es:di-26],ah
|
||||||
|
mov byte [es:di-24],al
|
||||||
|
; 读取年
|
||||||
|
mov al,0x09
|
||||||
|
call read_time
|
||||||
|
mov byte [es:di-32],ah
|
||||||
|
mov byte [es:di-30],al
|
||||||
|
|
||||||
|
|
||||||
|
hlt ; 使用停机指令降低 CPU 使用率
|
||||||
|
jmp near get_data
|
||||||
|
|
||||||
|
|
||||||
|
read_time:
|
||||||
|
out 0x70,al
|
||||||
|
in al,0x71
|
||||||
|
call bcd_to_ascii
|
||||||
|
ret
|
||||||
|
|
||||||
|
; 用于编码转换:BCD=》ASCII
|
||||||
|
; 输入:AL=bcd码
|
||||||
|
; 输出:AX=ascii
|
||||||
|
bcd_to_ascii:
|
||||||
|
mov ah,al
|
||||||
|
and al,0x0f
|
||||||
|
add al,0x30
|
||||||
|
|
||||||
|
shr ah,4
|
||||||
|
and ah,0x0f
|
||||||
|
add ah,0x30
|
||||||
|
ret
|
||||||
|
|
||||||
|
;poweroff:
|
||||||
|
; 关机
|
||||||
|
; mov ax,5307H ; 高级电源管理功能,设置电源状态
|
||||||
|
; mov bx,0001H ; 设备ID,1:所有设备
|
||||||
|
; mov cx,0003H ; 状态,3:表示关机
|
||||||
|
; int 15h
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
end:
|
||||||
|
times 510-($-$$) db 0
|
||||||
|
db 0x55,0xaa
|
||||||
|
|
||||||
|
; 后面部分暂时废弃
|
||||||
|
|
||||||
|
|
||||||
|
read_hard_disk_0: ; 从硬盘读取一个逻辑扇区
|
||||||
|
; 输入:DI:SI=起始逻辑扇区号
|
||||||
|
; DS:BX=目标缓冲区地址
|
||||||
|
push ax
|
||||||
|
push bx
|
||||||
|
push cx
|
||||||
|
push dx
|
||||||
|
|
||||||
|
mov dx,0x1f2
|
||||||
|
mov al,1
|
||||||
|
out dx,al ; 读取的扇区数
|
||||||
|
|
||||||
|
inc dx ; 0x1f3
|
||||||
|
mov ax,si
|
||||||
|
out dx,al ; LBA地址7~0
|
||||||
|
|
||||||
|
inc dx ; 0x1f4
|
||||||
|
mov al,ah
|
||||||
|
out dx,al ; LBA地址15~8
|
||||||
|
|
||||||
|
inc dx ; 0x1f5
|
||||||
|
mov ax,di
|
||||||
|
out dx,al ; LBA地址23~16
|
||||||
|
|
||||||
|
inc dx ; 0x1f6
|
||||||
|
mov al,0xe0 ; LBA28模式,主盘
|
||||||
|
or al,ah ; LBA地址27~24
|
||||||
|
out dx,al
|
||||||
|
|
||||||
|
inc dx ; 0x1f7
|
||||||
|
mov al,0x20 ; 读命令
|
||||||
|
out dx,al
|
||||||
|
|
||||||
|
.waits:
|
||||||
|
in al,dx ; 此时 dx 为 0x1f7,此时为命令端口也是状态窗口
|
||||||
|
and al,0x88
|
||||||
|
cmp al,0x08
|
||||||
|
jnz .waits
|
||||||
|
; 内部操作期间,会将 0x1f7 端口第 7 位设置为“1”,准备就绪后会将此位清零,并将第 3 位设为 1
|
||||||
|
|
||||||
|
mov cx,256 ; 总计要读取的/字/数
|
||||||
|
mov dx,0x1f0
|
||||||
|
|
||||||
|
.readw:
|
||||||
|
in ax,dx
|
||||||
|
mov [bx],ax
|
||||||
|
add bx,2
|
||||||
|
loop .readw
|
||||||
|
|
||||||
|
pop dx
|
||||||
|
pop cx
|
||||||
|
pop bx
|
||||||
|
pop ax
|
||||||
|
|
||||||
|
|
||||||
54
WindowModule.py
Executable file
54
WindowModule.py
Executable file
@@ -0,0 +1,54 @@
|
|||||||
|
# 用于实现窗口模块化的组件和调用封装
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import PyQt5.QtWidgets as QtWidgets
|
||||||
|
|
||||||
|
moduleNameList = {
|
||||||
|
"mainwindow": {
|
||||||
|
"Name": "运行器",
|
||||||
|
"RepeatShow": False
|
||||||
|
},
|
||||||
|
"deepin-wine-easy-packager": {
|
||||||
|
"Name": "简易打包器",
|
||||||
|
"RepeatShow": False
|
||||||
|
},
|
||||||
|
"deepin-wine-packager": {
|
||||||
|
"Name": "专业打包器",
|
||||||
|
"RepeatShow": False
|
||||||
|
},
|
||||||
|
"VM.mainwindow": {
|
||||||
|
"Name": "虚拟机管理工具",
|
||||||
|
"RepeatShow": True
|
||||||
|
},
|
||||||
|
"wine.installwine": {
|
||||||
|
"Name": "Wine 安装工具",
|
||||||
|
"RepeatShow": True
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class RunnerWindow:
|
||||||
|
programPath = os.path.split(os.path.realpath(__file__))[0] # 获取当前程序目录
|
||||||
|
import globalenv
|
||||||
|
recycleTime = 0
|
||||||
|
def __init__(self, app: QtWidgets.QApplication, moduleName: str) -> None:
|
||||||
|
self.globalenv._init() # globalenv 的 init 是必须的,这样才能正确的 import Wine 运行器的窗口
|
||||||
|
self.globalenv.set_value("app", app) # 用于将该部分的 app 给子模块的 Qt 控件调用以解决 UI 异常以及其它问题
|
||||||
|
# 因为 Python 有不允许重复 import 的特性从而导致多次返回的控件实际指向同一对象,所以要通过特殊的方式绕过这一限制
|
||||||
|
# 将使用指向程序所在文件夹的超链接以改变库名称从而实现每次引入时命名控件不同
|
||||||
|
# 通过嵌套多个 local.local.local 以解决问题
|
||||||
|
# 同理可以利用该特性使用 globalenv 传值
|
||||||
|
if (not os.path.exists(f"{self.programPath}/local")):
|
||||||
|
# 没有存在该超链接,不启用该机制
|
||||||
|
self.globalenv.set_value("app", app)
|
||||||
|
self.mainwindow = __import__(moduleName, fromlist=["mainwindow"])
|
||||||
|
return
|
||||||
|
while True:
|
||||||
|
self.recycleTime += 1
|
||||||
|
testModuleName = "local." * self.recycleTime + moduleName
|
||||||
|
if (not testModuleName in sys.modules):
|
||||||
|
self.mainwindow = __import__(testModuleName, fromlist=["mainwindow"]) # 设置 fromlist 就不会返回最上层节点,及 local
|
||||||
|
break
|
||||||
|
|
||||||
|
def Win(self) -> QtWidgets.QMainWindow:
|
||||||
|
# 输出窗口
|
||||||
|
return self.mainwindow.window
|
||||||
@@ -18,7 +18,7 @@ Depends: python3,
|
|||||||
python3-requests,
|
python3-requests,
|
||||||
python3-pyqt5 | pyqt5,
|
python3-pyqt5 | pyqt5,
|
||||||
python3-psutil | pypsutil,
|
python3-psutil | pypsutil,
|
||||||
xfce4-terminal | deepin-terminal-gtk | deepin-terminal | mate-terminal | gnome-terminal,
|
xfce4-terminal | gxde-terminal | deepin-terminal | mate-terminal | gnome-terminal,
|
||||||
python3-dbus,
|
python3-dbus,
|
||||||
python3-pip | pip, p7zip-full | p7zip-legacy | p7zip,
|
python3-pip | pip, p7zip-full | p7zip-legacy | p7zip,
|
||||||
sudo,
|
sudo,
|
||||||
|
|||||||
@@ -750,13 +750,13 @@ try:
|
|||||||
exePath.setText(sys.argv[1])
|
exePath.setText(sys.argv[1])
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
if (__name__ != "__main__"):
|
'''if (__name__ != "__main__"):
|
||||||
# 设置滚动条
|
# 设置滚动条
|
||||||
areaScroll = QtWidgets.QScrollArea(window)
|
areaScroll = QtWidgets.QScrollArea(window)
|
||||||
areaScroll.setWidgetResizable(True)
|
areaScroll.setWidgetResizable(True)
|
||||||
areaScroll.setWidget(widget)
|
areaScroll.setWidget(widget)
|
||||||
areaScroll.setFrameShape(QtWidgets.QFrame.NoFrame)
|
areaScroll.setFrameShape(QtWidgets.QFrame.NoFrame)
|
||||||
window.setCentralWidget(areaScroll)
|
window.setCentralWidget(areaScroll)'''
|
||||||
|
|
||||||
if (__name__ == "__main__"):
|
if (__name__ == "__main__"):
|
||||||
window.resize(int(window.frameGeometry().width() * 1.2), int(window.frameGeometry().height() * 1.1))
|
window.resize(int(window.frameGeometry().width() * 1.2), int(window.frameGeometry().height() * 1.1))
|
||||||
|
|||||||
File diff suppressed because it is too large
Load Diff
0
deepin-wine-runner_512x512.png
Normal file → Executable file
0
deepin-wine-runner_512x512.png
Normal file → Executable file
|
Before Width: | Height: | Size: 34 KiB After Width: | Height: | Size: 34 KiB |
0
globalenv.py
Normal file → Executable file
0
globalenv.py
Normal file → Executable file
2
information.json
Normal file → Executable file
2
information.json
Normal file → Executable file
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"Version": "4.0.0.2",
|
"Version": "4.1.0.0",
|
||||||
"Time": "未知",
|
"Time": "未知",
|
||||||
"Thank": [
|
"Thank": [
|
||||||
"感谢 @り哥拽的冇气质° 和 @杨 提供了 3a5000(新世界的测试机器)",
|
"感谢 @り哥拽的冇气质° 和 @杨 提供了 3a5000(新世界的测试机器)",
|
||||||
|
|||||||
213
main.py
Normal file → Executable file
213
main.py
Normal file → Executable file
@@ -1,41 +1,31 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
# 库的引用
|
# 库的引用
|
||||||
import os
|
|
||||||
import PyQt5.QtWidgets as QtWidgets
|
import PyQt5.QtWidgets as QtWidgets
|
||||||
import PyQt5.QtGui as QtGui
|
import PyQt5.QtGui as QtGui
|
||||||
import PyQt5.QtCore as QtCore
|
import PyQt5.QtCore as QtCore
|
||||||
import importlib
|
|
||||||
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
import json
|
||||||
|
import welcome
|
||||||
|
import subprocess
|
||||||
|
import WindowModule
|
||||||
|
|
||||||
class RunnerWindow:
|
# 读取文本文档
|
||||||
programPath = os.path.split(os.path.realpath(__file__))[0] # 获取当前程序目录
|
def readtxt(path):
|
||||||
import globalenv
|
f = open(path, "r") # 设置文件对象
|
||||||
recycleTime = 0
|
str = f.read() # 获取内容
|
||||||
def __init__(self, app: QtWidgets.QApplication, moduleName: str):
|
f.close() # 关闭文本对象
|
||||||
self.globalenv._init() # globalenv 的 init 是必须的,这样才能正确的 import Wine 运行器的窗口
|
return str # 返回结果
|
||||||
self.globalenv.set_value("app", app) # 用于将该部分的 app 给子模块的 Qt 控件调用以解决 UI 异常以及其它问题
|
|
||||||
# 因为 Python 有不允许重复 import 的特性从而导致多次返回的控件实际指向同一对象,所以要通过特殊的方式绕过这一限制
|
|
||||||
# 将使用指向程序所在文件夹的超链接以改变库名称从而实现每次引入时命名控件不同
|
|
||||||
# 通过嵌套多个 local.local.local 以解决问题
|
|
||||||
# 同理可以利用该特性使用 globalenv 传值
|
|
||||||
if (not os.path.exists(f"{self.programPath}/local")):
|
|
||||||
# 没有存在该超链接,不启用该机制
|
|
||||||
self.globalenv.set_value("app", app)
|
|
||||||
self.mainwindow = __import__(moduleName, fromlist=["mainwindow"])
|
|
||||||
return
|
|
||||||
while True:
|
|
||||||
self.recycleTime += 1
|
|
||||||
testModuleName = "local." * self.recycleTime + moduleName
|
|
||||||
if (not testModuleName in sys.modules):
|
|
||||||
self.mainwindow = __import__(testModuleName, fromlist=["mainwindow"]) # 设置 fromlist 就不会返回最上层节点,及 local
|
|
||||||
break
|
|
||||||
|
|
||||||
def Win(self) -> QtWidgets.QMainWindow:
|
|
||||||
# 输出窗口
|
|
||||||
return self.mainwindow.window
|
|
||||||
|
|
||||||
|
def ProgramVersion():
|
||||||
|
information = json.loads(readtxt(f"{programPath}/information.json"))
|
||||||
|
return information["Version"]
|
||||||
|
|
||||||
# 创建界面
|
# 创建界面
|
||||||
class Window(QtWidgets.QWidget):
|
class Window(QtWidgets.QWidget):
|
||||||
|
moduleMapList = {}
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
super().__init__()
|
super().__init__()
|
||||||
self.counter_a = 1
|
self.counter_a = 1
|
||||||
@@ -46,7 +36,7 @@ class Window(QtWidgets.QWidget):
|
|||||||
|
|
||||||
def initUI(self):
|
def initUI(self):
|
||||||
self.setMinimumSize(800, 600)
|
self.setMinimumSize(800, 600)
|
||||||
self.setWindowTitle("增减测试")
|
self.setWindowTitle("Wine 运行器 {}".format(ProgramVersion()))
|
||||||
self.mainLayout = QtWidgets.QHBoxLayout()
|
self.mainLayout = QtWidgets.QHBoxLayout()
|
||||||
self.setLayout(self.mainLayout)
|
self.setLayout(self.mainLayout)
|
||||||
|
|
||||||
@@ -54,91 +44,163 @@ class Window(QtWidgets.QWidget):
|
|||||||
self.leftWidget = LeftWidget()
|
self.leftWidget = LeftWidget()
|
||||||
self.mainLayout.addWidget(self.leftWidget)
|
self.mainLayout.addWidget(self.leftWidget)
|
||||||
|
|
||||||
self.leftWidget.btn1.clicked.connect(self.addA)
|
time = 0
|
||||||
self.leftWidget.btn2.clicked.connect(self.addB)
|
for i in WindowModule.moduleNameList.keys():
|
||||||
self.leftWidget.btn3.clicked.connect(self.addC)
|
self.moduleMapList[self.leftWidget.actionList[i].text()] = [i, WindowModule.moduleNameList[i]["Name"]]
|
||||||
self.leftWidget.btn4.clicked.connect(self.delCurrent)
|
self.leftWidget.actionList[i].triggered.connect(lambda: self.add(self.sender().text()))
|
||||||
|
|
||||||
|
#self.leftWidget.btn4.clicked.connect(self.delCurrent)
|
||||||
self.leftWidget.list1.itemClicked.connect(self.switchWidget)
|
self.leftWidget.list1.itemClicked.connect(self.switchWidget)
|
||||||
|
|
||||||
# 右侧区域
|
# 右侧区域
|
||||||
self.rightWidget = RightWidget()
|
self.rightWidget = RightWidget()
|
||||||
self.mainLayout.addWidget(self.rightWidget)
|
self.mainLayout.addWidget(self.rightWidget)
|
||||||
|
|
||||||
# 新增a类界面
|
self.addWelcome()
|
||||||
def addA(self):
|
|
||||||
self.newTab = "a类页面#{0}".format(self.counter_a)
|
# 判断运行器是否为第一次打开,如果不是则默认切换至 Wine 运行器主窗口
|
||||||
|
# 默认为列表里的第一个控件
|
||||||
|
if (os.path.exists(get_home() + "/.config/deepin-wine-runner")):
|
||||||
|
self.add(self.leftWidget.actionList[list(WindowModule.moduleNameList.keys())[0]].text())
|
||||||
|
self.ConfigureConfigFile()
|
||||||
|
|
||||||
|
|
||||||
|
# 新增欢迎界面
|
||||||
|
def addWelcome(self):
|
||||||
|
self.newTab = "欢迎页面"
|
||||||
|
self.leftWidget.list1.addItem(self.newTab)
|
||||||
|
|
||||||
|
self.newWidget = welcome.WinWelcome()
|
||||||
|
self.widgetList.append(self.newWidget)
|
||||||
|
self.rightWidget.addWidget(self.newWidget)
|
||||||
|
|
||||||
|
# 新增界面
|
||||||
|
def add(self, actionName: str):
|
||||||
|
self.newInfo = "{}#{}".format(self.moduleMapList[actionName][1], self.counter_a)
|
||||||
|
self.newTab = ItemWidget(self.newInfo)
|
||||||
|
self.newTab.btn.clicked.connect(self.delCurrent)
|
||||||
self.counter_a += 1
|
self.counter_a += 1
|
||||||
self.leftWidget.list1.addItem(self.newTab)
|
self.leftWidget.list1.addItem(self.newTab)
|
||||||
|
self.leftWidget.list1.setItemWidget(self.newTab, self.newTab.widget)
|
||||||
|
|
||||||
self.newWidget = RunnerWindow(app, "mainwindow").Win()
|
self.newWidget = WindowModule.RunnerWindow(app, self.moduleMapList[actionName][0]).Win()
|
||||||
print(self.newWidget)
|
|
||||||
self.widgetList.append(self.newWidget)
|
self.widgetList.append(self.newWidget)
|
||||||
self.rightWidget.addWidget(self.newWidget)
|
self.rightWidget.addWidget(self.newWidget)
|
||||||
|
|
||||||
# 新增b类界面
|
# 自动切换新打开的页面
|
||||||
def addB(self):
|
self.leftWidget.list1.setCurrentRow(self.leftWidget.list1.model().rowCount() - 1) # 设置选择最后一项
|
||||||
self.newTab = "b类页面#{0}".format(self.counter_b)
|
self.switchWidget()
|
||||||
self.counter_b += 1
|
|
||||||
self.leftWidget.list1.addItem(self.newTab)
|
|
||||||
|
|
||||||
self.newWidget = RunnerWindow(app, "deepin-wine-packager").Win()
|
|
||||||
self.widgetList.append(self.newWidget)
|
|
||||||
self.rightWidget.addWidget(self.newWidget)
|
|
||||||
|
|
||||||
# 新增c类界面
|
|
||||||
def addC(self):
|
|
||||||
self.newTab = "c类页面#{0}".format(self.counter_c)
|
|
||||||
self.counter_c += 1
|
|
||||||
self.leftWidget.list1.addItem(self.newTab)
|
|
||||||
self.newWidget = RunnerWindow(app, "VM.mainwindow").Win()
|
|
||||||
self.widgetList.append(self.newWidget)
|
|
||||||
self.rightWidget.addWidget(self.newWidget)
|
|
||||||
|
|
||||||
# 删除_本页面
|
# 删除_本页面
|
||||||
def delCurrent(self):
|
def delCurrent(self):
|
||||||
|
self.length = self.leftWidget.list1.count()
|
||||||
|
print(self.length)
|
||||||
self.row = self.leftWidget.list1.currentRow()
|
self.row = self.leftWidget.list1.currentRow()
|
||||||
|
print(self.row)
|
||||||
|
if self.row == 0:
|
||||||
|
return 0
|
||||||
self.leftWidget.list1.takeItem(self.row)
|
self.leftWidget.list1.takeItem(self.row)
|
||||||
self.rightWidget.removeWidget(self.widgetList[self.row])
|
self.rightWidget.removeWidget(self.widgetList[self.row])
|
||||||
|
self.widgetList.pop(self.row)
|
||||||
|
|
||||||
|
# 将新界面的关闭按钮设为可用
|
||||||
|
if self.row == self.length - 1:
|
||||||
|
if self.row == 1:
|
||||||
|
return 0
|
||||||
|
else:
|
||||||
|
self.leftWidget.list1.item(self.row - 1).btnEnable()
|
||||||
|
else:
|
||||||
|
self.leftWidget.list1.item(self.row).btnEnable()
|
||||||
|
|
||||||
# 切换页面
|
# 切换页面
|
||||||
def switchWidget(self):
|
def switchWidget(self):
|
||||||
self.row = self.leftWidget.list1.currentRow()
|
self.row = self.leftWidget.list1.currentRow()
|
||||||
self.rightWidget.setCurrentIndex(self.row)
|
self.rightWidget.setCurrentIndex(self.row)
|
||||||
|
|
||||||
|
# 将当前页的关闭按钮设为可用
|
||||||
|
for i in range(self.leftWidget.list1.count()):
|
||||||
|
if i == 0:
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
self.leftWidget.list1.item(i).btnDisable()
|
||||||
|
if self.row != 0:
|
||||||
|
self.leftWidget.list1.currentItem().btnEnable()
|
||||||
|
|
||||||
|
|
||||||
|
def ConfigureConfigFile(self):
|
||||||
|
if not os.path.exists(get_home() + "/.config/"): # 如果没有配置文件夹
|
||||||
|
os.mkdir(get_home() + "/.config/") # 创建配置文件夹
|
||||||
|
if not os.path.exists(get_home() + "/.config/deepin-wine-runner"): # 如果没有配置文件夹
|
||||||
|
os.mkdir(get_home() + "/.config/deepin-wine-runner") # 创建配置文件夹
|
||||||
|
|
||||||
# 左侧区域
|
# 左侧区域
|
||||||
class LeftWidget(QtWidgets.QWidget):
|
class LeftWidget(QtWidgets.QWidget):
|
||||||
|
actionList = {}
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
super().__init__()
|
super().__init__()
|
||||||
self.initUI()
|
self.initUI()
|
||||||
|
|
||||||
def initUI(self):
|
def initUI(self):
|
||||||
self.setFixedWidth(100)
|
self.setFixedWidth(120)
|
||||||
self.mainLayout = QtWidgets.QVBoxLayout()
|
self.mainLayout = QtWidgets.QVBoxLayout()
|
||||||
|
self.mainLayout.setContentsMargins(0, 0, 0, 0)
|
||||||
self.setLayout(self.mainLayout)
|
self.setLayout(self.mainLayout)
|
||||||
|
|
||||||
# 左侧标题
|
# 左侧标题
|
||||||
self.lab1 = QtWidgets.QLabel("页面导航区")
|
self.lab1 = QtWidgets.QLabel("<h2>页面导航区</h2>")
|
||||||
self.mainLayout.addWidget(self.lab1)
|
self.mainLayout.addWidget(self.lab1)
|
||||||
|
|
||||||
|
# 新建页面面按钮
|
||||||
|
self.btnAdd = QtWidgets.QPushButton("新建界面")
|
||||||
|
self.mainLayout.addWidget(self.btnAdd)
|
||||||
|
self.menuAdd = QtWidgets.QMenu()
|
||||||
|
self.btnAdd.setMenu(self.menuAdd)
|
||||||
|
|
||||||
|
for i in WindowModule.moduleNameList.keys():
|
||||||
|
action = QtWidgets.QAction("新建{}".format(WindowModule.moduleNameList[i]["Name"]))
|
||||||
|
self.actionList[i] = action
|
||||||
|
self.menuAdd.addAction(action)
|
||||||
|
|
||||||
# 左侧页面列表
|
# 左侧页面列表
|
||||||
self.list1 = QtWidgets.QListWidget()
|
self.list1 = QtWidgets.QListWidget()
|
||||||
self.mainLayout.addWidget(self.list1)
|
self.mainLayout.addWidget(self.list1)
|
||||||
|
|
||||||
# 新增a类按钮
|
|
||||||
self.btn1 = QtWidgets.QPushButton("新增a类界面")
|
|
||||||
self.mainLayout.addWidget(self.btn1)
|
|
||||||
|
|
||||||
# 新增b类按钮
|
|
||||||
self.btn2 = QtWidgets.QPushButton("新增b类界面")
|
|
||||||
self.mainLayout.addWidget(self.btn2)
|
|
||||||
|
|
||||||
# 新增c类按钮
|
|
||||||
self.btn3 = QtWidgets.QPushButton("新增c类界面")
|
|
||||||
self.mainLayout.addWidget(self.btn3)
|
|
||||||
|
|
||||||
# 删_页面按钮
|
# 删_页面按钮
|
||||||
self.btn4 = QtWidgets.QPushButton("删除_本页面")
|
self.archLabel = QtWidgets.QLabel("系统架构:{}".format(subprocess.getoutput("dpkg --print-architecture")))
|
||||||
self.mainLayout.addWidget(self.btn4)
|
self.mainLayout.addWidget(self.archLabel)
|
||||||
|
|
||||||
|
# 列表项目组件
|
||||||
|
class ItemWidget(QtWidgets.QListWidgetItem):
|
||||||
|
def __init__(self, info):
|
||||||
|
super().__init__()
|
||||||
|
self.info = info
|
||||||
|
self.initUI()
|
||||||
|
|
||||||
|
def initUI(self):
|
||||||
|
self.widget = QtWidgets.QWidget()
|
||||||
|
self.mainLayout = QtWidgets.QHBoxLayout()
|
||||||
|
self.mainLayout.setContentsMargins(2, 0, 0, 0)
|
||||||
|
self.widget.setLayout(self.mainLayout)
|
||||||
|
|
||||||
|
# 文字标签
|
||||||
|
self.lab = QtWidgets.QLabel(self.info)
|
||||||
|
self.mainLayout.addWidget(self.lab)
|
||||||
|
self.mainLayout.addStretch()
|
||||||
|
|
||||||
|
# 关闭按钮
|
||||||
|
self.btn = QtWidgets.QPushButton("x")
|
||||||
|
#self.btn.setMaximumWidth(20)
|
||||||
|
self.btn.setEnabled(False)
|
||||||
|
self.mainLayout.addWidget(self.btn)
|
||||||
|
|
||||||
|
# 将按钮设为可用
|
||||||
|
def btnEnable(self):
|
||||||
|
self.btn.setEnabled(True)
|
||||||
|
|
||||||
|
# 将按钮设为不可用
|
||||||
|
def btnDisable(self):
|
||||||
|
self.btn.setEnabled(False)
|
||||||
|
|
||||||
# 右侧区域
|
# 右侧区域
|
||||||
class RightWidget(QtWidgets.QStackedWidget):
|
class RightWidget(QtWidgets.QStackedWidget):
|
||||||
@@ -148,9 +210,18 @@ class RightWidget(QtWidgets.QStackedWidget):
|
|||||||
|
|
||||||
#def initUI(self):
|
#def initUI(self):
|
||||||
|
|
||||||
|
# 获取用户主目录
|
||||||
|
def get_home():
|
||||||
|
return os.path.expanduser('~')
|
||||||
|
|
||||||
|
programPath = os.path.split(os.path.realpath(__file__))[0] # 返回 string
|
||||||
|
iconPath = "{}/deepin-wine-runner.svg".format(programPath)
|
||||||
|
|
||||||
# 运行程序
|
# 运行程序
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
app = QtWidgets.QApplication(sys.argv)
|
app = QtWidgets.QApplication(sys.argv)
|
||||||
mainWindow = Window()
|
mainWindow = Window()
|
||||||
|
mainWindow.setWindowIcon(QtGui.QIcon(iconPath))
|
||||||
mainWindow.show()
|
mainWindow.show()
|
||||||
|
mainWindow.resize(int(mainWindow.geometry().width() * 1.2), int(mainWindow.geometry().height() * 1.2))
|
||||||
sys.exit(app.exec())
|
sys.exit(app.exec())
|
||||||
@@ -21,4 +21,4 @@ if [[ $DISPLAY == "" ]] && [[ $WAYLAND_DISPLAY == "" ]] && [[ -f /data/data/com.
|
|||||||
fi
|
fi
|
||||||
$CURRENT_DIR/VM/novnc/utils/novnc_proxy --vnc localhost:5905 $noVNCOption &
|
$CURRENT_DIR/VM/novnc/utils/novnc_proxy --vnc localhost:5905 $noVNCOption &
|
||||||
fi
|
fi
|
||||||
python3 $CURRENT_DIR/mainwindow.py
|
python3 $CURRENT_DIR/main.py
|
||||||
|
|||||||
@@ -317,32 +317,6 @@ class Runexebutton_threading(QtCore.QThread):
|
|||||||
option += "WINEDEBUG=FIXME,ERR,WARN,TRACE,Message "
|
option += "WINEDEBUG=FIXME,ERR,WARN,TRACE,Message "
|
||||||
wineUsingOption = ""
|
wineUsingOption = ""
|
||||||
exePath = e2.currentText()
|
exePath = e2.currentText()
|
||||||
# 禁用没什么用还一堆坑的参数识别问题
|
|
||||||
if False:
|
|
||||||
fileName = [".exe"]
|
|
||||||
changePath = False
|
|
||||||
for i in fileName:
|
|
||||||
if i in exePath:
|
|
||||||
print(i)
|
|
||||||
print(exePath)
|
|
||||||
l = exePath.index(i)
|
|
||||||
exePath = f"{exePath[:l+4]}' {exePath[l+4:]} '"
|
|
||||||
print(l)
|
|
||||||
print(exePath)
|
|
||||||
changePath = True
|
|
||||||
break
|
|
||||||
#if not changePath and not os.path.exists(changePath):
|
|
||||||
if not changePath and not os.path.exists(exePath):
|
|
||||||
# 删除前后无用空格以防止出现问题
|
|
||||||
print(exePath)
|
|
||||||
exePath = exePath.strip()
|
|
||||||
# 有空格再说
|
|
||||||
if " " in exePath:
|
|
||||||
l = exePath.index(" ")
|
|
||||||
exePath = f"{exePath[:l]}' {exePath[l:]} '"
|
|
||||||
print(l)
|
|
||||||
#print(i)
|
|
||||||
print(exePath)
|
|
||||||
if o1.currentText() == "基于 UOS exagear 的 deepin-wine6-stable" or o1.currentText() == "基于 UOS box86 的 deepin-wine6-stable":
|
if o1.currentText() == "基于 UOS exagear 的 deepin-wine6-stable" or o1.currentText() == "基于 UOS box86 的 deepin-wine6-stable":
|
||||||
wineUsingOption = ""
|
wineUsingOption = ""
|
||||||
if o1.currentText() == "基于 UOS box86 的 deepin-wine6-stable" or o1.currentText() == "基于 UOS exagear 的 deepin-wine6-stable":
|
if o1.currentText() == "基于 UOS box86 的 deepin-wine6-stable" or o1.currentText() == "基于 UOS exagear 的 deepin-wine6-stable":
|
||||||
@@ -422,12 +396,8 @@ StartupNotify=true''')
|
|||||||
class Temp:
|
class Temp:
|
||||||
webWindow = None
|
webWindow = None
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#QtCore.QUrl().url()
|
|
||||||
|
|
||||||
# 显示“关于这个程序”窗口
|
# 显示“关于这个程序”窗口
|
||||||
def about_this_program()->"显示“关于这个程序”窗口":
|
def about_this_program():
|
||||||
global about
|
global about
|
||||||
global title
|
global title
|
||||||
global iconPath
|
global iconPath
|
||||||
@@ -2508,23 +2478,23 @@ exe路径\' 参数 \'
|
|||||||
5、wine 容器如果没有指定,则会默认为 ~/.wine;
|
5、wine 容器如果没有指定,则会默认为 ~/.wine;
|
||||||
6、如果可执行文件比较大的话,会出现点击“获取该程序运行情况”出现假死的情况,因为正在后台读取 SHA1,只需要等一下即可(读取速度依照您电脑处理速度、读写速度、可执行文件大小等有关);
|
6、如果可执行文件比较大的话,会出现点击“获取该程序运行情况”出现假死的情况,因为正在后台读取 SHA1,只需要等一下即可(读取速度依照您电脑处理速度、读写速度、可执行文件大小等有关);
|
||||||
7、如果非 X86 的用户的 UOS 专业版用户想要使用的话,只需要在应用商店安装一个 Wine 版本微信即可在本程序选择正确的 Wine 运行程序;''')
|
7、如果非 X86 的用户的 UOS 专业版用户想要使用的话,只需要在应用商店安装一个 Wine 版本微信即可在本程序选择正确的 Wine 运行程序;''')
|
||||||
updateThingsString = QtCore.QCoreApplication.translate("U", '''※1、优化运行器窗口大小机制
|
updateThingsString = QtCore.QCoreApplication.translate("U", '''※1、修复在 GXDE OS 下无法正常调用 gxde-terminal 的问题
|
||||||
※2、Wine 安装器支持根据机器实际情况自动推荐适合的 Wine
|
※2、修复部分机器无法打开应用的问题
|
||||||
※3、Wine 安装器支持手动导入 Wine 7z 包并提供相应 7z 包的网盘下载地址
|
※3、修改打包器 wine 集成封装 机制以便可以被 uos 商店正确签名
|
||||||
※4、兼容 Deepin 终端(deepin 15 经典版本,deepin-terminal-gtk)
|
※4、打包器支持内置 spark dwine helper
|
||||||
※5、跟进 dxvk 2.4
|
※5、重构虚拟机安装模块以支持更多机器
|
||||||
※6、修复 deepin 23 无法使用 Mono/Gecko 安装器的问题
|
6、修复打包器设置依赖无法生效的问题
|
||||||
※7、修复 debian testing 打包时会把 / 打入 .7z 包内导致系统死机的问题
|
※7、补充图标
|
||||||
※8、支持 AOSC(安同)、小小电脑、proot 容器
|
※8、修复 deb 安装过程中可能出现 dpkg 卡死的问题
|
||||||
※9、支持在 Termux 直接运行(单独提供安装包)
|
※9、优化 Wine 安装器检测机制
|
||||||
10、修复虚拟机启动器入口不会调用安装的 Qemu Extra 的问题
|
※10、删除部分废弃组件
|
||||||
11、优化高级打包器容器名称生成机制
|
※11、修复 AOSC、Termux 无法正常打开 Wine 运行器的问题
|
||||||
12、修复部分机器无法正常打开高级打包器的问题
|
12、修改文案
|
||||||
13、修复高级打包器选择Wine封装入deb模式时helper只能使用spark dwine helper的问题
|
13、修复其它 bug 若干
|
||||||
''')
|
''')
|
||||||
for i in information["Thank"]:
|
for i in information["Thank"]:
|
||||||
thankText += f"{i}\n"
|
thankText += f"{i}\n"
|
||||||
updateTime = "2024年07月22日"
|
updateTime = "2024年09月15日"
|
||||||
aboutProgram = QtCore.QCoreApplication.translate("U", """<p>Wine运行器是一个能让Linux用户更加方便地运行Windows应用的程序。原版的 Wine 只能使用命令操作,且安装过程较为繁琐,对小白不友好。于是该运行器为了解决该痛点,内置了对Wine图形化的支持、Wine 安装器、微型应用商店、各种Wine工具、自制的Wine程序打包器、运行库安装工具等。</p>
|
aboutProgram = QtCore.QCoreApplication.translate("U", """<p>Wine运行器是一个能让Linux用户更加方便地运行Windows应用的程序。原版的 Wine 只能使用命令操作,且安装过程较为繁琐,对小白不友好。于是该运行器为了解决该痛点,内置了对Wine图形化的支持、Wine 安装器、微型应用商店、各种Wine工具、自制的Wine程序打包器、运行库安装工具等。</p>
|
||||||
<p>它同时还内置了基于Qemu/VirtualBox制作的、专供小白使用的Windows虚拟机安装工具,可以做到只需下载系统镜像并点击安装即可,无需考虑虚拟机的安装、创建、分区等操作,也能在非 X86 架构安装 X86 架构的 Windows 操作系统(但是效率较低,可以运行些老系统)。</p>
|
<p>它同时还内置了基于Qemu/VirtualBox制作的、专供小白使用的Windows虚拟机安装工具,可以做到只需下载系统镜像并点击安装即可,无需考虑虚拟机的安装、创建、分区等操作,也能在非 X86 架构安装 X86 架构的 Windows 操作系统(但是效率较低,可以运行些老系统)。</p>
|
||||||
<p>而且对于部分 Wine 应用适配者来说,提供了图形化的打包工具,以及提供了一些常用工具以及运行库的安装方式,以及能安装多种不同的 Wine 以测试效果,能极大提升适配效率。</p>
|
<p>而且对于部分 Wine 应用适配者来说,提供了图形化的打包工具,以及提供了一些常用工具以及运行库的安装方式,以及能安装多种不同的 Wine 以测试效果,能极大提升适配效率。</p>
|
||||||
@@ -3390,8 +3360,7 @@ window.setCentralWidget(widget)
|
|||||||
# 判断是否为小屏幕,是则设置滚动条并全屏
|
# 判断是否为小屏幕,是则设置滚动条并全屏
|
||||||
# 获取为 import 为控件,也默认开启滚动条
|
# 获取为 import 为控件,也默认开启滚动条
|
||||||
if (window.frameGeometry().width() > app.primaryScreen().availableGeometry().size().width() * 0.8 or
|
if (window.frameGeometry().width() > app.primaryScreen().availableGeometry().size().width() * 0.8 or
|
||||||
window.frameGeometry().height() > app.primaryScreen().availableGeometry().size().height() * 0.9 or
|
window.frameGeometry().height() > app.primaryScreen().availableGeometry().size().height() * 0.9):
|
||||||
__name__ != "__main__"):
|
|
||||||
# 设置滚动条
|
# 设置滚动条
|
||||||
areaScroll = QtWidgets.QScrollArea(window)
|
areaScroll = QtWidgets.QScrollArea(window)
|
||||||
areaScroll.setWidgetResizable(True)
|
areaScroll.setWidgetResizable(True)
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"Version": "4.0.0.2",
|
"Version": "4.1.0.0",
|
||||||
"Time": "未知",
|
"Time": "未知",
|
||||||
"Thank": [
|
"Thank": [
|
||||||
"感谢 @り哥拽的冇气质° 和 @杨 提供了 3a5000(新世界的测试机器)",
|
"感谢 @り哥拽的冇气质° 和 @杨 提供了 3a5000(新世界的测试机器)",
|
||||||
|
|||||||
14
packager-config/app.desktop
Normal file
14
packager-config/app.desktop
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
#!/usr/bin/env xdg-open
|
||||||
|
[Desktop Entry]
|
||||||
|
Encoding=UTF-8
|
||||||
|
Type=Application
|
||||||
|
X-Created-By=@@@MAINTAINER@@@
|
||||||
|
Categories=@@@DESKTOP_CATEGORIES@@@;
|
||||||
|
Icon=@@@ICON@@@
|
||||||
|
Exec=@@@DESKTOP_EXEC@@@
|
||||||
|
Name=@@@DESKTOP_NAME@@@
|
||||||
|
Comment=@@@DESCRIPTION@@@
|
||||||
|
MimeType=@@@DESKTOP_MIMETYPE@@@
|
||||||
|
GenericName=@@@DEB_PACKAGE_NAME@@@
|
||||||
|
Terminal=false
|
||||||
|
StartupNotify=false
|
||||||
278
packager-config/arm-kill.sh
Normal file
278
packager-config/arm-kill.sh
Normal file
@@ -0,0 +1,278 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
APP_NAME="QQ"
|
||||||
|
LOG_FILE=$0
|
||||||
|
SHELL_DIR=$(dirname $0)
|
||||||
|
SHELL_DIR=$(realpath "$SHELL_DIR")
|
||||||
|
if [ $SPECIFY_SHELL_DIR ]; then
|
||||||
|
SHELL_DIR=$SPECIFY_SHELL_DIR
|
||||||
|
fi
|
||||||
|
|
||||||
|
PUBLIC_DIR="/var/public"
|
||||||
|
|
||||||
|
UsePublicDir()
|
||||||
|
{
|
||||||
|
if [ -z "$USE_PUBLIC_DIR" ]; then
|
||||||
|
echo "Don't use public dir"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if [ ! -d "$PUBLIC_DIR" ];then
|
||||||
|
echo "Not found $PUBLIC_DIR"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if [ ! -r "$PUBLIC_DIR" ];then
|
||||||
|
echo "Can't read for $PUBLIC_DIR"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if [ ! -w "$PUBLIC_DIR" ];then
|
||||||
|
echo "Can't write for $PUBLIC_DIR"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if [ ! -x "$PUBLIC_DIR" ];then
|
||||||
|
echo "Can't excute for $PUBLIC_DIR"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
WINE_BOTTLE="$HOME/.deepinwine"
|
||||||
|
|
||||||
|
if UsePublicDir;then
|
||||||
|
WINE_BOTTLE="$PUBLIC_DIR"
|
||||||
|
fi
|
||||||
|
|
||||||
|
get_wine_by_pid()
|
||||||
|
{
|
||||||
|
wine_path=$(cat /proc/$1/maps | grep -E "\/wine$|\/wine64$|\/wine |\/wine64 " | head -1 | awk '{print $6}')
|
||||||
|
if [ -z "$wine_path" ];then
|
||||||
|
cat /proc/$1/cmdline| xargs -0 -L1 -I{} echo {} | grep -E "\/wine$|\/wine64$|\/wine |\/wine64 " | head -1
|
||||||
|
else
|
||||||
|
echo $wine_path
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
is_wine_process()
|
||||||
|
{
|
||||||
|
wine_module=$(get_wine_by_pid $1)
|
||||||
|
if [ -z "$wine_module" ];then
|
||||||
|
wine_module=$(cat /proc/$1/maps | grep -E "\/wineserver$" | head -1)
|
||||||
|
fi
|
||||||
|
echo $wine_module
|
||||||
|
}
|
||||||
|
|
||||||
|
get_prefix_by_pid()
|
||||||
|
{
|
||||||
|
WINE_PREFIX=$(xargs -0 printf '%s\n' < /proc/$1/environ | grep WINEPREFIX)
|
||||||
|
WINE_PREFIX=${WINE_PREFIX##*=}
|
||||||
|
if [ -z "$WINE_PREFIX" ] && [ -n "$(is_wine_process $1)" ]; then
|
||||||
|
#不指定容器的情况用默认容器目录
|
||||||
|
WINE_PREFIX="$HOME/.wine"
|
||||||
|
fi
|
||||||
|
if [ -n "$WINE_PREFIX" ];then
|
||||||
|
WINE_PREFIX=$(realpath $WINE_PREFIX)
|
||||||
|
echo $WINE_PREFIX
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
get_wineserver()
|
||||||
|
{
|
||||||
|
if [ -z "$1" ];then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
targ_prefix=$(realpath $1)
|
||||||
|
ps -ef | grep wineserver | while read server_info ;do
|
||||||
|
debug_log_to_file "get server info: $server_info"
|
||||||
|
server_pid=$(echo $server_info | awk '{print $2}')
|
||||||
|
server_prefix=$(get_prefix_by_pid $server_pid)
|
||||||
|
debug_log_to_file "get server pid $server_pid, prefix: $server_prefix"
|
||||||
|
|
||||||
|
if [ "$targ_prefix" = "$server_prefix" ];then
|
||||||
|
server=$(echo $server_info | awk '{print $NF}')
|
||||||
|
if [ "-p0" = "$server" ];then
|
||||||
|
server=$(echo $server_info | awk '{print $(NF-1)}')
|
||||||
|
fi
|
||||||
|
debug_log_to_file "get server $server"
|
||||||
|
echo $server
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
init_log_file()
|
||||||
|
{
|
||||||
|
if [ -d "$DEBUG_LOG" ];then
|
||||||
|
LOG_DIR=$(realpath $DEBUG_LOG)
|
||||||
|
if [ -d "$LOG_DIR" ];then
|
||||||
|
LOG_FILE="${LOG_DIR}/${LOG_FILE##*/}.log"
|
||||||
|
echo "" > "$LOG_FILE"
|
||||||
|
debug_log "LOG_FILE=$LOG_FILE"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
debug_log_to_file()
|
||||||
|
{
|
||||||
|
if [ -d "$DEBUG_LOG" ];then
|
||||||
|
strDate=$(date)
|
||||||
|
echo -e "${strDate}:${1}" >> "$LOG_FILE"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
debug_log()
|
||||||
|
{
|
||||||
|
strDate=$(date)
|
||||||
|
echo "${strDate}:${1}"
|
||||||
|
}
|
||||||
|
|
||||||
|
init_log_file
|
||||||
|
|
||||||
|
get_bottle_path_by_process_id()
|
||||||
|
{
|
||||||
|
PID_LIST="$1"
|
||||||
|
PREFIX_LIST=""
|
||||||
|
|
||||||
|
for pid_var in $PID_LIST ; do
|
||||||
|
WINE_PREFIX=$(get_prefix_by_pid $pid_var)
|
||||||
|
#去掉重复项
|
||||||
|
for path in $(echo -e $PREFIX_LIST) ; do
|
||||||
|
if [[ $path == "$WINE_PREFIX" ]]; then
|
||||||
|
WINE_PREFIX=""
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if [ -d "$WINE_PREFIX" ]; then
|
||||||
|
debug_log_to_file "found $pid_var : $WINE_PREFIX"
|
||||||
|
PREFIX_LIST+="\n$WINE_PREFIX"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
echo -e $PREFIX_LIST
|
||||||
|
}
|
||||||
|
|
||||||
|
get_pid_by_process_name()
|
||||||
|
{
|
||||||
|
PID_LIST=""
|
||||||
|
for pid_var in $(ps -ef | grep -E -i "$1" | grep -v grep | awk '{print $2}');do
|
||||||
|
#通过判断是否加载wine来判断是不是wine进程
|
||||||
|
if [ -n "$(is_wine_process $pid_var)" ];then
|
||||||
|
PID_LIST+=" $pid_var"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
echo "$PID_LIST"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_bottle_path_by_process_name()
|
||||||
|
{
|
||||||
|
PID_LIST=$(get_pid_by_process_name $1)
|
||||||
|
debug_log_to_file "get pid list: $PID_LIST"
|
||||||
|
get_bottle_path_by_process_id "$PID_LIST"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_bottle_path()
|
||||||
|
{
|
||||||
|
if [ -z "$1" ];then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f "$1/user.reg" ]; then
|
||||||
|
realpath "$1"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f "$WINE_BOTTLE/$1/user.reg" ]; then
|
||||||
|
realpath "$WINE_BOTTLE/$1"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
get_bottle_path_by_process_name "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
kill_app()
|
||||||
|
{
|
||||||
|
debug_log "try to kill $1"
|
||||||
|
for path in $(get_bottle_path $1); do
|
||||||
|
if [ -n "$path" ];then
|
||||||
|
WINESERVER=$(get_wineserver "$path")
|
||||||
|
|
||||||
|
if [ -f "$WINESERVER" ];then
|
||||||
|
debug_log "kill $path by $WINESERVER"
|
||||||
|
env WINEPREFIX="$path" "$WINESERVER" -k
|
||||||
|
fi
|
||||||
|
|
||||||
|
PID_LIST=$(get_pid_by_process_name "exe|wine")
|
||||||
|
for tag_pid in $PID_LIST; do
|
||||||
|
bottle=$(get_bottle_path_by_process_id "$tag_pid")
|
||||||
|
bottle=${bottle:1}
|
||||||
|
if [ "$path" = "$bottle" ];then
|
||||||
|
echo "kill $tag_pid for $bottle"
|
||||||
|
kill -9 $tag_pid
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
#Kill defunct process
|
||||||
|
ps -ef | grep -E "$USER.*exe.*<defunct>"
|
||||||
|
ps -ef | grep -E "$USER.*exe.*<defunct>" | grep -v grep | awk '{print $2}' | xargs -i kill -9 {}
|
||||||
|
}
|
||||||
|
|
||||||
|
get_tray_window()
|
||||||
|
{
|
||||||
|
$SHELL_DIR/get_tray_window | grep window_id: | awk -F: '{print $2}'
|
||||||
|
}
|
||||||
|
|
||||||
|
get_stacking_window()
|
||||||
|
{
|
||||||
|
xprop -root _NET_CLIENT_LIST_STACKING | awk -F# '{print $2}' | sed -e 's/, / /g'
|
||||||
|
}
|
||||||
|
|
||||||
|
get_window_pid()
|
||||||
|
{
|
||||||
|
for winid in $(echo "$1" | sed -e 's/ /\n/g') ;
|
||||||
|
do
|
||||||
|
xprop -id $winid _NET_WM_PID | awk -F= '{print $2}'
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
get_window_bottle()
|
||||||
|
{
|
||||||
|
debug_log_to_file "get_window_bottle $1"
|
||||||
|
PID_LIST=$(get_window_pid "$1")
|
||||||
|
debug_log_to_file "get_window_bottle pid list: $PID_LIST"
|
||||||
|
get_bottle_path_by_process_id "$PID_LIST"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_active_bottles()
|
||||||
|
{
|
||||||
|
TRAYWINDOWS=$(get_tray_window)
|
||||||
|
STACKINGWINDOWS=$(get_stacking_window)
|
||||||
|
debug_log_to_file "tray window id: $TRAYWINDOWS"
|
||||||
|
debug_log_to_file "stacking window id: $STACKINGWINDOWS"
|
||||||
|
PID_LIST="$TRAYWINDOWS $STACKINGWINDOWS"
|
||||||
|
get_window_bottle "$PID_LIST"
|
||||||
|
}
|
||||||
|
|
||||||
|
kill_exit_block_app()
|
||||||
|
{
|
||||||
|
TAGBOTTLE=$(get_bottle_path $1)
|
||||||
|
debug_log "tag bottle: $TAGBOTTLE"
|
||||||
|
ACTIVEBOTTLES=$(get_active_bottles)
|
||||||
|
debug_log "active bottles: $ACTIVEBOTTLES"
|
||||||
|
|
||||||
|
if [[ "$ACTIVEBOTTLES" != *"$TAGBOTTLE"* ]]; then
|
||||||
|
kill_app "$TAGBOTTLE"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#get_active_bottles
|
||||||
|
#exit
|
||||||
|
|
||||||
|
debug_log "kill $1 $2"
|
||||||
|
|
||||||
|
if [ -n "$1" ]; then
|
||||||
|
APP_NAME="$1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$2" = "block" ]; then
|
||||||
|
kill_exit_block_app $APP_NAME $3
|
||||||
|
else
|
||||||
|
kill_app $APP_NAME
|
||||||
|
fi
|
||||||
@@ -0,0 +1,39 @@
|
|||||||
|
# ===== Log =====
|
||||||
|
# log.info xxx
|
||||||
|
# log.warn xxx
|
||||||
|
# log.info xxx
|
||||||
|
# log.debug xxx
|
||||||
|
# 带颜色的echo
|
||||||
|
function log.color_output() {
|
||||||
|
local color=$1
|
||||||
|
shift 1
|
||||||
|
|
||||||
|
echo >&2 -e "\033[${color}m$@\033[0m"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# Log is named without prefix "utils." for convenience
|
||||||
|
# Usage: log.log <level> ...content
|
||||||
|
function log.log() {
|
||||||
|
if [[ $# < 2 ]]; then
|
||||||
|
return -1
|
||||||
|
fi
|
||||||
|
|
||||||
|
local level=$1
|
||||||
|
shift 1
|
||||||
|
|
||||||
|
case $level in
|
||||||
|
error) log.color_output "0;31" "[ERROR] $@" ;;
|
||||||
|
warn) log.color_output "1;33" "[WARN] $@" ;;
|
||||||
|
info) log.color_output "1;37" "[INFO] $@" ;;
|
||||||
|
debug) log.color_output "1;30" "[DEBUG] $@" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
function log.error() { log.log "error" "$@"; }
|
||||||
|
function log.warn() { log.log "warn" $@; }
|
||||||
|
function log.info() { log.log "info" $@; }
|
||||||
|
function log.debug() { log.log "debug" $@; }
|
||||||
|
|
||||||
32
packager-config/deepinwine/tools/bashimport/transhell.bashimport
Executable file
32
packager-config/deepinwine/tools/bashimport/transhell.bashimport
Executable file
@@ -0,0 +1,32 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
##load transhell
|
||||||
|
function load_transhell_debug()
|
||||||
|
{
|
||||||
|
local WORK_PATH="$(dirname $(realpath $0))"
|
||||||
|
echo $WORK_PATH
|
||||||
|
local CURRENT_LANG="$(echo ${LANG%.*})"
|
||||||
|
if [ -e "/usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell" ]; then source /usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell; echo "Loading transhell from /usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell ..."; fi
|
||||||
|
if [ -e "/usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell" ]; then source /usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell; echo "Loading transhell from /usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell ..."; fi
|
||||||
|
if [ -e "${WORK_PATH}/transhell/$(basename $0)_en_US.transhell" ]; then source ${WORK_PATH}/transhell/$(basename $0)_en_US.transhell; echo "Loading transhell from ${WORK_PATH}/transhell/$(basename $0)_en_US.transhell ..."; fi
|
||||||
|
if [ -e "${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell" ]; then source ${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell; echo "Loading transhell from ${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell ..."; fi
|
||||||
|
|
||||||
|
echo "-----------------------------------------------------------------------------"
|
||||||
|
}
|
||||||
|
|
||||||
|
function load_transhell()
|
||||||
|
{
|
||||||
|
local WORK_PATH="$(dirname $(realpath $0))"
|
||||||
|
local CURRENT_LANG="$(echo ${LANG%.*})"
|
||||||
|
if [ -e "/usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell" ]; then source /usr/share/$(basename $0)/transhell/$(basename $0)_en_US.transhell; fi
|
||||||
|
if [ -e "/usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell" ]; then source /usr/share/$(basename $0)/transhell/$(basename $0)_$CURRENT_LANG.transhell; fi
|
||||||
|
if [ -e "${WORK_PATH}/transhell/$(basename $0)_en_US.transhell" ]; then source ${WORK_PATH}/transhell/$(basename $0)_en_US.transhell; fi
|
||||||
|
if [ -e "${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell" ]; then source ${WORK_PATH}/transhell/$(basename $0)_$CURRENT_LANG.transhell; fi
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function update_transhell()
|
||||||
|
{
|
||||||
|
load_transhell $@
|
||||||
|
}
|
||||||
|
|
||||||
@@ -0,0 +1,36 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
source $(dirname $0)/log-function.bashimport
|
||||||
|
Get_Dist_Name()
|
||||||
|
{
|
||||||
|
if grep -Eqii "Deepin" /etc/issue || grep -Eq "Deepin" /etc/*-release; then
|
||||||
|
DISTRO='Deepin'
|
||||||
|
elif grep -Eqi "UnionTech" /etc/issue || grep -Eq "UnionTech" /etc/*-release; then
|
||||||
|
DISTRO='UniontechOS'
|
||||||
|
elif grep -Eqi "UOS" /etc/issue || grep -Eq "UOS" /etc/*-release; then
|
||||||
|
DISTRO='UniontechOS'
|
||||||
|
else
|
||||||
|
DISTRO='OtherOS'
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Get_Dist_Name
|
||||||
|
## 1. If WINEPREFIX is not set, use ~/.wine
|
||||||
|
if [ "$WINEPREFIX" = "" ];then
|
||||||
|
export WINEPREFIX=$HOME/.wine
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ "$DISTRO" != "Deepin" ] && [ "$DISTRO" != "UniontechOS" ];then
|
||||||
|
|
||||||
|
|
||||||
|
log.warn "WARNING:USING BOX64 INSTEAD OF DEEPIN-BOX64,SOME APP MAY FAIL TO LAUNCH"
|
||||||
|
|
||||||
|
spark-box64 /opt/deepin-wine8-stable/bin/wine "$@"
|
||||||
|
else
|
||||||
|
deepin-wine8-stable "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
@@ -0,0 +1,39 @@
|
|||||||
|
# ===== Log =====
|
||||||
|
# log.info xxx
|
||||||
|
# log.warn xxx
|
||||||
|
# log.info xxx
|
||||||
|
# log.debug xxx
|
||||||
|
# 带颜色的echo
|
||||||
|
function log.color_output() {
|
||||||
|
local color=$1
|
||||||
|
shift 1
|
||||||
|
|
||||||
|
echo >&2 -e "\033[${color}m$@\033[0m"
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
# Log is named without prefix "utils." for convenience
|
||||||
|
# Usage: log.log <level> ...content
|
||||||
|
function log.log() {
|
||||||
|
if [[ $# < 2 ]]; then
|
||||||
|
return -1
|
||||||
|
fi
|
||||||
|
|
||||||
|
local level=$1
|
||||||
|
shift 1
|
||||||
|
|
||||||
|
case $level in
|
||||||
|
error) log.color_output "0;31" "[ERROR] $@" ;;
|
||||||
|
warn) log.color_output "1;33" "[WARN] $@" ;;
|
||||||
|
info) log.color_output "1;37" "[INFO] $@" ;;
|
||||||
|
debug) log.color_output "1;30" "[DEBUG] $@" ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
function log.error() { log.log "error" "$@"; }
|
||||||
|
function log.warn() { log.log "warn" $@; }
|
||||||
|
function log.info() { log.log "info" $@; }
|
||||||
|
function log.debug() { log.log "debug" $@; }
|
||||||
|
|
||||||
BIN
packager-config/deepinwine/tools/spark-dwine-helper/pybanner/fallback.png
Executable file
BIN
packager-config/deepinwine/tools/spark-dwine-helper/pybanner/fallback.png
Executable file
Binary file not shown.
|
After Width: | Height: | Size: 195 KiB |
@@ -0,0 +1,127 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
import os
|
||||||
|
import sys
|
||||||
|
import time
|
||||||
|
import subprocess
|
||||||
|
import threading
|
||||||
|
from PyQt5.QtGui import *
|
||||||
|
from PyQt5.QtCore import *
|
||||||
|
from PyQt5.QtWidgets import *
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
def check_window():
|
||||||
|
# 使用 wmctrl 命令列出所有窗口,并使用 grep 过滤出特定的 WMCLASS
|
||||||
|
windows = subprocess.getoutput(f'wmctrl -lx | grep "{target_wmclass}"')
|
||||||
|
# 如果窗口存在,则关闭提示
|
||||||
|
if windows.replace("\n", "").replace(" ", "") != "":
|
||||||
|
# 提取窗口ID
|
||||||
|
window_id = windows.replace(" ", " ").split(" ")[0]
|
||||||
|
|
||||||
|
print(f"Window with WMCLASS '{target_wmclass}' found")
|
||||||
|
return 1
|
||||||
|
# else:
|
||||||
|
# print(f"Window with WMCLASS '{target_wmclass}' not found.")
|
||||||
|
|
||||||
|
|
||||||
|
def check_wmclass():
|
||||||
|
if timeout:
|
||||||
|
time.sleep(timeout)
|
||||||
|
window.close()
|
||||||
|
return
|
||||||
|
# 循环检测窗口是否存在的函数
|
||||||
|
# 每隔一段时间检测一次窗口是否存在
|
||||||
|
showtimeout = 20 # 为防止因为应用无法打开而无法正常关闭窗口,于是设置 time out
|
||||||
|
while True:
|
||||||
|
if check_window():
|
||||||
|
break
|
||||||
|
# 等待一段时间后再次检测
|
||||||
|
time.sleep(1)
|
||||||
|
AppInfoShowerRefresh()
|
||||||
|
showtimeout -= 1
|
||||||
|
if showtimeout <= 0:
|
||||||
|
break
|
||||||
|
window.close()
|
||||||
|
|
||||||
|
|
||||||
|
timeout = 0
|
||||||
|
if os.getenv("WAYLAND_DISPLAY"):
|
||||||
|
timeout = 3
|
||||||
|
|
||||||
|
if os.system("which wmctrl"):
|
||||||
|
print("No wmctrl installed. Do not check wmclass")
|
||||||
|
timeout = 3
|
||||||
|
|
||||||
|
target_wmclass = os.getenv("WINE_WMCLASS")
|
||||||
|
|
||||||
|
def GetRecommendWindowSize(window: QMainWindow):
|
||||||
|
# 计算屏幕分辨率
|
||||||
|
screen = QGuiApplication.primaryScreen()
|
||||||
|
width = screen.geometry().width()
|
||||||
|
height = screen.geometry().height()
|
||||||
|
# 如果为竖状屏幕
|
||||||
|
if width < height:
|
||||||
|
temp = height
|
||||||
|
height = width
|
||||||
|
width = temp
|
||||||
|
return [int(width / 4), window.geometry().height()]
|
||||||
|
|
||||||
|
def SetWindowSize(window: QMainWindow):
|
||||||
|
# 计算比例
|
||||||
|
size = GetRecommendWindowSize(window)
|
||||||
|
window.resize(size[0], size[1])
|
||||||
|
|
||||||
|
def MoveCenter(window: QMainWindow):
|
||||||
|
# 计算屏幕分辨率
|
||||||
|
screen = QGuiApplication.primaryScreen()
|
||||||
|
width = screen.geometry().width()
|
||||||
|
height = screen.geometry().height()
|
||||||
|
print(window.geometry().height())
|
||||||
|
# 计算窗口坐标
|
||||||
|
window.move(int(width / 2 - window.geometry().width() / 2),
|
||||||
|
int(height / 2.8 - window.geometry().height() / 2)
|
||||||
|
)
|
||||||
|
|
||||||
|
def AppInfoShowerRefresh():
|
||||||
|
global appInfoShowerTime
|
||||||
|
appInfoShower.setText(f"<h3 align='center'>星火Windows应用兼容助手</h3><p align='center'>正在为您启动以下应用:{os.getenv('WINE_APP_NAME')} {'.' * (appInfoShowerTime % 3 + 1)}</p>")
|
||||||
|
|
||||||
|
appInfoShowerTime += 1
|
||||||
|
|
||||||
|
programPath = os.path.split(os.path.realpath(__file__))[0] # 返回 string
|
||||||
|
|
||||||
|
app = QApplication(sys.argv)
|
||||||
|
# 构建窗口
|
||||||
|
window = QMainWindow()
|
||||||
|
widget = QWidget()
|
||||||
|
layout = QGridLayout()
|
||||||
|
|
||||||
|
appInfoShower = QLabel()
|
||||||
|
appInfoShowerTime = 0
|
||||||
|
AppInfoShowerRefresh()
|
||||||
|
|
||||||
|
# GXDE 彩蛋
|
||||||
|
if os.path.exists("/usr/share/gxde-resources/spark-dwine-helper.png"):
|
||||||
|
backgroundImgPath = "/usr/share/gxde-resources/spark-dwine-helper.png"
|
||||||
|
##########
|
||||||
|
if os.path.exists(f"{programPath}/fallback.png"):
|
||||||
|
backgroundImgPath = f"{programPath}/fallback.png"
|
||||||
|
if os.path.exists(f"/opt/apps/{os.getenv('DEB_PACKAGE_NAME')}/files/banner.png"):
|
||||||
|
backgroundImgPath = f"/opt/apps/{os.getenv('DEB_PACKAGE_NAME')}/files/banner.png"
|
||||||
|
window.setWindowTitle("星火Windows应用兼容助手")
|
||||||
|
layout.addWidget(QLabel(f""), 1, 0)
|
||||||
|
layout.addWidget(appInfoShower, 2, 0)
|
||||||
|
layout.addWidget(QLabel(f"<hr>由 Wine 运行器提供支持"), 4, 0)
|
||||||
|
widget.setLayout(layout)
|
||||||
|
window.setCentralWidget(widget)
|
||||||
|
window.setWindowFlags(Qt.CustomizeWindowHint | Qt.WindowStaysOnTopHint)
|
||||||
|
MoveCenter(window)
|
||||||
|
SetWindowSize(window)
|
||||||
|
window.show()
|
||||||
|
|
||||||
|
|
||||||
|
layout.addWidget(QLabel(f"<p align='center'><img width='{window.geometry().width()}' src='{backgroundImgPath}'></p>"), 0, 0)
|
||||||
|
threading.Thread(target=check_wmclass).start()
|
||||||
|
MoveCenter(window)
|
||||||
|
app.exec_()
|
||||||
@@ -0,0 +1,92 @@
|
|||||||
|
___
|
||||||
|
( )
|
||||||
|
| | .-. ___ ___ .--. .--.
|
||||||
|
| |/ \ ( )( ) / \ / \
|
||||||
|
| .-. . | | | | ; ,-. ' | .-. ;
|
||||||
|
| | | | | | | | | | | | | | | |
|
||||||
|
| | | | | | | | | | | | | |/ |
|
||||||
|
| | | | | | | | | | | | | ' _.'
|
||||||
|
| | | | | | ; ' | ' | | | .'.-.
|
||||||
|
| | | | ' `-' / ' `-' | ' `-' /
|
||||||
|
(___)(___) '.__.' `.__. | `.__.'
|
||||||
|
( `-' ;
|
||||||
|
`.__.
|
||||||
|
___
|
||||||
|
( )
|
||||||
|
| |.-. .---. ___ .-. .--. ___ .-.
|
||||||
|
| / \ / .-, \ ( ) \ / \ ( ) \
|
||||||
|
| .-. | (__) ; | | ' .-. ; | .-. ; | .-. .
|
||||||
|
| | | | .'` | | / (___) | | | | | | | |
|
||||||
|
| | | | / .'| | | | | | | | | | | |
|
||||||
|
| | | | | / | | | | | | | | | | | |
|
||||||
|
| ' | | ; | ; | | | | ' | | | | | |
|
||||||
|
' `-' ; ' `-' | | | ' `-' / | | | |
|
||||||
|
`.__. `.__.'_. (___) `.__.' (___)(___)
|
||||||
|
|
||||||
|
|
||||||
|
___
|
||||||
|
( )
|
||||||
|
| |.-. ___ ___ ___ .-. ___ .-. ___ ___
|
||||||
|
| / \ ( )( ) ( ) \ ( ) \ ( )( )
|
||||||
|
| .-. | | | | | | .-. . | .-. . | | | |
|
||||||
|
| | | | | | | | | | | | | | | | | | | |
|
||||||
|
| | | | | | | | | | | | | | | | | ' | |
|
||||||
|
| | | | | | | | | | | | | | | | ' `-' |
|
||||||
|
| ' | | | | ; ' | | | | | | | | `.__. |
|
||||||
|
' `-' ; ' `-' / | | | | | | | | ___ | |
|
||||||
|
`.__. '.__.' (___)(___) (___)(___) ( )' |
|
||||||
|
; `-' '
|
||||||
|
.__.'
|
||||||
|
............ .....]OOOo]`....
|
||||||
|
... ........ ...=OOOOOOOOO\..
|
||||||
|
.../OOOOOOO`.... ..=OOO@/[\OOOOO.
|
||||||
|
..=OOOOOOOOO\... .,@OO^/....O@O@`
|
||||||
|
..OOOOOO[[OOO@`. .=OO@,...=.OOOO.
|
||||||
|
..OOOOO./O^,@OO` .=OO^....,.@OO^.
|
||||||
|
..\OOO@^...=OOOO.... .OOO^*..,`/OOO..
|
||||||
|
...\OOOOOOOooooO^... .=OO^...`=OO@`..
|
||||||
|
..=@O@OooOOOOO@`...........=@@O]].,@O@`...
|
||||||
|
.,@OoOO`...O@^......,]]]]/OOOOOOO@@... .
|
||||||
|
...\OO@]]]OOOO@@@@@@@@@@@@@@@@@@@OO.....
|
||||||
|
.....[@@OOO@@@@@@@@@@@@@@@@@@@@@@@@@@`..
|
||||||
|
..OOO@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@`....
|
||||||
|
.,@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@\...
|
||||||
|
....=@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@^..
|
||||||
|
...=@@@@@@@@@@@@@@@@@@@@@@`,\@@@@@@@@@@@@@^.
|
||||||
|
..,@@@@@@@@@@@@@@@@@@@@@@@O,[].\@@@@@@@@@@@.
|
||||||
|
../@@@@@@@@@@@@O@@@@@@@@@@@......\@@@@@@@@@^
|
||||||
|
.,@@@@@@@@@@@O`.\@@@@@@@@@/........\@@@@@@@@...
|
||||||
|
.=@@@@@@@@@/.....\@@@@@@@@/`...[O`..\@@@@@@@`...
|
||||||
|
.=@@@@@@@^,O[..,`.,@@@@@/../@@O[`...,@@@@@@@....
|
||||||
|
....@@@@@@@O`,@@O[]..,@/[`..=oo@O`,^...@@@@@@@@`..
|
||||||
|
....O@@@@@@@@`,OOO@^*\.........\..../.../@`.=^..
|
||||||
|
.. ...,@^=@@@^.\`...,^...........[[......O]//...
|
||||||
|
..,\]@@@\...[`....................=@@/....
|
||||||
|
.=@@\............,]/`........../@@@\.. .
|
||||||
|
.....@@@@@\.....................,/@@@@@@\...
|
||||||
|
...=@@@@@@@@\]..............]@@@@@@@@@@@@`.
|
||||||
|
...,@@@@@@@@@@@@@@/[\O@@O/[*./@@@@@@@@@@@@@\.......
|
||||||
|
...@@@@@@@@@@@@@@@^.,O@@@@^../@@@@@@@@@@@@@@@\.....
|
||||||
|
..........@@@@@@@@@@@@@@@@@`..`\/`../@@@@@@@@@@@@@@@@@@@@]]
|
||||||
|
........,@@@@@@@@@@@@@@@@/*[\].,`]/[[@@@@@@@@@@@@@@,[[[[`..
|
||||||
|
..,O\/@@@@@@@@@@@@@@@@@@@`...........O@@O@@@@@@@@@@\....
|
||||||
|
.....\@@@@@@@@@@@@@@@@@@@OO\`,O.. .,@OOO@@@@@@@@@@. ..
|
||||||
|
..../@@@@@@@@@@@@@@OO@`.^,O. ..=@OOO@@@@@@@@@.. .
|
||||||
|
...=@@@@@@@@@@@@@@@@@O[[.... ...\@@@@@@@@@@@/.. .
|
||||||
|
...=@@@@@@@@@@@@@@,^ ....O...\@@@@@@`
|
||||||
|
....@@@@@@@@@@@@@/.. ...^/\]/[\@@@@`.
|
||||||
|
.@@@@/@@@@@@@^O..... ...,@@^]..]@/...
|
||||||
|
...\@`.[@@@@@@...... .=`@@@@@^..^....
|
||||||
|
....`....[@@@O\.[,..........OO@@@@@^.,[[....
|
||||||
|
............\@@@\`...,`**,]@@@@@@@^.........
|
||||||
|
.. .,@@@@@@@@@@@@@@@@@@/...
|
||||||
|
..O@@@@@@@@@@@@@@@@@^...
|
||||||
|
..O@@@@@@^...=@@@@@@@...
|
||||||
|
..@@@@@@@\...=@@@@@@@^..
|
||||||
|
.=@@@@@@@@...=@@@@@@@O..
|
||||||
|
.=@@@@@@@@`..=@@@@@@@@..
|
||||||
|
.=@@@O@@@@^..=@@OO@@@@^.
|
||||||
|
.O@OOOOO@O^..=@OOOOOOO^.
|
||||||
|
.Oo/[\O/\O@..=/[\O/\o*O.
|
||||||
|
.O^......=O...^......*/.
|
||||||
|
.=\.....]O^...\\...]//.. .. ........
|
||||||
@@ -0,0 +1,86 @@
|
|||||||
|
#/bin/bash
|
||||||
|
source ${SHELL_DIR}/bashimport/transhell.bashimport
|
||||||
|
load_transhell_debug
|
||||||
|
|
||||||
|
#########>>>>>>>函数段
|
||||||
|
Get_Dist_Name()
|
||||||
|
{
|
||||||
|
if grep -Eqii "Deepin" /etc/issue || grep -Eq "Deepin" /etc/*-release; then
|
||||||
|
DISTRO='Deepin'
|
||||||
|
elif grep -Eqi "UnionTech" /etc/issue || grep -Eq "UnionTech" /etc/*-release; then
|
||||||
|
DISTRO='UniontechOS'
|
||||||
|
elif grep -Eqi "UOS" /etc/issue || grep -Eq "UOS" /etc/*-release; then
|
||||||
|
DISTRO='UniontechOS'
|
||||||
|
else
|
||||||
|
DISTRO='OtherOS'
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
#########<<<<<<<
|
||||||
|
|
||||||
|
if [ $# -lt 1 ]; then
|
||||||
|
echo "无参数,无法启动。这是一个set-wine-scale的组件,一般来说,你不会需要单独启动这个脚本"
|
||||||
|
echo "请参考set-wine-scale.sh使用"
|
||||||
|
echo "参数为CONTAINER_PATH"
|
||||||
|
echo "只读取第一个,其他参数会被放弃"
|
||||||
|
fi
|
||||||
|
|
||||||
|
CONTAINER_PATH="$1"
|
||||||
|
|
||||||
|
if [ ! -f "$CONTAINER_PATH/user.reg" ];then
|
||||||
|
echo "错误:找不到user.reg,退出。你应当在文件解压结束后调用此脚本"
|
||||||
|
echo "E: Can not find user.reg. Exit. You should use this script after the extraction"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
mkdir -p $HOME/.config/spark-wine/
|
||||||
|
#####全局参数位置
|
||||||
|
#####能到这一步的说明已经是没有自定义参数了,直接读全局覆盖没问题
|
||||||
|
#####
|
||||||
|
|
||||||
|
if [ -f "$HOME/.config/spark-wine/scale.txt" ];then
|
||||||
|
cat $HOME/.config/spark-wine/scale.txt > $CONTAINER_PATH/scale.txt
|
||||||
|
echo "检测到已经设置过全局参数,直接复制"
|
||||||
|
echo "全局参数的位置在$HOME/.config/spark-wine/scale.txt,如果需要更换请删除此文件重新生成"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
Get_Dist_Name
|
||||||
|
if [ "$DISTRO" = "UniontechOS" ];then
|
||||||
|
echo 1.0 > $HOME/.config/spark-wine/scale.txt
|
||||||
|
cat $HOME/.config/spark-wine/scale.txt > $CONTAINER_PATH/scale.txt
|
||||||
|
#####就是1倍缩放
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
dimensions=`xdpyinfo | grep dimensions | sed -r 's/^[^0-9]*([0-9]+x[0-9]+).*$/\1/'`
|
||||||
|
scale_factor=`zenity --list \
|
||||||
|
--width=700 \
|
||||||
|
--height=350 \
|
||||||
|
--title="${TRANSHELL_CONTENT_YOUR_DIMENSION_IS} $dimensions ${TRANSHELL_CONTENT_PLEASE_CHOOSE_ONE_BELOW}" \
|
||||||
|
--column="${TRANSHELL_CONTENT_OPTION}" \
|
||||||
|
1.0 \
|
||||||
|
1.25 \
|
||||||
|
1.5 \
|
||||||
|
1.75 \
|
||||||
|
2.0 \
|
||||||
|
2.5 \
|
||||||
|
3.0 \
|
||||||
|
3.5 \
|
||||||
|
4.0`
|
||||||
|
|
||||||
|
case "$scale_factor" in
|
||||||
|
"")
|
||||||
|
zenity --info --text="${TRANSHELL_CONTENT_1_SCALE_AS_DEFAULT}${TRANSHELL_CONTENT_YOU_CAN_USE_SPARK_WINE_HELPER_SETTINGS_TO_ADJUST}" --width=500 --height=150
|
||||||
|
scale_factor="1.0"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
zenity --info --text="${TRANSHELL_CONTENT_SCALE_IS} $scale_factor ${TRANSHELL_CONTENT_SAVED}!${TRANSHELL_CONTENT_YOU_CAN_USE_SPARK_WINE_HELPER_SETTINGS_TO_ADJUST}" --width=500 --height=150
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
echo "$scale_factor" > $HOME/.config/spark-wine/scale.txt
|
||||||
|
cat $HOME/.config/spark-wine/scale.txt > $CONTAINER_PATH/scale.txt
|
||||||
|
|
||||||
@@ -0,0 +1,210 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
help() {
|
||||||
|
cat <<EOF
|
||||||
|
用法:$0 [-h|--help] [-s|--set-scale-factor] path
|
||||||
|
-h|--help 显示这个帮助
|
||||||
|
-s|--set-scale-factor 直接指定缩放。支持1.0,1.25,1.5,1.75,2.0,2.5,3.0,3.5,4.0
|
||||||
|
path 容器目录
|
||||||
|
|
||||||
|
本脚本具有超级兔力。
|
||||||
|
--------------------------------------------------------------------
|
||||||
|
Usage: $0 [-h|--help] [-s|--set-scale-factor] path
|
||||||
|
-h|--help Show this text
|
||||||
|
-s|--set-scale-factor Set scale factor direcly. Support 1.0,1.25,1.5,1.75,2.0,2.5,3.0,3.5,4.0
|
||||||
|
path Wine Container directory path
|
||||||
|
|
||||||
|
This script have super bunny power.
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
#########################帮助文件结束#############################
|
||||||
|
|
||||||
|
parse_args() {
|
||||||
|
while [ $# -gt 0 ]; do
|
||||||
|
case "$1" in
|
||||||
|
-h|--help)
|
||||||
|
help
|
||||||
|
exit
|
||||||
|
;;
|
||||||
|
-s|--set-scale-factor)
|
||||||
|
appointed_scale_factor="$2"
|
||||||
|
|
||||||
|
;;
|
||||||
|
|
||||||
|
"bunny")
|
||||||
|
cat ${SHELL_DIR}/spark-dwine-helper/scale-set-helper/bunny.txt
|
||||||
|
exit
|
||||||
|
|
||||||
|
;;
|
||||||
|
|
||||||
|
*)
|
||||||
|
CONTAINER_PATH="$1"
|
||||||
|
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
}
|
||||||
|
################
|
||||||
|
parse_args "$@"
|
||||||
|
|
||||||
|
#####先看看PATH对不对
|
||||||
|
if [ ! -f "$CONTAINER_PATH/user.reg" ];then
|
||||||
|
echo "错误:找不到user.reg,退出。你应当在文件解压结束后调用此脚本。"
|
||||||
|
echo "如果你不清楚如何使用这个脚本,请使用 $0 -h"
|
||||||
|
echo "E: Can not find user.reg. Exit. You should use this script after the extraction"
|
||||||
|
echo "If you don't know how to use this script, try $0 -h"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ "$appointed_scale_factor" = "" ];then
|
||||||
|
#########未指定下,读取$CONTAINER_PATH/scale.txt。如果没有,优先$DEEPIN_WINE_SCALE设置,然后是手动
|
||||||
|
|
||||||
|
if [ ! -f "$CONTAINER_PATH/scale.txt" ];then
|
||||||
|
|
||||||
|
echo "E: No SCALE profile found. try to use DEEPIN_WINE_SCALE"
|
||||||
|
echo "错误:没有检测到缩放设置,读取DEEPIN_WINE_SCALE"
|
||||||
|
if [ "$DEEPIN_WINE_SCALE" = "" ];then
|
||||||
|
echo "E: No DEEPIN_WINE_SCALE found. Use get-scale.sh to Set "
|
||||||
|
echo "错误:没有检测到DEEPIN_WINE_SCALE,用get-scale.sh设置"
|
||||||
|
${SHELL_DIR}/spark-dwine-helper/scale-set-helper/get-scale.sh "$CONTAINER_PATH"
|
||||||
|
wine_scale=`cat $CONTAINER_PATH/scale.txt`
|
||||||
|
echo "检测到的缩放倍数为:$wine_scale"
|
||||||
|
echo "Scale is $wine_scale"
|
||||||
|
else
|
||||||
|
echo "$DEEPIN_WINE_SCALE" > $CONTAINER_PATH/scale.txt
|
||||||
|
wine_scale=`cat $CONTAINER_PATH/scale.txt`
|
||||||
|
echo "检测到的缩放倍数为:$wine_scale"
|
||||||
|
echo "Scale is $wine_scale"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
wine_scale=`cat $CONTAINER_PATH/scale.txt`
|
||||||
|
|
||||||
|
echo "检测到的缩放倍数为:$wine_scale"
|
||||||
|
echo "Scale is $wine_scale"
|
||||||
|
|
||||||
|
|
||||||
|
fi
|
||||||
|
#####非deepin发行版似乎没有这个变量,暂时不清楚这个变量是哪个组件做的
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
else
|
||||||
|
#######指定了缩放倍数
|
||||||
|
echo "使用了--set-scale-factor,直接指定"
|
||||||
|
echo "--set-scale-factor detected. Arrange directly"
|
||||||
|
|
||||||
|
|
||||||
|
if [ "$appointed_scale_factor" != "1.0" ] && [ "$appointed_scale_factor" != "1.25" ] && [ "$appointed_scale_factor" != "1.5" ] && [ "$appointed_scale_factor" != "1.75" ] && [ "$appointed_scale_factor" != "2.0" ] && [ "$appointed_scale_factor" != "2.5" ] && [ "$appointed_scale_factor" != "3.0" ] && [ "$appointed_scale_factor" != "3.5" ] && [ "$appointed_scale_factor" != "4.0" ];then
|
||||||
|
echo "无法识别的倍数:$appointed_scale_factor,请参看$0 -h"
|
||||||
|
echo "Unrecognizable number. Use $0 -h to get help"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
#######没问题了再用
|
||||||
|
echo "$appointed_scale_factor" > $CONTAINER_PATH/scale.txt
|
||||||
|
wine_scale=`cat $CONTAINER_PATH/scale.txt`
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
########开始设置
|
||||||
|
########如果环境变量里没指定了APPRUN_CMD(在run.sh中)就替换,如果有就直接用来设置
|
||||||
|
|
||||||
|
if [ "$APPRUN_CMD" = "" ];then
|
||||||
|
echo "没有检测到APPRUN_CMD环境变量,执行sed替换。如果要使用wine原生提供的方法,请在环境变量中指定(export)"
|
||||||
|
case "$wine_scale" in
|
||||||
|
1.0*)
|
||||||
|
reg_text="\"LogPixels\"=dword:00000060"
|
||||||
|
;;
|
||||||
|
1.25*)
|
||||||
|
reg_text="\"LogPixels\"=dword:00000078"
|
||||||
|
;;
|
||||||
|
1.5*)
|
||||||
|
reg_text="\"LogPixels\"=dword:00000090"
|
||||||
|
;;
|
||||||
|
1.75*)
|
||||||
|
reg_text="\"LogPixels\"=dword:000000A8"
|
||||||
|
;;
|
||||||
|
2.0*)
|
||||||
|
reg_text="\"LogPixels\"=dword:000000C0"
|
||||||
|
;;
|
||||||
|
2.5*)
|
||||||
|
reg_text="\"LogPixels\"=dword:000000F0"
|
||||||
|
;;
|
||||||
|
3.0*)
|
||||||
|
reg_text="\"LogPixels\"=dword:00000120"
|
||||||
|
;;
|
||||||
|
3.5*)
|
||||||
|
reg_text="\"LogPixels\"=dword:00000150"
|
||||||
|
;;
|
||||||
|
4.0*)
|
||||||
|
reg_text="\"LogPixels\"=dword:00000180"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
reg_text="\"LogPixels\"=dword:00000060"
|
||||||
|
#可能不是Xorg
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
#####根据scale设置dword值
|
||||||
|
|
||||||
|
|
||||||
|
LogPixels_line=(`sed -n -e "/"LogPixels"/=" $CONTAINER_PATH/user.reg`)
|
||||||
|
#####关键词行数取得
|
||||||
|
until [ "${#LogPixels_line[@]}" = "0" ];do
|
||||||
|
|
||||||
|
|
||||||
|
line_num=${LogPixels_line[0]}
|
||||||
|
|
||||||
|
sed -i "$line_num"c\ "$reg_text" "$CONTAINER_PATH/user.reg"
|
||||||
|
LogPixels_line=(${LogPixels_line[@]:1})
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "已经完成替换。位置:$CONTAINER_PATH/user.reg"
|
||||||
|
echo "在以下行数进行了替换,内容为$reg_text"
|
||||||
|
echo `sed -n -e "/"LogPixels"/=" $CONTAINER_PATH/user.reg`
|
||||||
|
echo "---------------------------------------"
|
||||||
|
|
||||||
|
else
|
||||||
|
#####用wine提供的方法
|
||||||
|
|
||||||
|
case "$wine_scale" in
|
||||||
|
1.0*)
|
||||||
|
dpi="96"
|
||||||
|
;;
|
||||||
|
1.25*)
|
||||||
|
dpi="120"
|
||||||
|
;;
|
||||||
|
1.5*)
|
||||||
|
dpi="144"
|
||||||
|
;;
|
||||||
|
1.75*)
|
||||||
|
dpi="168"
|
||||||
|
;;
|
||||||
|
2.0*)
|
||||||
|
dpi="192"
|
||||||
|
;;
|
||||||
|
2.5*)
|
||||||
|
dpi="240"
|
||||||
|
;;
|
||||||
|
3.0*)
|
||||||
|
dpi="288"
|
||||||
|
;;
|
||||||
|
3.5*)
|
||||||
|
dpi="336"
|
||||||
|
;;
|
||||||
|
4.0*)
|
||||||
|
dpi="384"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
dpi="96"
|
||||||
|
#可能不是Xorg或者是其他错误
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
echo "用$APPRUN_CMD执行指令"
|
||||||
|
echo "指令为"
|
||||||
|
echo "env WINEPREFIX="$CONTAINER_PATH" $APPRUN_CMD reg ADD 'HKCU\Control Panel\Desktop' /v LogPixels /t REG_DWORD /d $dpi /f"
|
||||||
|
|
||||||
|
env WINEPREFIX="$CONTAINER_PATH" $APPRUN_CMD reg ADD 'HKCU\Control Panel\Desktop' /v LogPixels /t REG_DWORD /d $dpi /f
|
||||||
|
|
||||||
|
fi
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_OPTION="Options"
|
||||||
|
TRANSHELL_CONTENT_YOUR_DIMENSION_IS="Your dimension is :"
|
||||||
|
TRANSHELL_CONTENT_PLEASE_CHOOSE_ONE_BELOW="Please choose one option below"
|
||||||
|
TRANSHELL_CONTENT_1_SCALE_AS_DEFAULT="Setting 1.0 scale as default"
|
||||||
|
TRANSHELL_CONTENT_SCALE_IS="Scale multiple is "
|
||||||
|
TRANSHELL_CONTENT_SAVED="saved."
|
||||||
|
TRANSHELL_CONTENT_YOU_CAN_USE_SPARK_WINE_HELPER_SETTINGS_TO_ADJUST="You can use spark wine helper settings to adjust settings"
|
||||||
@@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_OPTION="选项"
|
||||||
|
TRANSHELL_CONTENT_YOUR_DIMENSION_IS="您的分辨率是:"
|
||||||
|
TRANSHELL_CONTENT_PLEASE_CHOOSE_ONE_BELOW="请在以下选项中选择一个"
|
||||||
|
TRANSHELL_CONTENT_1_SCALE_AS_DEFAULT="默认为1倍缩放。"
|
||||||
|
TRANSHELL_CONTENT_SCALE_IS="缩放倍数为"
|
||||||
|
TRANSHELL_CONTENT_SAVED="已保存"
|
||||||
|
TRANSHELL_CONTENT_YOU_CAN_USE_SPARK_WINE_HELPER_SETTINGS_TO_ADJUST="您可以使用星火wine助手设置来重新设置"
|
||||||
@@ -0,0 +1,201 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
SHELL_DIR=$(dirname $(realpath $0))
|
||||||
|
|
||||||
|
# 函数:获取所有应用列表
|
||||||
|
# 函数:获取所有应用列表
|
||||||
|
get_apps_list() {
|
||||||
|
local apps_list=()
|
||||||
|
local app_dirs=($(find /opt/apps -mindepth 1 -maxdepth 1 -type d -exec test -f {}/files/run.sh \; -print))
|
||||||
|
|
||||||
|
if [ ${#app_dirs[@]} -eq 0 ]; then
|
||||||
|
zenity --error --text="请至少在应用商店安装一个wine应用后启动" --width 200
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
for app_dir in "${app_dirs[@]}"; do
|
||||||
|
local package_name=$(basename "$app_dir")
|
||||||
|
local run_script="$app_dir/files/run.sh"
|
||||||
|
local bottle_name="无法读取"
|
||||||
|
local version="无法读取"
|
||||||
|
local use_spark="否"
|
||||||
|
|
||||||
|
if [ -f "$run_script" ]; then
|
||||||
|
bottle_name=$(grep -oP 'BOTTLENAME="\K[^"]+' "$run_script")
|
||||||
|
version=$(grep -oP 'APPVER="\K[^"]+' "$run_script")
|
||||||
|
|
||||||
|
if [ -z "$version" ]; then
|
||||||
|
version="无法读取"
|
||||||
|
fi
|
||||||
|
# START_SHELL_PATH=XXX/spark_run_v4.sh
|
||||||
|
if grep START_SHELL_PATH= "$run_script" | grep spark_run_v4.sh; then
|
||||||
|
use_spark="是"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
local app_name=$(get_app_name "$package_name")
|
||||||
|
|
||||||
|
apps_list+=("$app_name" "$package_name" "$bottle_name" "$version" "$use_spark")
|
||||||
|
done
|
||||||
|
|
||||||
|
echo "${apps_list[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
# 函数:获取应用名称
|
||||||
|
get_app_name() {
|
||||||
|
local app_name_orig=$(grep -m 1 '^Name=' "/usr/share/applications/$1.desktop" | cut -d '=' -f 2)
|
||||||
|
local app_name_i18n=$(grep -m 1 "^Name\[$LANGUAGE\]\=" "/usr/share/applications/$1.desktop" | cut -d '=' -f 2)
|
||||||
|
local app_name=""
|
||||||
|
|
||||||
|
if [ -z "$app_name_i18n" ]; then
|
||||||
|
app_name="$app_name_orig"
|
||||||
|
else
|
||||||
|
app_name="$app_name_i18n"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$app_name"
|
||||||
|
}
|
||||||
|
|
||||||
|
# 函数:选择应用
|
||||||
|
select_app() {
|
||||||
|
local apps_list=($(get_apps_list))
|
||||||
|
local app=$(zenity --print-column=2 --width=800 --height=600 --list --title="选择应用" --text="选择要执行的应用" --column="应用名" --column="包名" --column="容器名" --column="版本号" --column="是否使用星火wine助手" "${apps_list[@]}")
|
||||||
|
|
||||||
|
if [ -n "$app" ]; then
|
||||||
|
local app_dir="/opt/apps/$app"
|
||||||
|
local run_script="$app_dir/files/run.sh"
|
||||||
|
local use_spark="否"
|
||||||
|
if if grep START_SHELL_PATH= "$run_script" | grep spark_run_v4.sh; then
|
||||||
|
use_spark="是"
|
||||||
|
fi
|
||||||
|
if [ "$use_spark" == "是" ]; then
|
||||||
|
select_spark_action "$app" "$(get_app_name $app)"
|
||||||
|
else
|
||||||
|
select_non_spark_action "$app" "$(get_app_name $app)"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
select_non_spark_action(){
|
||||||
|
local app="$1"
|
||||||
|
local app_name="$2"
|
||||||
|
local options=("在终端中打开" "打开容器目录" "清理并重置容器目录" "更多操作")
|
||||||
|
local choice=$(zenity --width=800 --height=600 --list --title="选择操作" --text="选择要对$app_name执行的操作" --column="操作" "${options[@]}")
|
||||||
|
case "$choice" in
|
||||||
|
"在终端中打开")
|
||||||
|
local app_dir="/opt/apps/$app"
|
||||||
|
local run_script="$app_dir/files/run.sh"
|
||||||
|
x-terminal-emulator -e "$run_script"
|
||||||
|
;;
|
||||||
|
"打开容器目录")
|
||||||
|
local app_dir="/opt/apps/$app"
|
||||||
|
local run_script="$app_dir/files/run.sh"
|
||||||
|
local bottle_name=$(grep -oP 'BOTTLENAME="\K[^"]+' "$run_script")
|
||||||
|
xdg-open file:///home/$(whoami)/.deepinwine/${bottle_name}
|
||||||
|
;;
|
||||||
|
"清理并重置容器目录")
|
||||||
|
local app_dir="/opt/apps/$app"
|
||||||
|
local run_script="$app_dir/files/run.sh"
|
||||||
|
local bottle_name=$(grep -oP 'BOTTLENAME="\K[^"]+' "$run_script")
|
||||||
|
$SHELL_DIR/../kill.sh ${bottle_name}
|
||||||
|
rm -rf /home/$(whoami)/.deepinwine/${bottle_name}/*
|
||||||
|
zenity --info --width=300 --text="操作已完成,请重启Wine应用查看"
|
||||||
|
;;
|
||||||
|
"更多操作")
|
||||||
|
if [ -e /usr/bin/deepin-wine-runner ];then
|
||||||
|
/usr/bin/deepin-wine-runner
|
||||||
|
elif [ $(command -v spark-store) ];then
|
||||||
|
spark-store spk://store/tools/spark-deepin-wine-runner
|
||||||
|
elif [ $(command -v deepin-home-appstore-client) ];then
|
||||||
|
xdg-open appstore://deepin-home-appstore-client?app_detail_info/spark-deepin-wine-runner
|
||||||
|
else
|
||||||
|
xdg-open https://gitee.com/gfdgd-xi/deep-wine-runner/releases
|
||||||
|
fi
|
||||||
|
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
# 函数:选择星火wine助手操作
|
||||||
|
select_spark_action() {
|
||||||
|
local app="$1"
|
||||||
|
local app_name="$2"
|
||||||
|
local options=("在终端中打开" "打开容器目录" "清理并重置容器目录" "修改应用缩放" "修改全局缩放" "更多操作")
|
||||||
|
local choice=$(zenity --width=800 --height=600 --list --title="选择操作" --text="选择要对$app_name执行的操作" --column="操作" "${options[@]}")
|
||||||
|
|
||||||
|
case "$choice" in
|
||||||
|
"在终端中打开")
|
||||||
|
local app_dir="/opt/apps/$app"
|
||||||
|
local run_script="$app_dir/files/run.sh"
|
||||||
|
x-terminal-emulator -e "$run_script"
|
||||||
|
;;
|
||||||
|
"打开容器目录")
|
||||||
|
local app_dir="/opt/apps/$app"
|
||||||
|
local run_script="$app_dir/files/run.sh"
|
||||||
|
local bottle_name=$(grep -oP 'BOTTLENAME="\K[^"]+' "$run_script")
|
||||||
|
xdg-open file:///home/$(whoami)/.deepinwine/${bottle_name}
|
||||||
|
;;
|
||||||
|
"清理并重置容器目录")
|
||||||
|
local app_dir="/opt/apps/$app"
|
||||||
|
local run_script="$app_dir/files/run.sh"
|
||||||
|
local bottle_name=$(grep -oP 'BOTTLENAME="\K[^"]+' "$run_script")
|
||||||
|
$SHELL_DIR/../spark_kill.sh ${bottle_name}
|
||||||
|
rm -rf /home/$(whoami)/.deepinwine/${bottle_name}/*
|
||||||
|
zenity --info --width=300 --text="操作已完成,请重启Wine应用查看"
|
||||||
|
;;
|
||||||
|
"修改应用缩放")
|
||||||
|
select_scale_action "应用" "$app"
|
||||||
|
;;
|
||||||
|
"修改全局缩放")
|
||||||
|
select_scale_action "全局" "$app"
|
||||||
|
;;
|
||||||
|
"更多操作")
|
||||||
|
if [ -e /usr/bin/deepin-wine-runner ];then
|
||||||
|
/usr/bin/deepin-wine-runner
|
||||||
|
elif [ $(command -v spark-store) ];then
|
||||||
|
spark-store spk://store/tools/spark-deepin-wine-runner
|
||||||
|
elif [ $(command -v deepin-home-appstore-client) ];then
|
||||||
|
xdg-open appstore://deepin-home-appstore-client?app_detail_info/spark-deepin-wine-runner
|
||||||
|
else
|
||||||
|
xdg-open https://gitee.com/gfdgd-xi/deep-wine-runner/releases
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
}
|
||||||
|
|
||||||
|
# 函数:选择缩放操作
|
||||||
|
select_scale_action() {
|
||||||
|
local scale_type="$1"
|
||||||
|
local app="$2"
|
||||||
|
local app_dir="/opt/apps/$app"
|
||||||
|
local run_script="$app_dir/files/run.sh"
|
||||||
|
local bottle_name=$(grep -oP 'BOTTLENAME="\K[^"]+' "$run_script")
|
||||||
|
local scale_factors=("1.0" "1.25" "1.5" "1.75" "2.0" "2.5" "3.0" "3.5" "4.0" "恢复默认")
|
||||||
|
local choice=$(zenity --width=800 --height=600 --list --title="选择缩放比例" --text="选择要设置的缩放比例" --column="比例" "${scale_factors[@]}")
|
||||||
|
|
||||||
|
if [ -n "$choice" ]; then
|
||||||
|
local scale_factor="$choice"
|
||||||
|
|
||||||
|
if [ "$scale_type" == "应用" ]; then
|
||||||
|
if [ "$scale_factor" == "恢复默认" ];then
|
||||||
|
rm $HOME/.deepinwine/$bottle_name/scale.txt
|
||||||
|
else
|
||||||
|
$SHELL_DIR/scale-set-helper/set-wine-scale.sh -s "$scale_factor" "$HOME/.deepinwine/$bottle_name"
|
||||||
|
fi
|
||||||
|
elif [ "$scale_type" == "全局" ]; then
|
||||||
|
if [ "$scale_factor" == "恢复默认" ];then
|
||||||
|
rm $HOME/.config/spark-wine/scale.txt
|
||||||
|
else
|
||||||
|
echo "$scale_factor" > "$HOME/.config/spark-wine/scale.txt"
|
||||||
|
find "$HOME/.deepinwine/" -name "scale.txt" -type f -print -exec rm -rf {} \;
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
zenity --info --width=300 --text="操作已完成,请重启Wine应用查看"
|
||||||
|
}
|
||||||
|
|
||||||
|
select_app
|
||||||
|
|
||||||
57
packager-config/deepinwine/tools/spark-wine-banner
Executable file
57
packager-config/deepinwine/tools/spark-wine-banner
Executable file
@@ -0,0 +1,57 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
##### 若有pybanner则尝试启动
|
||||||
|
#if [ -e ${SHELL_DIR}/spark-dwine-helper/pybanner/pybanner.py ];then
|
||||||
|
#echo "Protocol upgrade: Trying to activate python banner..."
|
||||||
|
#python3 ${SHELL_DIR}/spark-dwine-helper/pybanner/pybanner.py
|
||||||
|
#if [ "$?" = "0" ];then
|
||||||
|
#exit
|
||||||
|
#else
|
||||||
|
#echo "Failed to activate. Fallback to normal zenity."
|
||||||
|
#fi
|
||||||
|
#fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ ! -z "$WAYLAND_DISPLAY" ]; then
|
||||||
|
echo "Wayland detected. Do not check wmclass"
|
||||||
|
zenity --progress --title="星火Windows应用兼容助手" --text="正在为您启动以下应用:$WINE_APP_NAME" --pulsate --width=400 --auto-close --no-cancel --timeout=3
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$(which wmctrl)" ]; then
|
||||||
|
echo "No wmctrl installed. Do not check wmclass"
|
||||||
|
zenity --progress --title="星火Windows应用兼容助手" --text="正在为您启动以下应用:$WINE_APP_NAME" --pulsate --width=400 --auto-close --no-cancel --timeout=3
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
target_wmclass="$WINE_WMCLASS"
|
||||||
|
|
||||||
|
|
||||||
|
function check_window() {
|
||||||
|
# 使用 wmctrl 命令列出所有窗口,并使用 grep 过滤出特定的 WMCLASS
|
||||||
|
windows=$(wmctrl -lx | grep "$target_wmclass")
|
||||||
|
|
||||||
|
# 如果窗口存在,则关闭提示
|
||||||
|
if [ -n "$windows" ]; then
|
||||||
|
# 提取窗口ID
|
||||||
|
window_id=$(echo "$windows" | awk '{print $1}')
|
||||||
|
|
||||||
|
echo "Window with WMCLASS '$target_wmclass' found"
|
||||||
|
exit
|
||||||
|
else
|
||||||
|
echo "Window with WMCLASS '$target_wmclass' not found."
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function check_wmclass(){
|
||||||
|
# 递归检测窗口是否存在的函数
|
||||||
|
|
||||||
|
# 每隔一段时间检测一次窗口是否存在
|
||||||
|
while true; do
|
||||||
|
check_window
|
||||||
|
# 等待一段时间后再次检测
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
check_wmclass | zenity --progress --title="星火Windows应用兼容助手" --text="正在为您启动以下应用:$WINE_APP_NAME" --pulsate --width=400 --auto-close --no-cancel --timeout=20
|
||||||
22
packager-config/deepinwine/tools/spark_get_tray_window
Executable file
22
packager-config/deepinwine/tools/spark_get_tray_window
Executable file
@@ -0,0 +1,22 @@
|
|||||||
|
#!/usr/bin/env python3
|
||||||
|
# vim: set ts=4 sw=4 fileencoding=utf-8:
|
||||||
|
# Luomio <nohappiness@gmail.com>
|
||||||
|
# Filename: dde-first-run.py
|
||||||
|
# Create Date: 27-03, 13
|
||||||
|
|
||||||
|
import dbus
|
||||||
|
|
||||||
|
def get_tray_window():
|
||||||
|
bus = dbus.SessionBus()
|
||||||
|
traymanager = bus.get_object("com.deepin.dde.TrayManager", "/com/deepin/dde/TrayManager")
|
||||||
|
|
||||||
|
traymanager_iface = dbus.Interface(traymanager, dbus_interface='org.freedesktop.DBus.Properties')
|
||||||
|
windows = traymanager_iface.Get("com.deepin.dde.TrayManager","TrayIcons")
|
||||||
|
str="window_id:"
|
||||||
|
for i in range(len(windows)):
|
||||||
|
str += '{:#x} '.format(windows[i])
|
||||||
|
|
||||||
|
print(str)
|
||||||
|
|
||||||
|
if __name__ == "__main__":
|
||||||
|
get_tray_window()
|
||||||
BIN
packager-config/deepinwine/tools/spark_gl-wine/gdid3d.reg
Normal file
BIN
packager-config/deepinwine/tools/spark_gl-wine/gdid3d.reg
Normal file
Binary file not shown.
BIN
packager-config/deepinwine/tools/spark_gl-wine/gl-wine32
Executable file
BIN
packager-config/deepinwine/tools/spark_gl-wine/gl-wine32
Executable file
Binary file not shown.
BIN
packager-config/deepinwine/tools/spark_gl-wine/gl-wine64
Executable file
BIN
packager-config/deepinwine/tools/spark_gl-wine/gl-wine64
Executable file
Binary file not shown.
19
packager-config/deepinwine/tools/spark_gl-wine/run_gl.sh
Executable file
19
packager-config/deepinwine/tools/spark_gl-wine/run_gl.sh
Executable file
@@ -0,0 +1,19 @@
|
|||||||
|
#/bin/bash
|
||||||
|
|
||||||
|
cd $(dirname $0)
|
||||||
|
|
||||||
|
SHELL_DIR=$(dirname $(realpath $0))
|
||||||
|
runtime_path=/opt/deepinwine/runtime-i386
|
||||||
|
echo $runtime_path
|
||||||
|
if [ -f "$runtime_path/init_runtime.sh" ];then
|
||||||
|
source "$runtime_path/init_runtime.sh"
|
||||||
|
|
||||||
|
init_runtime
|
||||||
|
init_32bit_config
|
||||||
|
echo "use deepinwine runtime"
|
||||||
|
"$WINELDPATH" ./gl-wine32
|
||||||
|
exit $?
|
||||||
|
fi
|
||||||
|
|
||||||
|
./gl-wine32
|
||||||
|
exit $?
|
||||||
272
packager-config/deepinwine/tools/spark_kill.sh
Executable file
272
packager-config/deepinwine/tools/spark_kill.sh
Executable file
@@ -0,0 +1,272 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
#####因为arm版本的deepin-wine-helper不带这个,又不想破坏x86兼容性,故改名
|
||||||
|
APP_NAME="QQ"
|
||||||
|
LOG_FILE=$0
|
||||||
|
PUBLIC_DIR="/var/public"
|
||||||
|
|
||||||
|
UsePublicDir()
|
||||||
|
{
|
||||||
|
if [ -z "$USE_PUBLIC_DIR" ]; then
|
||||||
|
echo "Don't use public dir"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if [ ! -d "$PUBLIC_DIR" ];then
|
||||||
|
echo "Not found $PUBLIC_DIR"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if [ ! -r "$PUBLIC_DIR" ];then
|
||||||
|
echo "Can't read for $PUBLIC_DIR"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if [ ! -w "$PUBLIC_DIR" ];then
|
||||||
|
echo "Can't write for $PUBLIC_DIR"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
if [ ! -x "$PUBLIC_DIR" ];then
|
||||||
|
echo "Can't excute for $PUBLIC_DIR"
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
|
WINE_BOTTLE="$HOME/.deepinwine"
|
||||||
|
|
||||||
|
if UsePublicDir;then
|
||||||
|
WINE_BOTTLE="$PUBLIC_DIR"
|
||||||
|
fi
|
||||||
|
|
||||||
|
get_wine_by_pid()
|
||||||
|
{
|
||||||
|
wine_path=$(cat /proc/$1/maps | grep -E "\/wine$|\/wine64$|\/wine |\/wine64 " | head -1 | awk '{print $6}')
|
||||||
|
if [ -z "$wine_path" ];then
|
||||||
|
cat /proc/$1/cmdline| xargs -0 -L1 -I{} echo {} | grep -E "\/wine$|\/wine64$|\/wine |\/wine64 " | head -1
|
||||||
|
else
|
||||||
|
echo $wine_path
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
is_wine_process()
|
||||||
|
{
|
||||||
|
wine_module=$(get_wine_by_pid $1)
|
||||||
|
if [ -z "$wine_module" ];then
|
||||||
|
wine_module=$(cat /proc/$1/maps | grep -E "\/wineserver$" | head -1)
|
||||||
|
fi
|
||||||
|
echo $wine_module
|
||||||
|
}
|
||||||
|
|
||||||
|
get_prefix_by_pid()
|
||||||
|
{
|
||||||
|
WINE_PREFIX=$(xargs -0 printf '%s\n' < /proc/$1/environ | grep WINEPREFIX)
|
||||||
|
WINE_PREFIX=${WINE_PREFIX##*=}
|
||||||
|
if [ -z "$WINE_PREFIX" ] && [ -n "$(is_wine_process $1)" ]; then
|
||||||
|
#不指定容器的情况用默认容器目录
|
||||||
|
WINE_PREFIX="$HOME/.wine"
|
||||||
|
fi
|
||||||
|
if [ -n "$WINE_PREFIX" ];then
|
||||||
|
WINE_PREFIX=$(realpath $WINE_PREFIX)
|
||||||
|
echo $WINE_PREFIX
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
get_wineserver()
|
||||||
|
{
|
||||||
|
if [ -z "$1" ];then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
targ_prefix=$(realpath $1)
|
||||||
|
ps -ef | grep wineserver | while read server_info ;do
|
||||||
|
debug_log_to_file "get server info: $server_info"
|
||||||
|
server_pid=$(echo $server_info | awk '{print $2}')
|
||||||
|
server_prefix=$(get_prefix_by_pid $server_pid)
|
||||||
|
debug_log_to_file "get server pid $server_pid, prefix: $server_prefix"
|
||||||
|
|
||||||
|
if [ "$targ_prefix" = "$server_prefix" ];then
|
||||||
|
server=$(echo $server_info | awk '{print $NF}')
|
||||||
|
if [ "-p0" = "$server" ];then
|
||||||
|
server=$(echo $server_info | awk '{print $(NF-1)}')
|
||||||
|
fi
|
||||||
|
debug_log_to_file "get server $server"
|
||||||
|
echo $server
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
init_log_file()
|
||||||
|
{
|
||||||
|
if [ -d "$DEBUG_LOG" ];then
|
||||||
|
LOG_DIR=$(realpath $DEBUG_LOG)
|
||||||
|
if [ -d "$LOG_DIR" ];then
|
||||||
|
LOG_FILE="${LOG_DIR}/${LOG_FILE##*/}.log"
|
||||||
|
echo "" > "$LOG_FILE"
|
||||||
|
debug_log "LOG_FILE=$LOG_FILE"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
debug_log_to_file()
|
||||||
|
{
|
||||||
|
if [ -d "$DEBUG_LOG" ];then
|
||||||
|
strDate=$(date)
|
||||||
|
echo -e "${strDate}:${1}" >> "$LOG_FILE"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
debug_log()
|
||||||
|
{
|
||||||
|
strDate=$(date)
|
||||||
|
echo "${strDate}:${1}"
|
||||||
|
}
|
||||||
|
|
||||||
|
init_log_file
|
||||||
|
|
||||||
|
get_bottle_path_by_process_id()
|
||||||
|
{
|
||||||
|
PID_LIST="$1"
|
||||||
|
PREFIX_LIST=""
|
||||||
|
|
||||||
|
for pid_var in $PID_LIST ; do
|
||||||
|
WINE_PREFIX=$(get_prefix_by_pid $pid_var)
|
||||||
|
#去掉重复项
|
||||||
|
for path in $(echo -e $PREFIX_LIST) ; do
|
||||||
|
if [[ $path == "$WINE_PREFIX" ]]; then
|
||||||
|
WINE_PREFIX=""
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
if [ -d "$WINE_PREFIX" ]; then
|
||||||
|
debug_log_to_file "found $pid_var : $WINE_PREFIX"
|
||||||
|
PREFIX_LIST+="\n$WINE_PREFIX"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
echo -e $PREFIX_LIST
|
||||||
|
}
|
||||||
|
|
||||||
|
get_pid_by_process_name()
|
||||||
|
{
|
||||||
|
PID_LIST=""
|
||||||
|
for pid_var in $(ps -ef | grep -E -i "$1" | grep -v grep | awk '{print $2}');do
|
||||||
|
#通过判断是否加载wine来判断是不是wine进程
|
||||||
|
if [ -n "$(is_wine_process $pid_var)" ];then
|
||||||
|
PID_LIST+=" $pid_var"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
echo "$PID_LIST"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_bottle_path_by_process_name()
|
||||||
|
{
|
||||||
|
PID_LIST=$(get_pid_by_process_name $1)
|
||||||
|
debug_log_to_file "get pid list: $PID_LIST"
|
||||||
|
get_bottle_path_by_process_id "$PID_LIST"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_bottle_path()
|
||||||
|
{
|
||||||
|
if [ -z "$1" ];then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f "$1/user.reg" ]; then
|
||||||
|
realpath "$1"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f "$WINE_BOTTLE/$1/user.reg" ]; then
|
||||||
|
realpath "$WINE_BOTTLE/$1"
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
get_bottle_path_by_process_name "$1"
|
||||||
|
}
|
||||||
|
|
||||||
|
kill_app()
|
||||||
|
{
|
||||||
|
debug_log "try to kill $1"
|
||||||
|
for path in $(get_bottle_path $1); do
|
||||||
|
if [ -n "$path" ];then
|
||||||
|
WINESERVER=$(get_wineserver "$path")
|
||||||
|
|
||||||
|
if [ -f "$WINESERVER" ];then
|
||||||
|
debug_log "kill $path by $WINESERVER"
|
||||||
|
env WINEPREFIX="$path" "$WINESERVER" -k
|
||||||
|
fi
|
||||||
|
|
||||||
|
PID_LIST=$(get_pid_by_process_name "exe|wine")
|
||||||
|
for tag_pid in $PID_LIST; do
|
||||||
|
bottle=$(get_bottle_path_by_process_id "$tag_pid")
|
||||||
|
bottle=${bottle:1}
|
||||||
|
if [ "$path" = "$bottle" ];then
|
||||||
|
echo "kill $tag_pid for $bottle"
|
||||||
|
kill -9 $tag_pid
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
#Kill defunct process
|
||||||
|
ps -ef | grep -E "$USER.*exe.*<defunct>"
|
||||||
|
ps -ef | grep -E "$USER.*exe.*<defunct>" | grep -v grep | awk '{print $2}' | xargs -i kill -9 {}
|
||||||
|
}
|
||||||
|
|
||||||
|
get_tray_window()
|
||||||
|
{
|
||||||
|
$SHELL_DIR/spark_get_tray_window | awk -F: '{print $2}'
|
||||||
|
}
|
||||||
|
|
||||||
|
get_stacking_window()
|
||||||
|
{
|
||||||
|
xprop -root _NET_CLIENT_LIST_STACKING | awk -F# '{print $2}' | sed -e 's/, / /g'
|
||||||
|
}
|
||||||
|
|
||||||
|
get_window_pid()
|
||||||
|
{
|
||||||
|
for winid in $(echo "$1" | sed -e 's/ /\n/g') ;
|
||||||
|
do
|
||||||
|
xprop -id $winid _NET_WM_PID | awk -F= '{print $2}'
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
get_window_bottle()
|
||||||
|
{
|
||||||
|
debug_log_to_file "get_window_bottle $1"
|
||||||
|
PID_LIST=$(get_window_pid "$1")
|
||||||
|
debug_log_to_file "get_window_bottle pid list: $PID_LIST"
|
||||||
|
get_bottle_path_by_process_id "$PID_LIST"
|
||||||
|
}
|
||||||
|
|
||||||
|
get_active_bottles()
|
||||||
|
{
|
||||||
|
TRAYWINDOWS=$(get_tray_window)
|
||||||
|
STACKINGWINDOWS=$(get_stacking_window)
|
||||||
|
debug_log_to_file "tray window id: $TRAYWINDOWS"
|
||||||
|
debug_log_to_file "stacking window id: $STACKINGWINDOWS"
|
||||||
|
PID_LIST="$TRAYWINDOWS $STACKINGWINDOWS"
|
||||||
|
get_window_bottle "$PID_LIST"
|
||||||
|
}
|
||||||
|
|
||||||
|
kill_exit_block_app()
|
||||||
|
{
|
||||||
|
TAGBOTTLE=$(get_bottle_path $1)
|
||||||
|
debug_log "tag bottle: $TAGBOTTLE"
|
||||||
|
ACTIVEBOTTLES=$(get_active_bottles)
|
||||||
|
debug_log "active bottles: $ACTIVEBOTTLES"
|
||||||
|
|
||||||
|
if [[ "$ACTIVEBOTTLES" != *"$TAGBOTTLE"* ]]; then
|
||||||
|
kill_app "$TAGBOTTLE"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#get_active_bottles
|
||||||
|
#exit
|
||||||
|
|
||||||
|
debug_log "kill $1 $2"
|
||||||
|
|
||||||
|
if [ -n "$1" ]; then
|
||||||
|
APP_NAME="$1"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$2" = "block" ]; then
|
||||||
|
kill_exit_block_app $APP_NAME $3
|
||||||
|
else
|
||||||
|
kill_app $APP_NAME
|
||||||
|
fi
|
||||||
500
packager-config/deepinwine/tools/spark_run_v4.sh
Executable file
500
packager-config/deepinwine/tools/spark_run_v4.sh
Executable file
@@ -0,0 +1,500 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# Copyright (C) 2016 Deepin, Inc.
|
||||||
|
# Copyright (C) 2022 The Spark Project
|
||||||
|
#
|
||||||
|
# Author: Li LongYu <lilongyu@linuxdeepin.com>
|
||||||
|
# Peng Hao <penghao@linuxdeepin.com>
|
||||||
|
#
|
||||||
|
# Modifier: shenmo <shenmo@spark-app.store>
|
||||||
|
#
|
||||||
|
#
|
||||||
|
SHELL_DIR=$(dirname $(realpath $0))
|
||||||
|
|
||||||
|
export SHELL_DIR
|
||||||
|
source ${SHELL_DIR}/bashimport/log-function.bashimport
|
||||||
|
source ${SHELL_DIR}/bashimport/transhell.bashimport
|
||||||
|
load_transhell_debug
|
||||||
|
|
||||||
|
#########Preload functions
|
||||||
|
function get_app_name() {
|
||||||
|
local app_name_orig=$(grep -m 1 '^Name=' "/usr/share/applications/$1.desktop" | cut -d '=' -f 2)
|
||||||
|
local app_name_i18n=$(grep -m 1 "^Name\[$LANGUAGE\]\=" "/usr/share/applications/$1.desktop" | cut -d '=' -f 2)
|
||||||
|
local app_name=""
|
||||||
|
|
||||||
|
if [ -z "$app_name_i18n" ]; then
|
||||||
|
app_name="$app_name_orig"
|
||||||
|
else
|
||||||
|
app_name="$app_name_i18n"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$app_name"
|
||||||
|
}
|
||||||
|
######### Vars
|
||||||
|
BOTTLENAME="$1"
|
||||||
|
WINEPREFIX="$HOME/.deepinwine/$1"
|
||||||
|
APPDIR="/opt/apps/${DEB_PACKAGE_NAME}/files"
|
||||||
|
APPVER=""
|
||||||
|
APPTAR="files.7z"
|
||||||
|
BOTTLENAME=""
|
||||||
|
WINE_CMD="deepin-wine"
|
||||||
|
#这里会被后续覆盖
|
||||||
|
LOG_FILE=$0
|
||||||
|
PUBLIC_DIR="/var/public"
|
||||||
|
if [ -z $WINE_WMCLASS ];then
|
||||||
|
export WINE_WMCLASS="$DEB_PACKAGE_NAME"
|
||||||
|
fi
|
||||||
|
export WINE_APP_NAME=$(get_app_name ${DEB_PACKAGE_NAME})
|
||||||
|
if [ -z "$WINE_APP_NAME" ];then
|
||||||
|
export WINE_APP_NAME=$BOTTLENAME
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if [ -e /opt/p7zip-legacy/bin/7z ];then
|
||||||
|
log.debug "Using p7zip-legacy as unpacker"
|
||||||
|
UNPACK_CMD=/opt/p7zip-legacy/bin/7z
|
||||||
|
else
|
||||||
|
UNPACK_CMD=7z
|
||||||
|
log.debug "Using system 7z as unpacker"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
if [ $APPRUN_CMD ]; then
|
||||||
|
WINE_CMD=$APPRUN_CMD
|
||||||
|
fi
|
||||||
|
|
||||||
|
#####################
|
||||||
|
|
||||||
|
if [ "$WINE_CMD" = "deepin-wine8-stable" ] && [ "$(arch)" != "x86_64" ];then
|
||||||
|
|
||||||
|
WINE_CMD="${SHELL_DIR}/spark-dwine-helper/deepin-wine8-stable-wrapper/deepin-wine8-stable"
|
||||||
|
log.warn "Using deepin-wine8-stable wrapper to fix arm problem"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
##################### Functions
|
||||||
|
progressbar()
|
||||||
|
{
|
||||||
|
WINDOWID="" zenity --progress --title="$1" --text="$2" --pulsate --width=400 --auto-close --no-cancel ||
|
||||||
|
WINDOWID="" zenity --progress --title="$1" --text="$2" --pulsate --width=400 --auto-close
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
_DeleteRegistry()
|
||||||
|
{
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD reg DELETE "$1" /f &> /dev/null
|
||||||
|
}
|
||||||
|
#########功能:删除注册表
|
||||||
|
init_log_file()
|
||||||
|
{
|
||||||
|
if [ ! -d "$DEBUG_LOG" ];then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
LOG_DIR=$(realpath $DEBUG_LOG)
|
||||||
|
if [ -d "$LOG_DIR" ];then
|
||||||
|
LOG_FILE="${LOG_DIR}/${LOG_FILE##*/}.log"
|
||||||
|
echo "" > "$LOG_FILE"
|
||||||
|
debug_log "LOG_FILE=$LOG_FILE"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
debug_log_to_file()
|
||||||
|
{
|
||||||
|
if [ -d "$DEBUG_LOG" ];then
|
||||||
|
echo -e "${1}" >> "$LOG_FILE"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
debug_log()
|
||||||
|
{
|
||||||
|
log.debug "${1}"
|
||||||
|
}
|
||||||
|
################log相关功能
|
||||||
|
HelpApp()
|
||||||
|
{
|
||||||
|
echo " Extra Commands:"
|
||||||
|
echo " -r/--reset Reset app to fix errors"
|
||||||
|
echo " -e/--remove Remove deployed app files"
|
||||||
|
echo " -h/--help Show program help info"
|
||||||
|
}
|
||||||
|
#############帮助文件
|
||||||
|
|
||||||
|
check_link()
|
||||||
|
{
|
||||||
|
if [ ! -d "$1" ];then
|
||||||
|
echo "$1 不是目录,不能创建$2软连接"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
link_path=$(realpath "$2")
|
||||||
|
target_path=$(realpath "$1")
|
||||||
|
if [ "$link_path" != "$target_path" ];then
|
||||||
|
if [ -d "$2" ];then
|
||||||
|
mv "$2" "${2}.bak"
|
||||||
|
else
|
||||||
|
rm "$2"
|
||||||
|
fi
|
||||||
|
echo "修复$2软连接为$1"
|
||||||
|
ln -s -f "$1" "$2"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
FixLink()
|
||||||
|
{
|
||||||
|
if [ -d ${WINEPREFIX} ]; then
|
||||||
|
CUR_DIR=$PWD
|
||||||
|
cd "${WINEPREFIX}/dosdevices"
|
||||||
|
check_link ../drive_c c:
|
||||||
|
check_link / z:
|
||||||
|
check_link $HOME y:
|
||||||
|
cd "../drive_c/users/$USER"
|
||||||
|
check_link "$HOME/Desktop" Desktop
|
||||||
|
check_link "$HOME/Downloads" Downloads
|
||||||
|
# Link to Document
|
||||||
|
if [ -L "$WINEPREFIX/drive_c/users/$(whoami)/My Documents" ]; then
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD reg add 'HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders' /t REG_EXPAND_SZ /v Personal /d "%USERPROFILE%\My Documents" /f
|
||||||
|
|
||||||
|
else
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD reg add 'HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders' /t REG_EXPAND_SZ /v Personal /d "%USERPROFILE%\Documents" /f
|
||||||
|
|
||||||
|
fi
|
||||||
|
cd $CUR_DIR
|
||||||
|
#ls -l "${WINEPREFIX}/dosdevices"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
###########会在应用启动和解压时执行,驱动器绑定
|
||||||
|
DisableWrite()
|
||||||
|
{
|
||||||
|
if [ -d "${1}" ]; then
|
||||||
|
chmod +w "${1}"
|
||||||
|
rm -rf "${1}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
mkdir "${1}"
|
||||||
|
chmod -w "${1}"
|
||||||
|
}
|
||||||
|
########如果有该文件夹则删除,然后再创建一个不允许写入的
|
||||||
|
is_autostart()
|
||||||
|
{
|
||||||
|
AUTOSTART="/opt/deepinwine/tools/autostart"
|
||||||
|
if [[ -f "$SHELL_DIR/autostart" ]]; then
|
||||||
|
# 如果打包时自带 autostart,则使用自带的
|
||||||
|
AUTOSTART="$SHELL_DIR/autostart"
|
||||||
|
fi
|
||||||
|
if [ -f "$AUTOSTART.all" ]&&[ -f "/opt/apps/$1/files/run.sh" ];then
|
||||||
|
return 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f $AUTOSTART ];then
|
||||||
|
grep -c "$1" $AUTOSTART > /dev/null
|
||||||
|
return $?
|
||||||
|
fi
|
||||||
|
|
||||||
|
return 1
|
||||||
|
}
|
||||||
|
#########自动启动相关,等用到了再研究
|
||||||
|
|
||||||
|
Test_GL_wine()
|
||||||
|
{
|
||||||
|
gl_wine_path="${SHELL_DIR}/spark_gl-wine"
|
||||||
|
|
||||||
|
#如果不支持32的GLX,d3d改为gdi的实现
|
||||||
|
if [[ ! -f "${WINEPREFIX}/.init_d3d" ]];then
|
||||||
|
if [[ $WINE_CMD == *"deepin-wine8-stable"* ]];then
|
||||||
|
gl_wine="${gl_wine_path}/gl-wine64"
|
||||||
|
else
|
||||||
|
gl_wine="${gl_wine_path}/run_gl.sh"
|
||||||
|
fi
|
||||||
|
|
||||||
|
run_gl=`${gl_wine} 2>&1`
|
||||||
|
|
||||||
|
#如果opengl测试程序运行失败,所有进程的渲染方式改为gdi渲染模式
|
||||||
|
if [ $? != 0 ];then
|
||||||
|
WINEPREFIX="$WINEPREFIX" $WINE_CMD regedit /S "${gl_wine_path}/gdid3d.reg"
|
||||||
|
fi
|
||||||
|
|
||||||
|
touch "${WINEPREFIX}/.init_d3d"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
urldecode() { : "${*//+/ }"; echo -e "${_//%/\\x}"; }
|
||||||
|
#######url转义
|
||||||
|
|
||||||
|
#arg 1: windows process file path
|
||||||
|
#arg 2-*: windows process args
|
||||||
|
CallProcess()
|
||||||
|
{
|
||||||
|
#get file full path
|
||||||
|
path="$1"
|
||||||
|
path=$(echo ${path/c:/${WINEPREFIX}/drive_c})
|
||||||
|
path=$(echo ${path//\\/\/})
|
||||||
|
|
||||||
|
#kill bloack process
|
||||||
|
is_autostart $DEB_PACKAGE_NAME
|
||||||
|
autostart=$?
|
||||||
|
if [[ $autostart -ne 0 ]] && [[ "$1" != *"pluginloader.exe" ]];then
|
||||||
|
$SHELL_DIR/spark_kill.sh "$BOTTLENAME" block
|
||||||
|
fi
|
||||||
|
#run gl-wine for test opengl
|
||||||
|
get_arch=`uname -m`
|
||||||
|
if [[ $get_arch = "x86_64" ]];then
|
||||||
|
Test_GL_wine
|
||||||
|
fi
|
||||||
|
#change current dir to excute path
|
||||||
|
path=$(dirname "$path")
|
||||||
|
cd "$path"
|
||||||
|
pwd
|
||||||
|
|
||||||
|
#Set default mime type
|
||||||
|
if [ -n "$MIME_TYPE" ]; then
|
||||||
|
xdg-mime default "$DEB_PACKAGE_NAME".desktop "$MIME_TYPE"
|
||||||
|
fi
|
||||||
|
# Disable winemenubuilder
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD reg add 'HKEY_CURRENT_USER\Software\Wine\DllOverrides' /v winemenubuilder.exe /f
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
debug_log "Starting process $* ..."
|
||||||
|
|
||||||
|
############# WARNING: Here is the modified content: Now will run set-dwine-scale.sh
|
||||||
|
${SHELL_DIR}/spark-dwine-helper/scale-set-helper/set-wine-scale.sh "$WINEPREFIX"
|
||||||
|
$SHELL_DIR/spark-wine-banner &
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD "$@"
|
||||||
|
|
||||||
|
#start autobottle
|
||||||
|
if [ $autostart -eq 0 ];then
|
||||||
|
$SHELL_DIR/autostart_wine.sh $DEB_PACKAGE_NAME
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
###通用启动APP逻辑。对于没有被case捕捉的非适配APP,则直接执行此部分。似乎已经有了防止残留的功能
|
||||||
|
###一些自定义的应用不会使用这个启动,而另一些则会调用这个
|
||||||
|
###有设置mimetype和自动启动(这个暂时没分析)的功能
|
||||||
|
|
||||||
|
###########专属优化段:
|
||||||
|
|
||||||
|
|
||||||
|
UnixUriToDosPath()
|
||||||
|
{
|
||||||
|
OPEN_FILE="$1"
|
||||||
|
if [ -f "$OPEN_FILE" ]; then
|
||||||
|
OPEN_FILE=$(realpath "$OPEN_FILE")
|
||||||
|
OPEN_FILE="z:$OPEN_FILE"
|
||||||
|
OPEN_FILE=$(echo $OPEN_FILE | sed -e 's/\//\\\\/g')
|
||||||
|
fi
|
||||||
|
echo $OPEN_FILE
|
||||||
|
}
|
||||||
|
|
||||||
|
#arg 1: exec file path
|
||||||
|
#arg 2: autostart ,or exec arg 1
|
||||||
|
#arg 3: exec arg 2
|
||||||
|
|
||||||
|
#### CallApp段,根据容器名找专属优化,没有就走通用启动
|
||||||
|
CallApp()
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
FixLink
|
||||||
|
debug_log "CallApp $BOTTLENAME arg count $#: $*"
|
||||||
|
if [ -f "/opt/apps/${DEB_PACKAGE_NAME}/files/pre_run.sh" ];then
|
||||||
|
source "/opt/apps/${DEB_PACKAGE_NAME}/files/pre_run.sh"
|
||||||
|
CallPreRun "$@"
|
||||||
|
fi
|
||||||
|
if [ -e "/opt/deepinwine/tools/spark_run_v4_app_configs/${BOTTLENAME}.sh" ];then
|
||||||
|
APP_CONFIG_PATH="/opt/deepinwine/tools/spark_run_v4_app_configs/${BOTTLENAME}.sh"
|
||||||
|
else
|
||||||
|
APP_CONFIG_PATH="${SHELL_DIR}/spark_run_v4_app_configs/${BOTTLENAME}.sh"
|
||||||
|
fi
|
||||||
|
if [ -f "$APP_CONFIG_PATH" ]; then
|
||||||
|
echo "执行 ${BOTTLENAME}.sh ..."
|
||||||
|
source $APP_CONFIG_PATH
|
||||||
|
else
|
||||||
|
echo "$APP_CONFIG_PATH 文件不存在,执行通用启动"
|
||||||
|
CallProcess "$@"
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
ExtractApp()
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
local tmp_log=$(mktemp)
|
||||||
|
mkdir -p "$1"
|
||||||
|
(${UNPACK_CMD} x "$APPDIR/$APPTAR" -o"$1" -bsp1 -bb1 -bse2 | grep --line-buffered -oP "(\d+(\.\d+)?(?=%))" > $tmp_log)&
|
||||||
|
|
||||||
|
cmd_pid=$!
|
||||||
|
(while kill -0 $cmd_pid 2> /dev/null; do
|
||||||
|
tail -n 1 "${tmp_log}"
|
||||||
|
sleep 1
|
||||||
|
done)| zenity --progress --title="${TRANSHELL_CONTENT_SPARK_WINDOWS_COMPATIBILITY_TOOL}" --text="${TRANSHELL_CONTENT_UNPACKING} $WINE_APP_NAME..." --width=600 --auto-close --no-cancel
|
||||||
|
rm $tmp_log
|
||||||
|
|
||||||
|
|
||||||
|
mv "$1/drive_c/users/@current_user@" "$1/drive_c/users/$USER"
|
||||||
|
sed -i "s#@current_user@#$USER#" $1/*.reg
|
||||||
|
FixLink
|
||||||
|
}
|
||||||
|
DeployApp()
|
||||||
|
{
|
||||||
|
ExtractApp "$WINEPREFIX"
|
||||||
|
|
||||||
|
|
||||||
|
echo "$APPVER" > "$WINEPREFIX/PACKAGE_VERSION"
|
||||||
|
|
||||||
|
}
|
||||||
|
RemoveApp()
|
||||||
|
{
|
||||||
|
rm -rf "$WINEPREFIX"
|
||||||
|
}
|
||||||
|
ResetApp()
|
||||||
|
{
|
||||||
|
debug_log "Reset $PACKAGENAME....."
|
||||||
|
read -p "* Are you sure?(Y/N)" ANSWER
|
||||||
|
if [ "$ANSWER" = "Y" -o "$ANSWER" = "y" -o -z "$ANSWER" ]; then
|
||||||
|
EvacuateApp
|
||||||
|
DeployApp
|
||||||
|
CallApp
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
UpdateApp()
|
||||||
|
{
|
||||||
|
if [ -d "${WINEPREFIX}.tmpdir" ]; then
|
||||||
|
rm -rf "${WINEPREFIX}.tmpdir"
|
||||||
|
fi
|
||||||
|
if [ -f "$WINEPREFIX/PACKAGE_VERSION" ] && [ "$(cat "$WINEPREFIX/PACKAGE_VERSION")" = "$APPVER" ]; then
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -f "/opt/apps/${DEB_PACKAGE_NAME}/files/pre_update.sh" ];then
|
||||||
|
source "/opt/apps/${DEB_PACKAGE_NAME}/files/pre_update.sh"
|
||||||
|
CallPreUpdate
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
case $BOTTLENAME in
|
||||||
|
"Deepin-Intelligent" | "Deepin-QQ" | "Deepin-TIM" | "Deepin-WeChat" | "Deepin-WXWork" | "Deepin-Dding" | "Wine-QQ" | "Spark-QQ" | "Spark-weixin")
|
||||||
|
rm -rf "$WINEPREFIX"
|
||||||
|
DeployApp
|
||||||
|
return
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
ExtractApp "${WINEPREFIX}.tmpdir"
|
||||||
|
$SHELL_DIR/spark_updater -s "${WINEPREFIX}.tmpdir" -c "${WINEPREFIX}" -v
|
||||||
|
|
||||||
|
|
||||||
|
rm -rf "${WINEPREFIX}.tmpdir"
|
||||||
|
echo "$APPVER" > "$WINEPREFIX/PACKAGE_VERSION"
|
||||||
|
}
|
||||||
|
RunApp()
|
||||||
|
{
|
||||||
|
|
||||||
|
|
||||||
|
progpid=$(ps -ef | grep "zenity --progress --title=${BOTTLENAME}" | grep -v grep)
|
||||||
|
debug_log "run ${BOTTLENAME} progress pid $progpid"
|
||||||
|
if [ -n "$progpid" ]; then
|
||||||
|
debug_log "$BOTTLENAME is running"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d "$WINEPREFIX" ]; then
|
||||||
|
if [ ! -f "$WINEPREFIX/PACKAGE_VERSION" ] || [ "$(cat "$WINEPREFIX/PACKAGE_VERSION")" != "$APPVER" ]; then
|
||||||
|
UpdateApp
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
DeployApp
|
||||||
|
fi
|
||||||
|
|
||||||
|
CallApp "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
CreateBottle()
|
||||||
|
{
|
||||||
|
if [ -d "$WINEPREFIX" ]; then
|
||||||
|
if [ ! -f "$WINEPREFIX/PACKAGE_VERSION" ] || [ "$(cat "$WINEPREFIX/PACKAGE_VERSION")" != "$APPVER" ]; then
|
||||||
|
UpdateApp
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
DeployApp
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
ParseArgs()
|
||||||
|
{
|
||||||
|
if [ $# -eq 4 ];then
|
||||||
|
RunApp "$3"
|
||||||
|
elif [ -f "$5" ];then
|
||||||
|
if [ -n "$MIME_EXEC" ];then
|
||||||
|
RunApp "$MIME_EXEC" "$(UnixUriToDosPath "$5")" "${@:6}"
|
||||||
|
else
|
||||||
|
RunApp "$3" "$(UnixUriToDosPath "$5")" "${@:6}"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
RunApp "$3" "${@:5}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
#init_log_file
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#####准备启动进程,分析在 https://blog.shenmo.tech/post/deepin-wine6%E7%9A%84run_v4%E8%84%9A%E6%9C%AC%E6%8E%A2%E7%B4%A2%E5%90%AF%E5%8A%A8%E6%96%B9%E5%BC%8F/
|
||||||
|
if [ $# -lt 3 ]; then
|
||||||
|
debug_log "参数个数小于3个"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
APPDIR="/opt/apps/${DEB_PACKAGE_NAME}/files"
|
||||||
|
if [ -f "$APPDIR/files.md5sum" ];then
|
||||||
|
APPVER="$(cat $APPDIR/files.md5sum)"
|
||||||
|
else
|
||||||
|
APPVER="$2"
|
||||||
|
fi
|
||||||
|
|
||||||
|
debug_log "Run $*"
|
||||||
|
|
||||||
|
|
||||||
|
#执行lnk文件通过判断第5个参数是否是“/Unix”来判断
|
||||||
|
if [ "$4" == "/Unix" ];then
|
||||||
|
RunApp "$3" "$4" "$5"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $# -lt 4 ]; then
|
||||||
|
RunApp "$3"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
case $4 in
|
||||||
|
"-r" | "--reset")
|
||||||
|
ResetApp
|
||||||
|
;;
|
||||||
|
"-cb" | "--create")
|
||||||
|
CreateBottle
|
||||||
|
;;
|
||||||
|
"-e" | "--remove")
|
||||||
|
RemoveApp
|
||||||
|
;;
|
||||||
|
"-u" | "--uri")
|
||||||
|
ParseArgs "$@"
|
||||||
|
;;
|
||||||
|
"-f" | "--file")
|
||||||
|
ParseArgs "$@"
|
||||||
|
;;
|
||||||
|
"-h" | "--help")
|
||||||
|
HelpApp
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Invalid option: $4"
|
||||||
|
echo "Use -h|--help to get help"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
exit 0
|
||||||
@@ -0,0 +1,22 @@
|
|||||||
|
#get file full path
|
||||||
|
path="$1"
|
||||||
|
path=$(echo ${path/c:/${WINEPREFIX}/drive_c})
|
||||||
|
path=$(echo ${path//\\/\/})
|
||||||
|
|
||||||
|
#kill bloack process
|
||||||
|
name="${path##*/}"
|
||||||
|
$SHELL_DIR/spark_kill.sh "$name" block
|
||||||
|
|
||||||
|
#change current dir to excute path
|
||||||
|
path=$(dirname "$path")
|
||||||
|
cd "$path"
|
||||||
|
pwd
|
||||||
|
|
||||||
|
#Set default mime type
|
||||||
|
if [ -n "$MIME_TYPE" ]; then
|
||||||
|
xdg-mime default "$DEB_PACKAGE_NAME".desktop "$MIME_TYPE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
debug_log_to_file "Starting process $* ..."
|
||||||
|
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,4 @@
|
|||||||
|
debug_log "run $1"
|
||||||
|
$SHELL_DIR/spark_kill.sh DingTalk block
|
||||||
|
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
#set -- "$1" "${2#file://*}"
|
||||||
|
local path=$(urldecode "$2")
|
||||||
|
path=${path/file:\/\//}
|
||||||
|
set -- "$1" "$path"
|
||||||
|
if [ "$path" ];then
|
||||||
|
CallProcess "$@"
|
||||||
|
else
|
||||||
|
CallProcess "$1"
|
||||||
|
fi
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
#set -- "$1" "${2#file://*}"
|
||||||
|
local path=$(urldecode "$2")
|
||||||
|
path=${path/file:\/\//}
|
||||||
|
set -- "$1" "$path"
|
||||||
|
if [ "$path" ];then
|
||||||
|
CallProcess "$@"
|
||||||
|
else
|
||||||
|
CallProcess "$1"
|
||||||
|
fi
|
||||||
@@ -0,0 +1,2 @@
|
|||||||
|
sed -i '/LogPixels/d' ${WINEPREFIX}/user.reg
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
#set -- "$1" "${2#file://*}"
|
||||||
|
local path=$(urldecode "$2")
|
||||||
|
path=${path/file:\/\//}
|
||||||
|
set -- "$1" "$path"
|
||||||
|
if [ "$path" ];then
|
||||||
|
CallProcess "$@"
|
||||||
|
else
|
||||||
|
CallProcess "$1"
|
||||||
|
fi
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
Deepin-QQ.sh
|
||||||
@@ -0,0 +1,25 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
if [ ! -f "$WINEPREFIX/../.QQ_run" ]; then
|
||||||
|
debug_log "first run time"
|
||||||
|
$SHELL_DIR/add_hotkeys
|
||||||
|
$SHELL_DIR/fontconfig
|
||||||
|
touch "$WINEPREFIX/../.QQ_run"
|
||||||
|
fi
|
||||||
|
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/Program Files/Tencent/QQ/Bin/QQLiveMPlayer"
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/Program Files/Tencent/QQ/Bin/QQLiveMPlayer1"
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/Program Files/Tencent/QzoneMusic"
|
||||||
|
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/Program Files/Tencent/QQBrowser"
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/Program Files/Common Files/Tencent/QQBrowser"
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/users/Public/Application Data/Tencent/QQBrowserBin"
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/users/Public/Application Data/Tencent/QQBrowserDefault"
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/users/${USER}/Application Data/Tencent/QQBrowserDefault"
|
||||||
|
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/users/Public/Application Data/Tencent/QQPCMgr"
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/Program Files/Common Files/Tencent/QQPCMgr"
|
||||||
|
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/Program Files/Common Files/Tencent/HuaYang"
|
||||||
|
DisableWrite "${WINEPREFIX}/drive_c/users/${USER}/Application Data/Tencent/HuaYang"
|
||||||
|
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
debug_log "run $1"
|
||||||
|
$SHELL_DIR/spark_kill.sh QQMicroGameBox block
|
||||||
|
CallProcess "$1" -action:force_download -appid:1104632801 -pid:8 -bin_version:1.1.2.4 -loginuin:
|
||||||
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
debug_log "run $1"
|
||||||
|
$SHELL_DIR/spark_kill.sh qqgame block
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD "$1" &
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
debug_log "run $1"
|
||||||
|
$SHELL_DIR/spark_kill.sh QQMicroGameBox block
|
||||||
|
CallProcess "$1" -action:force_download -appid:363 -pid:8 -bin_version:1.1.2.4 -loginuin:
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
debug_log "run $1"
|
||||||
|
$SHELL_DIR/spark_kill.sh QQMicroGameBox block
|
||||||
|
CallProcess "$1" -action:force_download -appid:1105856612 -pid:8 -bin_version:1.1.2.4 -loginuin:
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
debug_log "run $1"
|
||||||
|
$SHELL_DIR/spark_kill.sh QQMicroGameBox block
|
||||||
|
CallProcess "$1" -action:force_download -appid:1105640244 -pid:8 -bin_version:1.1.2.4 -loginuin:
|
||||||
@@ -0,0 +1,23 @@
|
|||||||
|
$SHELL_DIR/spark_kill.sh ths block
|
||||||
|
|
||||||
|
debug_log "Start run $1"
|
||||||
|
#get file full path
|
||||||
|
path="$1"
|
||||||
|
path=$(echo ${path/c:/${WINEPREFIX}/drive_c})
|
||||||
|
path=$(echo ${path//\\/\/})
|
||||||
|
|
||||||
|
#kill bloack process
|
||||||
|
name="${path##*/}"
|
||||||
|
$SHELL_DIR/spark_kill.sh "$name" block
|
||||||
|
|
||||||
|
#change current dir to excute path
|
||||||
|
path=$(dirname "$path")
|
||||||
|
cd "$path"
|
||||||
|
pwd
|
||||||
|
|
||||||
|
#Set default mime type
|
||||||
|
if [ -n "$MIME_TYPE" ]; then
|
||||||
|
xdg-mime default "$DEB_PACKAGE_NAME".desktop "$MIME_TYPE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,17 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
if [ ! -f "$WINEPREFIX/../.QQ_run" ]; then
|
||||||
|
debug_log "first run time"
|
||||||
|
$SHELL_DIR/add_hotkeys
|
||||||
|
####似乎是给dde-control-center添加快捷键
|
||||||
|
$SHELL_DIR/fontconfig
|
||||||
|
####暂时无法得知用途和用法
|
||||||
|
# If the bottle not exists, run reg may cost lots of times
|
||||||
|
# So create the bottle befor run reg
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD uninstaller --list
|
||||||
|
touch $WINEPREFIX/../.QQ_run
|
||||||
|
fi
|
||||||
|
|
||||||
|
CallProcess "$@"
|
||||||
|
|
||||||
|
#disable Tencent MiniBrowser
|
||||||
|
_DeleteRegistry "HKCU\\Software\\Tencent\\MiniBrowser"
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
if [ -f "${WINEPREFIX}/drive_c/Program Files/Tencent/QQLive/Upgrade.dll" ]; then
|
||||||
|
rm -rf "${WINEPREFIX}/drive_c/Program Files/Tencent/QQLive/Upgrade.dll"
|
||||||
|
fi
|
||||||
|
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
if [ -d "${WINEPREFIX}/drive_c/users/${USER}/Application Data/Tencent/WXWork/Update" ]; then
|
||||||
|
rm -rf "${WINEPREFIX}/drive_c/users/${USER}/Application Data/Tencent/WXWork/Update"
|
||||||
|
fi
|
||||||
|
if [ -d "${WINEPREFIX}/drive_c/users/${USER}/Application Data/Tencent/WXWork/upgrade" ]; then
|
||||||
|
rm -rf "${WINEPREFIX}/drive_c/users/${USER}/Application Data/Tencent/WXWork/upgrade"
|
||||||
|
fi
|
||||||
|
#Support use native file dialog
|
||||||
|
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,9 @@
|
|||||||
|
#/bin/bash
|
||||||
|
chmod 700 "$WINEPREFIX/drive_c/Program Files/AliWangWang/9.12.10C/wwbizsrv.exe"
|
||||||
|
chmod 700 "$WINEPREFIX/drive_c/Program Files/Alibaba/wwbizsrv/wwbizsrv.exe"
|
||||||
|
if [ $# = 3 ] && [ -z "$3" ];then
|
||||||
|
EXEC_PATH="c:/Program Files/AliWangWang/9.12.10C/WWCmd.exe"
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD "$EXEC_PATH" "$2" &
|
||||||
|
else
|
||||||
|
CallProcess "$@"
|
||||||
|
fi
|
||||||
@@ -0,0 +1,2 @@
|
|||||||
|
export DISABLE_RENDER_CLIPBOARD=1
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,18 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
#change current dir to excute path
|
||||||
|
path=$(dirname "$path")
|
||||||
|
cd "$path"
|
||||||
|
pwd
|
||||||
|
|
||||||
|
#Set default mime type
|
||||||
|
if [ -n "$MIME_TYPE" ]; then
|
||||||
|
xdg-mime default "$DEB_PACKAGE_NAME".desktop "$MIME_TYPE"
|
||||||
|
fi
|
||||||
|
|
||||||
|
debug_log_to_file "Starting process $* ..."
|
||||||
|
if [ -n "$2" ];then
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD "$1" "--url=$2" &
|
||||||
|
else
|
||||||
|
env WINEPREFIX="$WINEPREFIX" $WINE_CMD "$1" &
|
||||||
|
fi
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
rm -f "$WINEPREFIX/system.reg"
|
||||||
|
cp $APPDIR/system.reg "$WINEPREFIX/system.reg"
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
CallProcess "$@"
|
||||||
|
sleep 2
|
||||||
|
/opt/apps/com.163.music.spark/files/disable_cloudmusic_shadows
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
CallProcess "$@"
|
||||||
|
sleep 2
|
||||||
|
/opt/apps/com.163.dashi.mailmaster.spark/files/disable_mailmaster_shadows
|
||||||
@@ -0,0 +1,4 @@
|
|||||||
|
if [ -f "${WINEPREFIX}/drive_c/ProgramData/Microsoft/Windows/Start\ Menu/Programs/MuBu.lnk" ]; then
|
||||||
|
chmod 555 ${WINEPREFIX}/drive_c/ProgramData/Microsoft/Windows/Start\ Menu/Programs/MuBu.lnk
|
||||||
|
fi
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
Deepin-QQ.sh
|
||||||
@@ -0,0 +1,16 @@
|
|||||||
|
if [ -e ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic/QQMusic.exe ]; then
|
||||||
|
sleep 1
|
||||||
|
rm -rf ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic/*.log
|
||||||
|
else
|
||||||
|
mkdir ${WINEPREFIX}/drive_c/Program\ Files/Tencent/updatetemp
|
||||||
|
mv ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic/*.dll ${WINEPREFIX}/drive_c/Program\ Files/Tencent/updatetemp
|
||||||
|
mv ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic/*.exe ${WINEPREFIX}/drive_c/Program\ Files/Tencent/updatetemp
|
||||||
|
mv ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic/*.rdb ${WINEPREFIX}/drive_c/Program\ Files/Tencent/updatetemp
|
||||||
|
mv ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic/*.log ${WINEPREFIX}/drive_c/Program\ Files/Tencent/updatetemp
|
||||||
|
mv ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic/QQMusic* ${WINEPREFIX}/drive_c/Program\ Files/Tencent
|
||||||
|
rm -rf ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic
|
||||||
|
rm -rf ${WINEPREFIX}/drive_c/Program\ Files/Tencent/updatetemp
|
||||||
|
rm -rf ${WINEPREFIX}/drive_c/Program\ Files/Tencent/*.log
|
||||||
|
mv ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic* ${WINEPREFIX}/drive_c/Program\ Files/Tencent/QQMusic
|
||||||
|
fi
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
Deepin-TIM.sh
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
Deepin-WXWork.sh
|
||||||
@@ -0,0 +1,6 @@
|
|||||||
|
if [ -f "${WINEPREFIX}/drive_c/users/${USER}/Application Data/douyin" ]; then
|
||||||
|
rm "${WINEPREFIX}/drive_c/users/${USER}/Application Data/douyin"
|
||||||
|
mv ${WINEPREFIX}/drive_c/users/${USER}/Application\ Data/*.tmp ${WINEPREFIX}/drive_c/users/${USER}/Application\ Data/douyin
|
||||||
|
chmod 755 ${WINEPREFIX}/drive_c/users/${USER}/Application\ Data/douyin
|
||||||
|
fi
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,2 @@
|
|||||||
|
DisableWrite ${WINEPREFIX}/drive_c/users/${USER}/Temp
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,5 @@
|
|||||||
|
if [ -w ${WINEPREFIX}/drive_c/users/${USER}/Application\ Data/飞项/Crashpad/reports ]; then
|
||||||
|
rm -rf ${WINEPREFIX}/drive_c/users/${USER}/Application\ Data/飞项/Crashpad/reports/*
|
||||||
|
chmod 555 ${WINEPREFIX}/drive_c/users/${USER}/Application\ Data/飞项/Crashpad/reports
|
||||||
|
fi
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1,37 @@
|
|||||||
|
echo
|
||||||
|
echo "⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⢀⣾⡟⠉⠻⣷⡄⠀⠀⠀⠀⠀⠀⢀⣀⣀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⢀⣾⣿⣴⣶⣶⣿⣿⡄⠀⠀⢀⣤⣾⠿⠻⣿⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⢀⣾⣿⣿⣿⣿⣿⣿⣿⣿⣤⣾⣿⣏⡁⠀⠀⣿⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⣼⡿⢿⣿⣯⣀⣿⣿⡿⢿⣿⣿⣿⣿⣿⣷⣄⣿⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⢸⣿⣿⣶⣬⡙⠿⠋⣡⣶⣿⣿⣿⣿⣿⣿⣿⣿⣿⠇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠀⣀⣀⣀⣀⣀⠀⠀⠀⠀⠀⠈⢻⣿⣿⠟⣁⣴⣤⡙⠻⣿⣿⣿⣿⣿⣿⣿⣿⡿⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠺⢿⣿⣿⣿⢿⠇⠀⠀⠀⠀⠀⠀⠹⣷⣾⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⠛⠁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⣖⣆⣀⣀⣀⣀⣀⣀⣀⡀⠀⠀⠀⠀⠀⠀⠀⠙⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⠟⠉⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⣿⠟⠛⠛⠛⠛⠛⠛⠛⠷⠿⠿⢿⣷⣶⣤⣤⣀⣸⣿⣿⣿⣿⣿⣿⠟⠁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⣿⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠉⠉⠛⢻⡏⠁⣈⢻⠙⣿⡆⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⣿⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠛⣲⡟⠞⢀⣿⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⣿⡇⠀⠀⠀⠀⢀⣀⣀⣤⣤⣤⣤⣤⣶⣶⣶⣶⣾⣿⣿⣿⣿⣿⣿⣿⣿⣶⣤⣄⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⣿⣷⣶⣾⡿⠿⠿⠛⢛⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣦⣄⠀⠀⠀⠀⠀⠀⠀⢀⣠⡤⣀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠙⠋⠀⠀⠀⠀⢀⣴⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⡄⠀⠀⠀⢠⣾⣿⣿⣿⣿⡆⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠀⠀⣠⣿⣿⣿⣿⣥⣼⣿⣿⣿⣿⣿⣿⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣆⠀⠀⠸⠽⠻⣿⡿⠟⠁⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠀⣼⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣾⣿⣁⣼⣿⣿⣿⣿⣿⢻⣿⡀⠙⣿⣿⣿⣿⣿⣧⠀⠀⠀⠀⣀⣤⣤⣄⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⢰⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣾⣿⣿⣶⣿⣿⣿⣿⣿⣿⣇⠀⠀⠀⢿⣿⣿⣿⠇⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⢸⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡄⠀⠀⠀⠉⠉⠁⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⢀⣾⣿⣿⣿⣿⣿⣿⣿⣿⡿⠿⠾⣿⣿⣿⣿⣿⣿⣿⡿⠷⣬⡻⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡇⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣶⣄⠀⢘⣿⣿⣿⣿⣿⠏⠀⠀⣀⣤⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠻⣿⣿⣿⣿⣿⣿⣿⣿⠁⠀⠈⠙⢿⣿⣷⣾⣿⠿⣿⣿⣇⣤⣶⣿⣿⠿⠛⠋⠙⠻⣿⣿⣿⣿⣿⣿⣿⣿⣧⡀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠉⠻⣿⣿⣿⣿⣷⠀⠀⣠⣶⣿⠿⠉⠁⠀⠀⠀⠉⠉⠉⠻⣿⣷⣄⠀⠀⠀⠀⢸⣿⣿⣿⣿⣿⣿⣿⣿⣿⣶⣤⣤⣤⣤⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠙⠿⣿⣿⣿⣷⠿⡿⠋⠀⠀⠀⠀⣄⢀⣀⠀⠀⠀⠀⠀⠙⢿⣷⣄⠀⢀⣾⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⠛⠀⠀⠀⠀⠀
|
||||||
|
⣀⣀⠀⠀⠀⠀⢀⣴⣿⣿⠛⠀⠀⢸⣧⡿⠀⠀⣸⠋⠋⠉⢻⡄⠀⠀⠀⠀⠀⠉⢁⣴⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⠟⠋⠁⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣷⣄⠀⠀⠈⠀⠀⠀⢻⣀⣀⣀⣀⡿⠀⠀⠀⠀⠀⠀⠀⢉⣭⣭⣽⣿⣿⣿⣿⣿⣿⣿⣿⣦⣄⠀⠀⠀⠀⠀⣀⣤⡄
|
||||||
|
⠘⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣦⣄⣀⠀⠀⠀⠉⠀⠀⠉⠀⠀⠀⠀⠀⢀⣀⣴⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⠃
|
||||||
|
⠀⠈⠻⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⢟⣿⣿⣿⣿⣶⣶⡶⣶⣶⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⠃⠀
|
||||||
|
⠀⠀⠀⠈⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⣿⢿⡸⣿⣿⣿⣿⣎⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⠋⠀⠀⠀
|
||||||
|
⠀⠀⠀⢸⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣯⣽⣿⣿⡟⠁⠀⢙⣿⣿⣿⢿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡏⠉⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⢸⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⣿⣿⣿⣿⣿⣦⣶⣿⣿⣿⣿⣿⡿⠿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⠇⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⢿⣿⣿⣿⣿⣿⣿⣿⡿⠁⠀⠘⣿⣿⡿⠟⠉⢿⣯⣿⣿⣿⠁⠀⠀⠈⠻⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⣿⡿⠃⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠙⠿⣿⣿⣿⣿⣿⡇⠀⠀⢸⡟⠋⠀⠀⠀⠀⠙⠛⠋⢸⠀⠀⠀⠀⠀⠘⣿⣿⣿⣿⣿⣿⣿⡿⠿⠛⠁⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀
|
||||||
|
⠀⠀⠀⠀⠀⠀⠀⠀⠉⠉⢻⣿⠀⠀⠀⢸⡇⠀⠀⠀⠀⠀⠀⠀⠀⢸⡆⠀⠀⠀⠀⠀⢻⣿⣿⣿⣿⠟⠋⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀⠀"
|
||||||
|
|
||||||
|
echo "以此纪念2.4.0版本"
|
||||||
|
CallProcess "$@"
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
Deepin-QQ.sh
|
||||||
@@ -0,0 +1 @@
|
|||||||
|
Deepin-WXWork.sh
|
||||||
42
packager-config/deepinwine/tools/spark_updater
Executable file
42
packager-config/deepinwine/tools/spark_updater
Executable file
@@ -0,0 +1,42 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
# 检查是否提供了-c和-s选项
|
||||||
|
if [[ ! "$*" =~ "-c" ]] || [[ ! "$*" =~ "-s" ]]; then
|
||||||
|
echo "用法: updater -c <目标目录> -s <源目录> [-v]"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 解析命令行参数
|
||||||
|
while getopts ":c:s:v" opt; do
|
||||||
|
case $opt in
|
||||||
|
c)
|
||||||
|
destination_dir=$OPTARG
|
||||||
|
;;
|
||||||
|
s)
|
||||||
|
source_dir=$OPTARG
|
||||||
|
;;
|
||||||
|
v)
|
||||||
|
verbose=true
|
||||||
|
;;
|
||||||
|
\?)
|
||||||
|
echo "无效选项: -$OPTARG" >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
:)
|
||||||
|
echo "选项 -$OPTARG 需要一个参数." >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
done
|
||||||
|
|
||||||
|
# 从源目录复制文件到目标目录
|
||||||
|
if [ "$verbose" = true ]; then
|
||||||
|
echo "正在从 $source_dir 复制文件到 $destination_dir"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# 使用cp命令覆盖同名文件
|
||||||
|
cp -rf "$source_dir"/* "$destination_dir"
|
||||||
|
|
||||||
|
echo "文件复制完成!"
|
||||||
|
exit 0
|
||||||
|
|
||||||
@@ -0,0 +1,3 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_UNPACKING="Preparing the following APP:"
|
||||||
|
TRANSHELL_CONTENT_SPARK_WINDOWS_COMPATIBILITY_TOOL="Spark Windows APP Compatibility Helper"
|
||||||
@@ -0,0 +1,4 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
TRANSHELL_CONTENT_UNPACKING="正在为您准备以下应用:"
|
||||||
|
TRANSHELL_CONTENT_SPARK_WINDOWS_COMPATIBILITY_TOOL="星火Windows应用兼容助手"
|
||||||
|
|
||||||
12
packager-config/postinst
Normal file
12
packager-config/postinst
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
PACKAGE_NAME="@@@DEB_PACKAGE_NAME@@@"
|
||||||
|
for username in $(ls /home)
|
||||||
|
do
|
||||||
|
echo /home/$username
|
||||||
|
if [ -d /home/$username/桌面 ]; then
|
||||||
|
cp /opt/apps/$PACKAGE_NAME/entries/applications/* /home/$username/桌面
|
||||||
|
fi
|
||||||
|
if [ -d /home/$username/Desktop ]; then
|
||||||
|
cp /opt/apps/$PACKAGE_NAME/entries/applications/* /home/$username/Desktop
|
||||||
|
fi
|
||||||
|
done
|
||||||
26
packager-config/postrm
Normal file
26
packager-config/postrm
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
if [ "$1" = "remove" ] || [ "$1" = "purge" ];then
|
||||||
|
|
||||||
|
echo "清理卸载残留"
|
||||||
|
CONTAINER_NAME="@@@BOTTLENAME@@@"
|
||||||
|
|
||||||
|
if [ -z $CONTAINER_NAME ];then
|
||||||
|
echo "W: 没有指定容器,跳过清理容器。请手动前往 ~/.deepinwine/ 下删除"
|
||||||
|
exit
|
||||||
|
fi
|
||||||
|
|
||||||
|
/opt/deepinwine/tools/kill.sh $CONTAINER_NAME
|
||||||
|
/opt/deepinwine/tools/spark_kill.sh $CONTAINER_NAME
|
||||||
|
###这里注意,如果没写CONTAINER_NAME,会把QQ杀了
|
||||||
|
|
||||||
|
for username in $(ls /home)
|
||||||
|
do
|
||||||
|
echo /home/$username
|
||||||
|
if [ -d /home/$username/.deepinwine/$CONTAINER_NAME ]
|
||||||
|
then
|
||||||
|
rm -rf /home/$username/.deepinwine/$CONTAINER_NAME
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
else
|
||||||
|
echo "非卸载,跳过清理"
|
||||||
|
fi
|
||||||
44
packager-config/run-old.sh
Normal file
44
packager-config/run-old.sh
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Copyright (C) 2016 Deepin, Inc.
|
||||||
|
#
|
||||||
|
# Author: Li LongYu <lilongyu@linuxdeepin.com>
|
||||||
|
# Peng Hao <penghao@linuxdeepin.com>
|
||||||
|
|
||||||
|
version_gt() { test "$(echo "$@" | tr " " "\\n" | sort -V | head -n 1)" != "$1"; }
|
||||||
|
|
||||||
|
BOTTLENAME="@@@BOTTLENAME@@@"
|
||||||
|
APPVER="@@@APPVER@@@"
|
||||||
|
EXEC_PATH="@@@EXEC_PATH@@@"
|
||||||
|
START_SHELL_PATH="/opt/deepinwine/tools/run_v4.sh"
|
||||||
|
export MIME_TYPE=""
|
||||||
|
export DEB_PACKAGE_NAME="@@@DEB_PACKAGE_NAME@@@"
|
||||||
|
export APPRUN_CMD="@@@APPRUN_CMD@@@"
|
||||||
|
DISABLE_ATTACH_FILE_DIALOG=""
|
||||||
|
EXPORT_ENVS=""
|
||||||
|
|
||||||
|
export SPECIFY_SHELL_DIR=`dirname $START_SHELL_PATH`
|
||||||
|
|
||||||
|
ARCHIVE_FILE_DIR="/opt/apps/$DEB_PACKAGE_NAME/files"
|
||||||
|
|
||||||
|
export WINEDLLPATH=/opt/$APPRUN_CMD/lib:/opt/$APPRUN_CMD/lib64
|
||||||
|
|
||||||
|
export WINEPREDLL="$ARCHIVE_FILE_DIR/dlls"
|
||||||
|
|
||||||
|
if [ -z "$DISABLE_ATTACH_FILE_DIALOG" ];then
|
||||||
|
export ATTACH_FILE_DIALOG=1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$EXPORT_ENVS" ];then
|
||||||
|
export $EXPORT_ENVS
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$EXEC_PATH" ];then
|
||||||
|
if [ -z "${EXEC_PATH##*.lnk*}" ];then
|
||||||
|
$START_SHELL_PATH $BOTTLENAME $APPVER "C:/windows/command/start.exe" "/Unix" "$EXEC_PATH" "$@"
|
||||||
|
else
|
||||||
|
$START_SHELL_PATH $BOTTLENAME $APPVER "$EXEC_PATH" "$@"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
$START_SHELL_PATH $BOTTLENAME $APPVER "uninstaller.exe" "$@"
|
||||||
|
fi
|
||||||
161
packager-config/run.sh
Normal file
161
packager-config/run.sh
Normal file
@@ -0,0 +1,161 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
# Copyright (C) 2016 Deepin, Inc.
|
||||||
|
#
|
||||||
|
# Author: Li LongYu <lilongyu@linuxdeepin.com>
|
||||||
|
# Peng Hao <penghao@linuxdeepin.com>
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Copyright (C) 2022 The Spark Project
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Modifier shenmo <shenmo@spark-app.store>
|
||||||
|
#
|
||||||
|
#
|
||||||
|
#
|
||||||
|
|
||||||
|
#######################函数段。下文调用的额外功能会在此处声明
|
||||||
|
|
||||||
|
version_gt() { test "$(echo "$@" | tr " " "
|
||||||
|
" | sort -V | head -n 1)" != "$1"; }
|
||||||
|
|
||||||
|
extract_archive()
|
||||||
|
{
|
||||||
|
archive=$1
|
||||||
|
version_file=$2
|
||||||
|
dest_dir=$3
|
||||||
|
if [ -f "$archive" ] && [ -n "$dest_dir" ] && [ "$dest_dir" != "." ];then
|
||||||
|
archive_version=`cat $version_file`
|
||||||
|
if [ -d "$dest_dir" ];then
|
||||||
|
if [ -f "$dest_dir/VERSION" ];then
|
||||||
|
dest_version=`cat $dest_dir/VERSION`
|
||||||
|
if version_gt "$archive_version" "$dest_version";then
|
||||||
|
7z x "$archive" -o/"$dest_dir" -aoa
|
||||||
|
echo "$archive_version" > "$dest_dir/VERSION"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
mkdir -p $dest_dir
|
||||||
|
7z x "$archive" -o/"$dest_dir" -aoa
|
||||||
|
echo "$archive_version" > "$dest_dir/VERSION"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
Get_Dist_Name()
|
||||||
|
{
|
||||||
|
if grep -Eqii "Deepin" /etc/issue || grep -Eq "Deepin" /etc/*-release; then
|
||||||
|
DISTRO='Deepin'
|
||||||
|
elif grep -Eqi "UnionTech" /etc/issue || grep -Eq "UnionTech" /etc/*-release; then
|
||||||
|
DISTRO='UniontechOS'
|
||||||
|
elif grep -Eqi "UOS" /etc/issue || grep -Eq "UOS" /etc/*-release; then
|
||||||
|
DISTRO='UniontechOS'
|
||||||
|
else
|
||||||
|
DISTRO='OtherOS'
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
####获得发行版名称
|
||||||
|
|
||||||
|
#########################预设值段
|
||||||
|
|
||||||
|
version_gt() { test "$(echo "$@" | tr " " "\n" | sort -V | head -n 1)" != "$1"; }
|
||||||
|
####用于比较版本?未实装
|
||||||
|
BOTTLENAME="@@@BOTTLENAME@@@"
|
||||||
|
APPVER="@@@APPVER@@@"
|
||||||
|
EXEC_PATH="@@@EXEC_PATH@@@"
|
||||||
|
##### 软件在wine中的启动路径
|
||||||
|
SHELL_DIR=$(dirname $(realpath $0))
|
||||||
|
START_SHELL_PATH="/opt/deepinwine/tools/run_v4.sh"
|
||||||
|
if [ -e "$SHELL_DIR/deepinwine/tools/spark_run_v4.sh" ] ;then
|
||||||
|
# 如果 helper 在 run.sh 相同目录的 deepinwine/tools/spark_run_v4.sh 则可以调用
|
||||||
|
START_SHELL_PATH="$SHELL_DIR/deepinwine/tools/spark_run_v4.sh"
|
||||||
|
fi
|
||||||
|
if [ -e "/opt/deepinwine/tools/run_v4.sh" ] ;then
|
||||||
|
START_SHELL_PATH="/opt/deepinwine/tools/run_v4.sh"
|
||||||
|
fi
|
||||||
|
if [ -e "/opt/deepinwine/tools/spark_run_v4.sh" ] ;then
|
||||||
|
START_SHELL_PATH="/opt/deepinwine/tools/spark_run_v4.sh"
|
||||||
|
fi
|
||||||
|
ENABLE_DOT_NET=""
|
||||||
|
####若使用spark-wine时需要用到.net,则请把ENABLE_DOT_NET设为true,同时在依赖中写spark-wine7-mono
|
||||||
|
#export BOX86_EMU_CMD="/opt/spark-box86/box86"
|
||||||
|
####仅在Arm且不可使用exagear时可用,作用是强制使用box86而不是deepin-box86.如果你想要这样做,请取消注释
|
||||||
|
export MIME_TYPE=""
|
||||||
|
|
||||||
|
export DEB_PACKAGE_NAME="@@@DEB_PACKAGE_NAME@@@"
|
||||||
|
####这里写包名才能在启动的时候正确找到files.7z,似乎也和杀残留进程有关
|
||||||
|
export APPRUN_CMD="@@@APPRUN_CMD@@@"
|
||||||
|
#####wine启动指令,建议
|
||||||
|
#EXPORT_ENVS="wine的动态链接库路径"
|
||||||
|
##例如我的wine应用是使用的dwine6的32位容器,那么我要填LD_LIBRARY_PATH=$LD_LIBRARY;/opt/deepin-wine6-stable/lib
|
||||||
|
## 如果用不到就不填,不要删除前面的注释用的#
|
||||||
|
|
||||||
|
export SPECIFY_SHELL_DIR=`dirname $START_SHELL_PATH`
|
||||||
|
|
||||||
|
ARCHIVE_FILE_DIR="/opt/apps/$DEB_PACKAGE_NAME/files"
|
||||||
|
|
||||||
|
export WINEDLLPATH=/opt/$APPRUN_CMD/lib:/opt/$APPRUN_CMD/lib64
|
||||||
|
|
||||||
|
export WINEPREDLL="$ARCHIVE_FILE_DIR/dlls"
|
||||||
|
|
||||||
|
DISABLE_ATTACH_FILE_DIALOG=""
|
||||||
|
##默认为空。若为1,则不使用系统自带的文件选择,而是使用wine的
|
||||||
|
##对于deepin/UOS,大部分的应用都不需要使用wine的,如果有需求(比如wine应用选择的限定种类文件系统的文管不支持)
|
||||||
|
##请填1。
|
||||||
|
##注意:因为非DDE的环境不确定,所以默认会在非Deepin/UOS发行版上禁用这个功能。如果你确认在适配的发行版上可以正常启动,请注释或者删除下面这段
|
||||||
|
|
||||||
|
##############<<<<<<<<<禁用文件选择工具开始
|
||||||
|
Get_Dist_Name
|
||||||
|
#此功能实现参见开头函数段
|
||||||
|
if [ "$DISTRO" != "Deepin" ] && [ "$DISTRO" != "UniontechOS" ];then
|
||||||
|
DISABLE_ATTACH_FILE_DIALOG="1"
|
||||||
|
echo "非deepin/UOS,默认关闭系统自带的文件选择工具,使用Wine的"
|
||||||
|
echo "如果你想改变这个行为,请到/opt/apps/$DEB_PACKAGE_NAME/files/$0处修改"
|
||||||
|
echo "To打包者:如果你要打开自带请注意在适配的发行版上进行测试"
|
||||||
|
echo "To用户:打包者没有打开这个功能,这证明启用这个功能可能造成运行问题。如果你要修改这个行为,请确保你有一定的动手能力"
|
||||||
|
fi
|
||||||
|
##############>>>>>>>>>禁用文件选择工具结束
|
||||||
|
|
||||||
|
##############<<<<<<<<<屏蔽mono和gecko安装器开始
|
||||||
|
##默认屏蔽mono和gecko安装器
|
||||||
|
if [ "$APPRUN_CMD" = "spark-wine7-devel" ] || [ "$APPRUN_CMD" = "spark-wine" ]|| [ "$APPRUN_CMD" = "spark-wine8" ] && [ -z "$ENABLE_DOT_NET" ];then
|
||||||
|
|
||||||
|
#export WINEDLLOVERRIDES="mscoree=d,mshtml=d,control.exe=d"
|
||||||
|
export WINEDLLOVERRIDES="control.exe=d"
|
||||||
|
#### "为了降低打包体积,默认关闭gecko和momo,如有需要,注释此行(仅对spark-wine7-devel有效)"
|
||||||
|
|
||||||
|
fi
|
||||||
|
##############>>>>>>>>>屏蔽mono和gecko安装器结束
|
||||||
|
|
||||||
|
##############<<<<<<<<<解压自行封装的 Wine(如果存在的话)
|
||||||
|
if [ -e "$ARCHIVE_FILE_DIR/wine_archive.7z" ]; then
|
||||||
|
WINE_BIN_DIR=`dirname $APPRUN_CMD`
|
||||||
|
WINE_DIR=`dirname $WINE_BIN_DIR`
|
||||||
|
extract_archive "$ARCHIVE_FILE_DIR/wine_archive.7z" "$ARCHIVE_FILE_DIR/wine_archive.md5sum" "$WINE_DIR"
|
||||||
|
fi
|
||||||
|
##############>>>>>>>>>
|
||||||
|
|
||||||
|
#########################执行段
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if [ -z "$DISABLE_ATTACH_FILE_DIALOG" ];then
|
||||||
|
export ATTACH_FILE_DIALOG=1
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$EXPORT_ENVS" ];then
|
||||||
|
export $EXPORT_ENVS
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -n "$EXEC_PATH" ];then
|
||||||
|
if [ -z "${EXEC_PATH##*.lnk*}" ];then
|
||||||
|
$START_SHELL_PATH $BOTTLENAME $APPVER "C:/windows/command/start.exe" "/Unix" "$EXEC_PATH" "$@"
|
||||||
|
else
|
||||||
|
$START_SHELL_PATH $BOTTLENAME $APPVER "C:/windows/command/start.exe" "/Unix" "$EXEC_PATH" "$@"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
$START_SHELL_PATH $BOTTLENAME $APPVER "uninstaller.exe" "$@"
|
||||||
|
fi
|
||||||
17
packager-config/uos-info.json
Normal file
17
packager-config/uos-info.json
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"appid": "@@@DEB_PACKAGE_NAME@@@",
|
||||||
|
"name": "@@@APP_NAME@@@",
|
||||||
|
"version": "@@@APPVER@@@",
|
||||||
|
"arch": ["@@@ARCH@@@"],
|
||||||
|
"permissions": {
|
||||||
|
"autostart": false,
|
||||||
|
"notification": false,
|
||||||
|
"trayicon": true,
|
||||||
|
"clipboard": true,
|
||||||
|
"account": false,
|
||||||
|
"bluetooth": false,
|
||||||
|
"camera": true,
|
||||||
|
"audio_record": true,
|
||||||
|
"installed_apps": false
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -8,6 +8,9 @@ if (TMPDIR == None):
|
|||||||
TMPDIR = ""
|
TMPDIR = ""
|
||||||
PIDFILE = TMPDIR + '/tmp/deepin-wine-runner.pid'
|
PIDFILE = TMPDIR + '/tmp/deepin-wine-runner.pid'
|
||||||
|
|
||||||
|
if (not os.path.exists(TMPDIR + "/tmp")):
|
||||||
|
os.makedirs(TMPDIR + "/tmp")
|
||||||
|
|
||||||
#程序结束时清理pid
|
#程序结束时清理pid
|
||||||
@atexit.register
|
@atexit.register
|
||||||
def remove_pid():
|
def remove_pid():
|
||||||
|
|||||||
0
vkd3d-proton.7z
Normal file → Executable file
0
vkd3d-proton.7z
Normal file → Executable file
38
welcome.py
Executable file
38
welcome.py
Executable file
@@ -0,0 +1,38 @@
|
|||||||
|
# 库的引用
|
||||||
|
import PyQt5.QtWidgets as QtWidgets
|
||||||
|
import PyQt5.QtGui as QtGui
|
||||||
|
import PyQt5.QtCore as QtCore
|
||||||
|
|
||||||
|
import sys
|
||||||
|
|
||||||
|
# 创建界面
|
||||||
|
class WinWelcome(QtWidgets.QWidget):
|
||||||
|
def __init__(self):
|
||||||
|
super().__init__()
|
||||||
|
self.initUI()
|
||||||
|
|
||||||
|
def initUI(self):
|
||||||
|
self.mainLayout = QtWidgets.QVBoxLayout()
|
||||||
|
self.mainLayout.setContentsMargins(0, 0, 0, 0)
|
||||||
|
self.setLayout(self.mainLayout)
|
||||||
|
|
||||||
|
# 标签1
|
||||||
|
self.lab1 = QtWidgets.QLabel("<h3>欢迎使用Wine运行器!</h3>")
|
||||||
|
self.mainLayout.addWidget(self.lab1)
|
||||||
|
|
||||||
|
# 文本栏
|
||||||
|
self.txt = QtWidgets.QTextBrowser()
|
||||||
|
self.introduction = "Wine运行器\n用于运行一般的Windows程序及安装包(exe、msi文件)\n\nWine打包器\n将特定的Windows程序打包为deb格式,以便存储或分享\n\n虚拟机\n可用于运行无法通过Wine运行的程序,或在龙架构上运行x86程序\n请注意,虚拟机可解决兼容性问题,但性能开销较大"
|
||||||
|
self.txt.setText(self.introduction)
|
||||||
|
self.mainLayout.addWidget(self.txt)
|
||||||
|
|
||||||
|
# 标签2
|
||||||
|
self.lab2 = QtWidgets.QLabel("请根据您的需求,在左侧打开相应页面")
|
||||||
|
self.mainLayout.addWidget(self.lab2)
|
||||||
|
|
||||||
|
# 测试界面
|
||||||
|
if __name__ == "__main__":
|
||||||
|
app = QtWidgets.QApplication(sys.argv)
|
||||||
|
winWelcome = WinWelcome()
|
||||||
|
winWelcome.show()
|
||||||
|
sys.exit(app.exec())
|
||||||
0
wineautobuild-action-7z-aarch64-daily.sh
Normal file → Executable file
0
wineautobuild-action-7z-aarch64-daily.sh
Normal file → Executable file
0
wineautobuild-action-7z-aarch64.sh
Normal file → Executable file
0
wineautobuild-action-7z-aarch64.sh
Normal file → Executable file
0
wineautobuild-action-7z-daily.sh
Normal file → Executable file
0
wineautobuild-action-7z-daily.sh
Normal file → Executable file
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user