something

This commit is contained in:
恍兮惚兮 2024-08-30 03:09:49 +08:00
parent eb5ed97719
commit 739fa24944
41 changed files with 248 additions and 147 deletions

View File

@ -4,9 +4,7 @@ from qtsymbols import *
from traceback import print_exc from traceback import print_exc
from myutils.config import ( from myutils.config import (
globalconfig, globalconfig,
_TR,
savehook_new_list, savehook_new_list,
uid2gamepath,
findgameuidofpath, findgameuidofpath,
savehook_new_data, savehook_new_data,
static_data, static_data,

View File

@ -13,8 +13,8 @@ from gui.specialwidget import lazyscrollflow
from myutils.config import ( from myutils.config import (
savehook_new_data, savehook_new_data,
savegametaged, savegametaged,
uid2gamepath,
_TR, _TR,
get_launchpath,
globalconfig, globalconfig,
) )
from gui.usefulwidget import ( from gui.usefulwidget import (
@ -182,7 +182,7 @@ class dialog_savedgame_new(QWidget):
notshow = False notshow = False
for tag, _type, _ in tags: for tag, _type, _ in tags:
if _type == tagitem.TYPE_EXISTS: if _type == tagitem.TYPE_EXISTS:
if os.path.exists(uid2gamepath[k]) == False: if os.path.exists(get_launchpath(k)) == False:
notshow = True notshow = True
break break
elif _type == tagitem.TYPE_DEVELOPER: elif _type == tagitem.TYPE_DEVELOPER:
@ -229,7 +229,7 @@ class dialog_savedgame_new(QWidget):
othersetting = LAction(("其他设置")) othersetting = LAction(("其他设置"))
if self.currentfocusuid: if self.currentfocusuid:
exists = os.path.exists(uid2gamepath[self.currentfocusuid]) exists = os.path.exists(get_launchpath(self.currentfocusuid))
if exists: if exists:
menu.addAction(startgame) menu.addAction(startgame)
if exists: if exists:
@ -491,7 +491,7 @@ class dialog_savedgame_new(QWidget):
_able1 = b and ( _able1 = b and (
(not exists) (not exists)
or (self.currentfocusuid) or (self.currentfocusuid)
and (os.path.exists(uid2gamepath[self.currentfocusuid])) and (os.path.exists(get_launchpath(self.currentfocusuid)))
) )
_btn.setEnabled(_able1) _btn.setEnabled(_able1)

View File

@ -12,12 +12,12 @@ from myutils.config import (
savehook_new_data, savehook_new_data,
savegametaged, savegametaged,
uid2gamepath, uid2gamepath,
get_launchpath,
_TR, _TR,
savehook_new_list, savehook_new_list,
globalconfig, globalconfig,
) )
from gui.usefulwidget import ( from gui.usefulwidget import (
yuitsu_switch,
getIconButton, getIconButton,
FocusCombo, FocusCombo,
getsimplecombobox, getsimplecombobox,
@ -114,17 +114,14 @@ class ItemWidget(QWidget):
layout.addWidget(self._lb) layout.addWidget(self._lb)
self.setLayout(layout) self.setLayout(layout)
self.gameuid = gameuid self.gameuid = gameuid
exists = os.path.exists(get_launchpath(gameuid))
c = globalconfig["dialog_savegame_layout"][ c = globalconfig["dialog_savegame_layout"][
("onfilenoexistscolor1", "backcolor1")[ ("onfilenoexistscolor1", "backcolor1")[exists]
os.path.exists(uid2gamepath[gameuid])
]
] ]
c = str2rgba( c = str2rgba(
c, c,
globalconfig["dialog_savegame_layout"][ globalconfig["dialog_savegame_layout"][
("transparentnotexits", "transparent")[ ("transparentnotexits", "transparent")[exists]
os.path.exists(uid2gamepath[gameuid])
]
], ],
) )
self.maskshowfileexists.setStyleSheet(f"background-color:{c};") self.maskshowfileexists.setStyleSheet(f"background-color:{c};")
@ -345,7 +342,7 @@ class TagWidget(QWidget):
def opendirforgameuid(gameuid): def opendirforgameuid(gameuid):
f = uid2gamepath[gameuid] f = get_launchpath(gameuid)
f = os.path.dirname(f) f = os.path.dirname(f)
if os.path.exists(f) and os.path.isdir(f): if os.path.exists(f) and os.path.isdir(f):
os.startfile(f) os.startfile(f)
@ -354,7 +351,7 @@ def opendirforgameuid(gameuid):
@threader @threader
def startgame(gameuid): def startgame(gameuid):
try: try:
game = uid2gamepath[gameuid] game = get_launchpath(gameuid)
if os.path.exists(game): if os.path.exists(game):
mode = savehook_new_data[gameuid]["onloadautochangemode2"] mode = savehook_new_data[gameuid]["onloadautochangemode2"]
if mode > 0: if mode > 0:
@ -438,7 +435,7 @@ def getpixfunction(kk, small=False):
def startgamecheck(self, reflist, gameuid): def startgamecheck(self, reflist, gameuid):
if not gameuid: if not gameuid:
return return
if not os.path.exists(uid2gamepath[gameuid]): if not os.path.exists(get_launchpath(gameuid)):
return return
if globalconfig["startgamenototop"] == False: if globalconfig["startgamenototop"] == False:
idx = reflist.index(gameuid) idx = reflist.index(gameuid)

View File

@ -1,7 +1,7 @@
from PyQt5.QtWidgets import QWidget from PyQt5.QtWidgets import QWidget
from qtsymbols import * from qtsymbols import *
import functools, threading import functools, threading
from myutils.config import savehook_new_list, savehook_new_data, uid2gamepath from myutils.config import savehook_new_list, savehook_new_data, get_launchpath
from myutils.hwnd import getExeIcon from myutils.hwnd import getExeIcon
from gui.usefulwidget import ( from gui.usefulwidget import (
TableViewW, TableViewW,
@ -131,7 +131,7 @@ class dialog_savedgame_legacy(QWidget):
"", "",
"", "",
functools.partial(opendirforgameuid, k), functools.partial(opendirforgameuid, k),
qicon=getExeIcon(uid2gamepath[k], cache=True), qicon=getExeIcon(get_launchpath(k), cache=True),
) )
def callback_leuse(self, k, use): def callback_leuse(self, k, use):

View File

@ -8,6 +8,7 @@ import gobject
from myutils.config import ( from myutils.config import (
savehook_new_data, savehook_new_data,
uid2gamepath, uid2gamepath,
get_launchpath,
_TR, _TR,
postprocessconfig, postprocessconfig,
globalconfig, globalconfig,
@ -51,7 +52,14 @@ from gui.usefulwidget import (
getspinbox, getspinbox,
listediterline, listediterline,
) )
from gui.dynalang import LFormLayout, LPushButton, LStandardItemModel, LAction, LLabel, LDialog from gui.dynalang import (
LFormLayout,
LPushButton,
LStandardItemModel,
LAction,
LLabel,
LDialog,
)
from gui.dialog_savedgame_common import tagitem, TagWidget from gui.dialog_savedgame_common import tagitem, TagWidget
@ -155,7 +163,7 @@ class browserdialog(saveposwindow):
def __init__(self, parent, gameuid=None) -> None: def __init__(self, parent, gameuid=None) -> None:
super().__init__(parent, poslist=globalconfig["browserwidget"]) super().__init__(parent, poslist=globalconfig["browserwidget"])
if gameuid: if gameuid:
self.setWindowIcon(getExeIcon(uid2gamepath[gameuid], cache=True)) self.setWindowIcon(getExeIcon(get_launchpath(gameuid), cache=True))
self.browser = auto_select_webview(self) self.browser = auto_select_webview(self)
self.tagswidget = TagWidget(self) self.tagswidget = TagWidget(self)
@ -274,20 +282,12 @@ def maybehavebutton(self, gameuid, post):
class dialog_setting_game_internal(QWidget): class dialog_setting_game_internal(QWidget):
def selectexe(self): def selectexe(self, res):
originpath = uid2gamepath[self.gameuid]
f = QFileDialog.getOpenFileName(directory=originpath)
res = f[0]
if res == "":
return
# 修改路径允许路径重复
# 添加路径实际上也允许重复,只不过会去重。
res = os.path.normpath(res) res = os.path.normpath(res)
uid2gamepath[self.gameuid] = res uid2gamepath[self.gameuid] = res
_icon = getExeIcon(res, cache=True) _icon = getExeIcon(get_launchpath(self.gameuid), cache=True)
self.setWindowIcon(_icon) self.setWindowIcon(_icon)
self.editpath.setText(res)
def __init__(self, parent, gameuid) -> None: def __init__(self, parent, gameuid) -> None:
super().__init__(parent) super().__init__(parent)
@ -295,14 +295,16 @@ class dialog_setting_game_internal(QWidget):
formLayout = LFormLayout() formLayout = LFormLayout()
self.setLayout(vbox) self.setLayout(vbox)
self.gameuid = gameuid self.gameuid = gameuid
self.editpath = QLineEdit(uid2gamepath[gameuid])
self.editpath.setReadOnly(True)
formLayout.addRow( formLayout.addRow(
"路径", "路径",
getboxlayout( getboxlayout(
[ [
self.editpath, getsimplepatheditor(
getIconButton(functools.partial(self.selectexe), icon="fa.gear"), uid2gamepath[gameuid],
callback=self.selectexe,
clearable=False,
icons=("fa.gear",),
),
getIconButton( getIconButton(
lambda: browserdialog( lambda: browserdialog(
gobject.baseobject.commonstylebase, gameuid gobject.baseobject.commonstylebase, gameuid
@ -476,6 +478,15 @@ class dialog_setting_game_internal(QWidget):
layout.addWidget(w) layout.addWidget(w)
do() do()
def selectexe_lauch(self, p):
if p:
p = os.path.normpath(p)
savehook_new_data[self.gameuid]["launchpath"] = p
_icon = getExeIcon(get_launchpath(self.gameuid), cache=True)
self.setWindowIcon(_icon)
def starttab(self, formLayout: LFormLayout, gameuid): def starttab(self, formLayout: LFormLayout, gameuid):
box = QGroupBox() box = QGroupBox()
settinglayout = LFormLayout() settinglayout = LFormLayout()
@ -490,14 +501,23 @@ class dialog_setting_game_internal(QWidget):
box.show() box.show()
__launch_method = getsimplecombobox( __launch_method = getsimplecombobox(
[_.name for _ in getgamecamptools(uid2gamepath[gameuid])], [_.name for _ in getgamecamptools(get_launchpath(gameuid))],
savehook_new_data[gameuid], savehook_new_data[gameuid],
"launch_method", "launch_method",
internal=[_.id for _ in getgamecamptools(uid2gamepath[gameuid])], internal=[_.id for _ in getgamecamptools(get_launchpath(gameuid))],
callback=functools.partial( callback=functools.partial(
__, box, settinglayout, savehook_new_data[gameuid] __, box, settinglayout, savehook_new_data[gameuid]
), ),
) )
formLayout.addRow(
"启动程序",
getsimplepatheditor(
get_launchpath(gameuid),
callback=self.selectexe_lauch,
icons=("fa.gear", "fa.window-close-o"),
clearset=uid2gamepath[gameuid],
),
)
formLayout.addRow("启动方式", __launch_method) formLayout.addRow("启动方式", __launch_method)
formLayout.addRow(box) formLayout.addRow(box)
@ -779,7 +799,7 @@ class dialog_setting_game_internal(QWidget):
False, False,
filt, filt,
functools.partial(selectimg, gameuid, key), functools.partial(selectimg, gameuid, key),
True, icons=("fa.folder-open", "fa.window-close-o"),
), ),
) )
@ -1114,7 +1134,6 @@ class dialog_setting_game_internal(QWidget):
) )
def calculate_centered_rect(original_rect: QRect, size: QSize) -> QRect: def calculate_centered_rect(original_rect: QRect, size: QSize) -> QRect:
original_center = original_rect.center() original_center = original_rect.center()
new_left = original_center.x() - size.width() // 2 new_left = original_center.x() - size.width() // 2
@ -1122,6 +1141,7 @@ def calculate_centered_rect(original_rect: QRect, size: QSize) -> QRect:
new_rect = QRect(new_left, new_top, size.width(), size.height()) new_rect = QRect(new_left, new_top, size.width(), size.height())
return new_rect return new_rect
@Singleton_close @Singleton_close
class dialog_setting_game(LDialog): class dialog_setting_game(LDialog):
@ -1131,7 +1151,7 @@ class dialog_setting_game(LDialog):
self.setWindowTitle(savehook_new_data[gameuid]["title"]) self.setWindowTitle(savehook_new_data[gameuid]["title"])
self.setWindowIcon(getExeIcon(uid2gamepath[gameuid], cache=True)) self.setWindowIcon(getExeIcon(get_launchpath(gameuid), cache=True))
_ = dialog_setting_game_internal(self, gameuid) _ = dialog_setting_game_internal(self, gameuid)
_.methodtab.setCurrentIndex(setindexhook) _.methodtab.setCurrentIndex(setindexhook)
_.setMinimumSize(QSize(600, 500)) _.setMinimumSize(QSize(600, 500))

View File

@ -8,7 +8,7 @@ from myutils.config import (
savehook_new_list, savehook_new_list,
savehook_new_data, savehook_new_data,
savegametaged, savegametaged,
uid2gamepath, get_launchpath,
extradatas, extradatas,
globalconfig, globalconfig,
) )
@ -96,16 +96,14 @@ class clickitem(QWidget):
self.lay.setContentsMargins(0, 0, 0, 0) self.lay.setContentsMargins(0, 0, 0, 0)
self.maskshowfileexists = QLabel(self) self.maskshowfileexists = QLabel(self)
exits = os.path.exists(get_launchpath(uid))
c = globalconfig["dialog_savegame_layout"][ c = globalconfig["dialog_savegame_layout"][
("onfilenoexistscolor1", "backcolor1")[os.path.exists(uid2gamepath[uid])] ("onfilenoexistscolor1", "backcolor1")[exits]
] ]
c = str2rgba( c = str2rgba(
c, c,
globalconfig["dialog_savegame_layout"][ globalconfig["dialog_savegame_layout"][
("transparentnotexits", "transparent")[ ("transparentnotexits", "transparent")[exits]
os.path.exists(uid2gamepath[uid])
]
], ],
) )
self.maskshowfileexists.setStyleSheet(f"background-color:{c};") self.maskshowfileexists.setStyleSheet(f"background-color:{c};")
@ -121,9 +119,7 @@ class clickitem(QWidget):
_.setFixedSize(QSize(size, size)) _.setFixedSize(QSize(size, size))
_.setScaledContents(True) _.setScaledContents(True)
_.setStyleSheet("background-color: rgba(255,255,255, 0);") _.setStyleSheet("background-color: rgba(255,255,255, 0);")
icon = getpixfunction( icon = getpixfunction(uid, small=True)
uid, small=True
) # getExeIcon(uid2gamepath[uid], icon=False, cache=True)
icon.setDevicePixelRatio(self.devicePixelRatioF()) icon.setDevicePixelRatio(self.devicePixelRatioF())
_.setPixmap(icon) _.setPixmap(icon)
self.lay.addWidget(_) self.lay.addWidget(_)
@ -229,19 +225,17 @@ class MyQListWidget(QListWidget):
end = self.indexAt(self.viewport().rect().bottomRight()).row() end = self.indexAt(self.viewport().rect().bottomRight()).row()
if start < 0: if start < 0:
return return
if end < 0:
end = start
with self.lock: with self.lock:
model = self.model() model = self.model()
if end < 0:
end = model.rowCount()
for row in range(start, end + 1): for row in range(start, end + 1):
index = model.index(row, 0) index = model.index(row, 0)
if not index.data(ImageRequestedRole): if not index.data(ImageRequestedRole):
self.model().setData(index, True, ImageRequestedRole) self.model().setData(index, True, ImageRequestedRole)
image = getcachedimage(index.data(PathRole), True) image = getcachedimage(index.data(PathRole), True)
if image is None: if image is None:
self.blockSignals(True)
self.takeItem(index.row()) self.takeItem(index.row())
self.blockSignals(False)
else: else:
self.item(index.row()).setIcon(QIcon(image)) self.item(index.row()).setIcon(QIcon(image))
except: except:
@ -670,7 +664,7 @@ class dialog_savedgame_v3(QWidget):
_able1 = b and ( _able1 = b and (
(not exists) (not exists)
or (self.currentfocusuid) or (self.currentfocusuid)
and (os.path.exists(uid2gamepath[self.currentfocusuid])) and (os.path.exists(get_launchpath(self.currentfocusuid)))
) )
_btn.setEnabled(_able1) _btn.setEnabled(_able1)
if self.currentfocusuid: if self.currentfocusuid:
@ -712,7 +706,7 @@ class dialog_savedgame_v3(QWidget):
menu.addAction(addlist) menu.addAction(addlist)
else: else:
exists = os.path.exists(uid2gamepath[self.currentfocusuid]) exists = os.path.exists(get_launchpath(self.currentfocusuid))
if exists: if exists:
menu.addAction(startgame) menu.addAction(startgame)
menu.addAction(delgame) menu.addAction(delgame)
@ -862,9 +856,8 @@ class dialog_savedgame_v3(QWidget):
self.stack.insertw(i, group0) self.stack.insertw(i, group0)
rowreal = 0 rowreal = 0
for row, k in enumerate(lst): for row, k in enumerate(lst):
if globalconfig["hide_not_exists"] and not os.path.exists( if globalconfig["hide_not_exists"]:
uid2gamepath[k] if not os.path.exists(get_launchpath(k)):
):
continue continue
self.reallist[tagid].append(k) self.reallist[tagid].append(k)
if opened and isfirst and (rowreal == 0): if opened and isfirst and (rowreal == 0):

View File

@ -3,7 +3,7 @@ import sqlite3, os, json, functools
from traceback import print_exc from traceback import print_exc
from myutils.config import globalconfig, _TR from myutils.config import globalconfig, _TR
from myutils.utils import autosql from myutils.utils import autosql
from gui.usefulwidget import getQMessageBox, LFocusCombo, getsimplepatheditor from gui.usefulwidget import getQMessageBox, LFocusCombo
from gui.dynalang import LFormLayout, LPushButton, LDialog from gui.dynalang import LFormLayout, LPushButton, LDialog
from textsource.texthook import splitembedlines from textsource.texthook import splitembedlines
from collections import Counter from collections import Counter

View File

@ -6,7 +6,7 @@ from myutils.config import (
globalconfig, globalconfig,
_TR, _TR,
savehook_new_data, savehook_new_data,
uid2gamepath, get_launchpath,
savehook_new_list, savehook_new_list,
static_data, static_data,
) )
@ -224,7 +224,7 @@ def exportchspatch(self):
gameuid = selectgameuid(self) gameuid = selectgameuid(self)
if gameuid is None: if gameuid is None:
return return
exe = uid2gamepath[gameuid] exe = get_launchpath(gameuid)
if exe.lower().endswith(".exe") == False: if exe.lower().endswith(".exe") == False:
f = QFileDialog.getOpenFileName( f = QFileDialog.getOpenFileName(
self, caption=_TR("选择EXE文件"), filter="*.exe" self, caption=_TR("选择EXE文件"), filter="*.exe"

View File

@ -2035,11 +2035,13 @@ def getsimplepatheditor(
isdir=False, isdir=False,
filter1="*.*", filter1="*.*",
callback=None, callback=None,
useiconbutton=False, icons=None,
reflist=None, reflist=None,
name=None, name=None,
header=None, header=None,
dirorfile=False, dirorfile=False,
clearable=True,
clearset=""
): ):
lay = QHBoxLayout() lay = QHBoxLayout()
lay.setContentsMargins(0, 0, 0, 0) lay.setContentsMargins(0, 0, 0, 0)
@ -2055,11 +2057,13 @@ def getsimplepatheditor(
else: else:
e = QLineEdit(text) e = QLineEdit(text)
e.setReadOnly(True) e.setReadOnly(True)
if useiconbutton: if icons:
bu = getIconButton(icon="fa.folder-open") bu = getIconButton(icon=icons[0])
clear = getIconButton(icon="fa.window-close-o") if clearable:
clear = getIconButton(icon=icons[1])
else: else:
bu = LPushButton("选择" + ("文件夹" if isdir else "文件")) bu = LPushButton("选择" + ("文件夹" if isdir else "文件"))
if clearable:
clear = LPushButton("清除") clear = LPushButton("清除")
bu.clicked.connect( bu.clicked.connect(
functools.partial( functools.partial(
@ -2072,14 +2076,15 @@ def getsimplepatheditor(
callback, callback,
) )
) )
def __(_cb, _e):
_cb("")
_e.setText("")
clear.clicked.connect(functools.partial(__, callback, e))
lay.addWidget(e) lay.addWidget(e)
lay.addWidget(bu) lay.addWidget(bu)
if clearable:
def __(_cb, _e, t):
_cb("")
_e.setText(t)
clear.clicked.connect(functools.partial(__, callback, e, clearset))
lay.addWidget(clear) lay.addWidget(clear)
return lay return lay

View File

@ -4,7 +4,6 @@ from myutils.utils import initanewitem, gamdidchangedtask
import functools, time, json, gobject import functools, time, json, gobject
from qtsymbols import * from qtsymbols import *
from metadata.abstract import common from metadata.abstract import common
from gui.usefulwidget import getlineedit
from gui.dialog_savedgame import getreflist, getalistname from gui.dialog_savedgame import getreflist, getalistname
from myutils.wrapper import Singleton_close, threader from myutils.wrapper import Singleton_close, threader
from gui.dynalang import LPushButton from gui.dynalang import LPushButton
@ -121,9 +120,11 @@ class bgmsettings(QDialog):
getalistname(self, callback) getalistname(self, callback)
infosig = pyqtSignal(str) infosig = pyqtSignal(str)
showhide = pyqtSignal(bool)
@threader @threader
def checkvalid(self, k): def checkvalid(self, k):
self.showhide.emit(False)
self.lbinfo.setText("") self.lbinfo.setText("")
t = time.time() t = time.time()
self.tm = t self.tm = t
@ -146,6 +147,17 @@ class bgmsettings(QDialog):
expires = response.get("expires", 0) expires = response.get("expires", 0)
if expires: if expires:
info = "" info = ""
try:
response1 = requests.get(
f"https://api.bgm.tv/v0/me",
params={"access_token": k},
headers=self.headers,
proxies=self._ref.proxy,
)
print(response1.json())
info += "用户名: " + response1.json()["nickname"] + "\n"
except:
pass
try: try:
create = ( create = (
json.loads(response["info"]) json.loads(response["info"])
@ -160,10 +172,12 @@ class bgmsettings(QDialog):
info += "有效期至: " + time.strftime( info += "有效期至: " + time.strftime(
"%Y-%m-%d %H:%M:%S", time.localtime(expires) "%Y-%m-%d %H:%M:%S", time.localtime(expires)
) )
self.showhide.emit(True)
else: else:
info = " ".join( info = " ".join(
(response.get("error", ""), response.get("error_description", "")) (response.get("error", ""), response.get("error_description", ""))
) )
self.showhide.emit(False)
self.lbinfo.setText(info) self.lbinfo.setText(info)
def __oauth(self): def __oauth(self):
@ -223,7 +237,13 @@ class bgmsettings(QDialog):
s = QLineEdit() s = QLineEdit()
self.lbinfo = QLabel() self.lbinfo = QLabel()
s.textChanged.connect(self.checkvalid) s.textChanged.connect(self.checkvalid)
s.setText(_ref.config["access-token"]) fl2 = QFormLayout()
fl2.setContentsMargins(0, 0, 0, 0)
ww = QWidget()
ww.setLayout(fl2)
ww.hide()
self.fl2 = ww
self.showhide.connect(self.fl2.setVisible)
self._token = s self._token = s
vbox.addLayout(hbox) vbox.addLayout(hbox)
hbox.addWidget(s) hbox.addWidget(s)
@ -232,22 +252,23 @@ class bgmsettings(QDialog):
oauth.clicked.connect(self.__oauth) oauth.clicked.connect(self.__oauth)
vbox.addWidget(self.lbinfo) vbox.addWidget(self.lbinfo)
fl.addRow("access-token", vbox) fl.addRow("access-token", vbox)
btn = LPushButton("上传游戏") btn = LPushButton("上传游戏")
btn.clicked.connect( btn.clicked.connect(
functools.partial(self.singleupload_existsoverride, gameuid) functools.partial(self.singleupload_existsoverride, gameuid)
) )
fl.addRow(btn) fl2.addRow(btn)
btn = LPushButton("上传游戏列表") btn = LPushButton("上传游戏列表")
btn.clicked.connect( btn.clicked.connect(
functools.partial(self.__getalistname, self.getalistname_upload) functools.partial(self.__getalistname, self.getalistname_upload)
) )
fl.addRow(btn) fl2.addRow(btn)
btn = LPushButton("获取游戏列表") btn = LPushButton("获取游戏列表")
btn.clicked.connect( btn.clicked.connect(
functools.partial(self.__getalistname, self.getalistname_download) functools.partial(self.__getalistname, self.getalistname_download)
) )
fl.addRow(btn) fl2.addRow(btn)
fl.addRow(ww)
s.setText(_ref.config["access-token"])
self.show() self.show()

View File

@ -6,13 +6,12 @@ import time
from qtsymbols import * from qtsymbols import *
from gui.inputdialog import autoinitdialog from gui.inputdialog import autoinitdialog
from metadata.abstract import common from metadata.abstract import common
from gui.usefulwidget import getlineedit
from gui.dialog_savedgame import getreflist, getalistname from gui.dialog_savedgame import getreflist, getalistname
from myutils.wrapper import Singleton_close from myutils.wrapper import Singleton_close, threader
from gui.dynalang import LPushButton from gui.dynalang import LPushButton
def saferequestvndb(proxy, method, url, json=None, headers=None): def saferequestvndb(proxy, method, url, json=None, headers=None, failnone=True):
print(method, url, json) print(method, url, json)
resp = requests.request( resp = requests.request(
method, method,
@ -35,11 +34,14 @@ def saferequestvndb(proxy, method, url, json=None, headers=None):
except: except:
print(resp.status_code) print(resp.status_code)
print(resp.text) print(resp.text)
if failnone:
return None return None
else:
return resp.text
def safegetvndbjson(proxy, url, json): def safegetvndbjson(proxy, url, json=None, headers=None):
return saferequestvndb(proxy, "POST", url, json) return saferequestvndb(proxy, "POST", url, json, headers)
def gettitlefromjs(js): def gettitlefromjs(js):
@ -279,28 +281,69 @@ class vndbsettings(QDialog):
def __getalistname(self, callback, _): def __getalistname(self, callback, _):
getalistname(self, callback) getalistname(self, callback)
showhide = pyqtSignal(bool)
@threader
def checkvalid(self, k):
self.showhide.emit(False)
self.lbinfo.setText("")
t = time.time()
self.tm = t
if k != self._ref.config["Token"]:
self._ref.config["Token"] = k
response = saferequestvndb(
self._ref.proxy, "GET", "authinfo", headers=self.headers, failnone=False
)
if t != self.tm:
return
print(response)
if isinstance(response, dict) and response.get("username"):
info = "username: " + response.get("username")
self.showhide.emit(True)
else:
info = response
self.showhide.emit(False)
self.lbinfo.setText(info)
def __init__(self, parent, _ref: common, gameuid: str) -> None: def __init__(self, parent, _ref: common, gameuid: str) -> None:
super().__init__(parent, Qt.WindowType.WindowCloseButtonHint) super().__init__(parent, Qt.WindowType.WindowCloseButtonHint)
self.tm = None
self._ref = _ref self._ref = _ref
self.resize(QSize(800, 10)) self.resize(QSize(800, 10))
self.setWindowTitle(self._ref.config_all["name"]) self.setWindowTitle(self._ref.config_all["name"])
fl = QFormLayout(self) fl = QFormLayout(self)
fl.addRow("Token", getlineedit(_ref.config, "Token")) vbox = QVBoxLayout()
s = QLineEdit()
self.lbinfo = QLabel()
s.textChanged.connect(self.checkvalid)
fl2 = QFormLayout()
fl2.setContentsMargins(0, 0, 0, 0)
ww = QWidget()
ww.setLayout(fl2)
ww.hide()
self.fl2 = ww
self.showhide.connect(self.fl2.setVisible)
self._token = s
vbox.addWidget(s)
vbox.addWidget(self.lbinfo)
fl.addRow("Token", vbox)
btn = LPushButton("上传游戏") btn = LPushButton("上传游戏")
btn.clicked.connect( btn.clicked.connect(
functools.partial(self.singleupload_existsoverride, gameuid) functools.partial(self.singleupload_existsoverride, gameuid)
) )
fl.addRow(btn) fl2.addRow(btn)
btn = LPushButton("上传游戏列表") btn = LPushButton("上传游戏列表")
btn.clicked.connect( btn.clicked.connect(
functools.partial(self.__getalistname, self.getalistname_upload) functools.partial(self.__getalistname, self.getalistname_upload)
) )
fl.addRow(btn) fl2.addRow(btn)
btn = LPushButton("获取游戏列表") btn = LPushButton("获取游戏列表")
btn.clicked.connect( btn.clicked.connect(
functools.partial(self.__getalistname, self.getalistname_download) functools.partial(self.__getalistname, self.getalistname_download)
) )
fl.addRow(btn) fl2.addRow(btn)
fl.addRow(ww)
s.setText(_ref.config["Token"])
self.show() self.show()

View File

@ -118,6 +118,7 @@ ocrsetting = tryreadconfig("ocrsetting.json")
def getdefaultsavehook(title=None): def getdefaultsavehook(title=None):
default = { default = {
"gamepath": "", # 不要直接访问要通过uid2gamepath来间接访问 "gamepath": "", # 不要直接访问要通过uid2gamepath来间接访问
#"launchpath": "",
"hooksetting_follow_default": True, "hooksetting_follow_default": True,
"hooksetting_private": {}, # 显示时再加载缺省用global中的键 "hooksetting_private": {}, # 显示时再加载缺省用global中的键
"textproc_follow_default": True, "textproc_follow_default": True,
@ -336,6 +337,11 @@ class __uid2gamepath:
uid2gamepath = __uid2gamepath() uid2gamepath = __uid2gamepath()
def get_launchpath(uid):
launch = savehook_new_data[uid].get("launchpath", "")
if not launch:
launch = uid2gamepath[uid]
return launch
def findgameuidofpath(gamepath, findall=False): def findgameuidofpath(gamepath, findall=False):
collect = [] collect = []

View File

@ -1,6 +1,6 @@
import windows, os, winreg, winsharedutils, re, functools import windows, os, winsharedutils, re, functools
from qtsymbols import * from qtsymbols import *
from myutils.config import savehook_new_data, uid2gamepath, globalconfig from myutils.config import savehook_new_data, get_launchpath, globalconfig
from gui.usefulwidget import ( from gui.usefulwidget import (
getlineedit, getlineedit,
getsimplecombobox, getsimplecombobox,
@ -12,7 +12,6 @@ from gui.usefulwidget import (
getsimplepatheditor, getsimplepatheditor,
clearlayout, clearlayout,
) )
from traceback import print_exc
from gui.dynalang import LFormLayout from gui.dynalang import LFormLayout
@ -529,9 +528,9 @@ def fundlauncher(_id):
def localeswitchedrun(gameuid): def localeswitchedrun(gameuid):
config = savehook_new_data[gameuid] config = savehook_new_data[gameuid]
launch_method = config.get("launch_method", None) launch_method = config.get("launch_method", None)
gameexe = uid2gamepath[gameuid] gameexe = get_launchpath(gameuid)
tools = getgamecamptools(gameexe) tools = getgamecamptools(gameexe)
ids = [_.id for _ in getgamecamptools(uid2gamepath[gameuid])] ids = [_.id for _ in tools]
if launch_method not in ids: if launch_method not in ids:
index = 0 index = 0
else: else:

View File

@ -3,12 +3,7 @@ import time
import os, threading import os, threading
from qtsymbols import * from qtsymbols import *
from traceback import print_exc from traceback import print_exc
from myutils.config import ( from myutils.config import findgameuidofpath, savehook_new_data
uid2gamepath,
findgameuidofpath,
savehook_new_list,
savehook_new_data,
)
from myutils.hwnd import getpidexe from myutils.hwnd import getpidexe
import windows import windows
import gobject import gobject

View File

@ -20,7 +20,6 @@ from myutils.config import (
import threading, winreg import threading, winreg
import re, heapq, winsharedutils import re, heapq, winsharedutils
from myutils.wrapper import tryprint, threader from myutils.wrapper import tryprint, threader
from myutils.subproc import subproc_w
def checkisusingwine(): def checkisusingwine():
@ -195,8 +194,9 @@ def dispatchsearchfordata(gameuid, target, vid):
targetmod[target].dispatchsearchfordata(gameuid, vid) targetmod[target].dispatchsearchfordata(gameuid, vid)
def trysearchforid_1(gameuid, searchargs: list): def trysearchforid_1(gameuid, searchargs: list, target=None):
infoid = None infoid = None
if target is None:
primitivtemetaorigin = globalconfig["primitivtemetaorigin"] primitivtemetaorigin = globalconfig["primitivtemetaorigin"]
__ = [primitivtemetaorigin] __ = [primitivtemetaorigin]
for k in targetmod: for k in targetmod:
@ -205,7 +205,8 @@ def trysearchforid_1(gameuid, searchargs: list):
if not globalconfig["metadata"][k]["auto"]: if not globalconfig["metadata"][k]["auto"]:
continue continue
__.append(k) __.append(k)
else:
__ = [target]
for key in __: for key in __:
vid = None vid = None
for arg in searchargs: for arg in searchargs:
@ -232,12 +233,15 @@ def trysearchforid_1(gameuid, searchargs: list):
dispatchsearchfordata(gameuid, key, vid) dispatchsearchfordata(gameuid, key, vid)
def trysearchforid(gameuid, searchargs: list): def trysearchforid(*argc):
threading.Thread(target=trysearchforid_1, args=(gameuid, searchargs)).start() threading.Thread(target=trysearchforid_1, args=argc).start()
def gamdidchangedtask(key, idname, gameuid): def gamdidchangedtask(key, idname, gameuid):
vid = savehook_new_data[gameuid].get(idname, "") vid = savehook_new_data[gameuid].get(idname, "")
if not vid:
trysearchforid(gameuid, [savehook_new_data[gameuid]["title"]], key)
else:
dispatchsearchfordata(gameuid, key, vid) dispatchsearchfordata(gameuid, key, vid)

View File

@ -1,4 +1,4 @@
from myutils.config import globalconfig, savehook_new_data, uid2gamepath from myutils.config import globalconfig, savehook_new_data, get_launchpath
from myutils.utils import postusewhich from myutils.utils import postusewhich
from gui.inputdialog import postconfigdialog_ from gui.inputdialog import postconfigdialog_
import gobject import gobject
@ -24,7 +24,7 @@ class Process:
"专有名词翻译_sakura_gpt_词典_-_" + savehook_new_data[gameuid]["title"], "专有名词翻译_sakura_gpt_词典_-_" + savehook_new_data[gameuid]["title"],
["原文", "翻译", "注释"], ["原文", "翻译", "注释"],
dictkeys=["src", "dst", "info"], dictkeys=["src", "dst", "info"],
).setWindowIcon(getExeIcon(uid2gamepath[gameuid], cache=True)) ).setWindowIcon(getExeIcon(get_launchpath(gameuid), cache=True))
def process_before(self, japanese): def process_before(self, japanese):

View File

@ -5,7 +5,7 @@ from gui.usefulwidget import threebuttons, TableViewW
from myutils.wrapper import Singleton_close from myutils.wrapper import Singleton_close
from myutils.utils import postusewhich from myutils.utils import postusewhich
from gui.dynalang import LDialog, LPushButton, LStandardItemModel from gui.dynalang import LDialog, LPushButton, LStandardItemModel
from myutils.config import uid2gamepath from myutils.config import get_launchpath
from myutils.hwnd import getExeIcon from myutils.hwnd import getExeIcon
@ -114,7 +114,7 @@ class Process:
parent_window, parent_window,
savehook_new_data[gameuid]["noundictconfig"], savehook_new_data[gameuid]["noundictconfig"],
"专有名词翻译_占位符_-_" + savehook_new_data[gameuid]["title"], "专有名词翻译_占位符_-_" + savehook_new_data[gameuid]["title"],
).setWindowIcon(getExeIcon(uid2gamepath[gameuid], cache=True)) ).setWindowIcon(getExeIcon(get_launchpath(gameuid), cache=True))
@staticmethod @staticmethod
def get_setting_window(parent_window): def get_setting_window(parent_window):

View File

@ -2,7 +2,7 @@ from myutils.config import transerrorfixdictconfig, savehook_new_data
from myutils.utils import parsemayberegexreplace, postusewhich from myutils.utils import parsemayberegexreplace, postusewhich
from gui.inputdialog import noundictconfigdialog1 from gui.inputdialog import noundictconfigdialog1
import gobject import gobject
from myutils.config import uid2gamepath from myutils.config import get_launchpath
from myutils.hwnd import getExeIcon from myutils.hwnd import getExeIcon
@ -24,7 +24,7 @@ class Process:
savehook_new_data[gameuid]["transerrorfix"], savehook_new_data[gameuid]["transerrorfix"],
"翻译结果修正_-_" + savehook_new_data[gameuid]["title"], "翻译结果修正_-_" + savehook_new_data[gameuid]["title"],
["正则",'转义', "翻译", "替换"], ["正则",'转义', "翻译", "替换"],
).setWindowIcon(getExeIcon(uid2gamepath[gameuid], cache=True)) ).setWindowIcon(getExeIcon(get_launchpath(gameuid), cache=True))
def process_after(self, res, mp1): def process_after(self, res, mp1):
res = parsemayberegexreplace(self.usewhich(), res) res = parsemayberegexreplace(self.usewhich(), res)

View File

@ -1,7 +1,7 @@
from myutils.config import globalconfig, savehook_new_data, uid2gamepath from myutils.config import globalconfig, savehook_new_data, get_launchpath
from myutils.utils import postusewhich, parsemayberegexreplace from myutils.utils import postusewhich, parsemayberegexreplace
from gui.inputdialog import noundictconfigdialog1 from gui.inputdialog import noundictconfigdialog1
import gobject, json, functools import gobject
from myutils.hwnd import getExeIcon from myutils.hwnd import getExeIcon
@ -26,7 +26,7 @@ class Process:
savehook_new_data[gameuid]["namemap2"], savehook_new_data[gameuid]["namemap2"],
"专有名词翻译_直接替换_-_" + savehook_new_data[gameuid]["title"], "专有名词翻译_直接替换_-_" + savehook_new_data[gameuid]["title"],
["正则", "转义", "原文", "翻译"], ["正则", "转义", "原文", "翻译"],
).setWindowIcon(getExeIcon(uid2gamepath[gameuid], cache=True)) ).setWindowIcon(getExeIcon(get_launchpath(gameuid), cache=True))
@property @property
def using_X(self): def using_X(self):

View File

@ -1943,7 +1943,7 @@
"type": "api", "type": "api",
"use": false, "use": false,
"color": "blue", "color": "blue",
"name": "Azure Openai", "name": "Azure",
"is_gpt_like": true "is_gpt_like": true
}, },
"cohere": { "cohere": {

View File

@ -846,5 +846,6 @@
"单词": "كلمة .", "单词": "كلمة .",
"成功添加后关闭窗口": "إغلاق النافذة بعد إضافة ناجحة", "成功添加后关闭窗口": "إغلاق النافذة بعد إضافة ناجحة",
"绑定窗口": "ملزمة نافذة", "绑定窗口": "ملزمة نافذة",
"(点击自己取消)": "( انقر على نفسك لإلغاء )" "(点击自己取消)": "( انقر على نفسك لإلغاء )",
"启动程序": "بدء البرنامج"
} }

View File

@ -846,5 +846,6 @@
"单词": "單詞", "单词": "單詞",
"成功添加后关闭窗口": "成功添加後關閉窗口", "成功添加后关闭窗口": "成功添加後關閉窗口",
"绑定窗口": "綁定視窗", "绑定窗口": "綁定視窗",
"(点击自己取消)": "(點擊自己取消)" "(点击自己取消)": "(點擊自己取消)",
"启动程序": "啟動程式"
} }

View File

@ -846,5 +846,6 @@
"单词": "slovo", "单词": "slovo",
"成功添加后关闭窗口": "Zavřít okno po úspěšném přidání", "成功添加后关闭窗口": "Zavřít okno po úspěšném přidání",
"绑定窗口": "Vázat okno", "绑定窗口": "Vázat okno",
"(点击自己取消)": "(Kliknutím zrušíte sami)" "(点击自己取消)": "(Kliknutím zrušíte sami)",
"启动程序": "Spustit program"
} }

View File

@ -846,5 +846,6 @@
"单词": "Wort", "单词": "Wort",
"成功添加后关闭窗口": "Fenster nach erfolgreichem Hinzufügen schließen", "成功添加后关闭窗口": "Fenster nach erfolgreichem Hinzufügen schließen",
"绑定窗口": "Fenster binden", "绑定窗口": "Fenster binden",
"(点击自己取消)": "(Klicken Sie, um selbst abzubrechen)" "(点击自己取消)": "(Klicken Sie, um selbst abzubrechen)",
"启动程序": "Programm starten"
} }

View File

@ -846,5 +846,6 @@
"单词": "word", "单词": "word",
"成功添加后关闭窗口": "Close the window after successful addition", "成功添加后关闭窗口": "Close the window after successful addition",
"绑定窗口": "Bind Window", "绑定窗口": "Bind Window",
"(点击自己取消)": "(Click to cancel by yourself)" "(点击自己取消)": "(Click to cancel by yourself)",
"启动程序": "Start the program"
} }

View File

@ -846,5 +846,6 @@
"单词": "Palabras", "单词": "Palabras",
"成功添加后关闭窗口": "Cerrar la ventana después de agregar con éxito", "成功添加后关闭窗口": "Cerrar la ventana después de agregar con éxito",
"绑定窗口": "Ventana vinculada", "绑定窗口": "Ventana vinculada",
"(点击自己取消)": "(haga clic para cancelar por sí mismo)" "(点击自己取消)": "(haga clic para cancelar por sí mismo)",
"启动程序": "Iniciar el programa"
} }

View File

@ -846,5 +846,6 @@
"单词": "Mots", "单词": "Mots",
"成功添加后关闭窗口": "Fermer la fenêtre après un ajout réussi", "成功添加后关闭窗口": "Fermer la fenêtre après un ajout réussi",
"绑定窗口": "Fenêtre de liaison", "绑定窗口": "Fenêtre de liaison",
"(点击自己取消)": "(cliquez vous - même pour annuler)" "(点击自己取消)": "(cliquez vous - même pour annuler)",
"启动程序": "Lancer le programme"
} }

View File

@ -846,5 +846,6 @@
"单词": "parola", "单词": "parola",
"成功添加后关闭窗口": "Chiudere la finestra dopo l'aggiunta riuscita", "成功添加后关闭窗口": "Chiudere la finestra dopo l'aggiunta riuscita",
"绑定窗口": "Associa finestra", "绑定窗口": "Associa finestra",
"(点击自己取消)": "(Clicca per annullare da solo)" "(点击自己取消)": "(Clicca per annullare da solo)",
"启动程序": "Avvia il programma"
} }

View File

@ -846,5 +846,6 @@
"单词": "単語", "单词": "単語",
"成功添加后关闭窗口": "追加に成功したらウィンドウを閉じる", "成功添加后关闭窗口": "追加に成功したらウィンドウを閉じる",
"绑定窗口": "「バインド」ウィンドウ", "绑定窗口": "「バインド」ウィンドウ",
"(点击自己取消)": "(自分でキャンセルするをクリック)" "(点击自己取消)": "(自分でキャンセルするをクリック)",
"启动程序": "スタートアッププログラム"
} }

View File

@ -846,5 +846,6 @@
"单词": "단어", "单词": "단어",
"成功添加后关闭窗口": "성공적으로 추가한 후 창 닫기", "成功添加后关闭窗口": "성공적으로 추가한 후 창 닫기",
"绑定窗口": "바인딩 창", "绑定窗口": "바인딩 창",
"(点击自己取消)": "(자체 취소 클릭)" "(点击自己取消)": "(자체 취소 클릭)",
"启动程序": "프로그램 시작"
} }

View File

@ -846,5 +846,6 @@
"单词": "woord", "单词": "woord",
"成功添加后关闭窗口": "Sluit het venster na succesvolle toevoeging", "成功添加后关闭窗口": "Sluit het venster na succesvolle toevoeging",
"绑定窗口": "Venster binden", "绑定窗口": "Venster binden",
"(点击自己取消)": "(Klik om zelf te annuleren)" "(点击自己取消)": "(Klik om zelf te annuleren)",
"启动程序": "Start het programma"
} }

View File

@ -846,5 +846,6 @@
"单词": "słowo", "单词": "słowo",
"成功添加后关闭窗口": "Zamknij okno po pomyślnym dodaniu", "成功添加后关闭窗口": "Zamknij okno po pomyślnym dodaniu",
"绑定窗口": "Wiąż okno", "绑定窗口": "Wiąż okno",
"(点击自己取消)": "(Kliknij, aby anulować samodzielnie)" "(点击自己取消)": "(Kliknij, aby anulować samodzielnie)",
"启动程序": "Uruchom program"
} }

View File

@ -846,5 +846,6 @@
"单词": "palavra", "单词": "palavra",
"成功添加后关闭窗口": "Fechar a janela após a adição bem sucedida", "成功添加后关闭窗口": "Fechar a janela após a adição bem sucedida",
"绑定窗口": "Janela Vincular", "绑定窗口": "Janela Vincular",
"(点击自己取消)": "(Clique para cancelar por si mesmo)" "(点击自己取消)": "(Clique para cancelar por si mesmo)",
"启动程序": "Iniciar o programa"
} }

View File

@ -846,5 +846,6 @@
"单词": "Слова", "单词": "Слова",
"成功添加后关闭窗口": "Закрыть окно после успешного добавления", "成功添加后关闭窗口": "Закрыть окно после успешного добавления",
"绑定窗口": "Связанное окно", "绑定窗口": "Связанное окно",
"(点击自己取消)": "(Нажмите сами, чтобы отменить)" "(点击自己取消)": "(Нажмите сами, чтобы отменить)",
"启动程序": "Запуск программы"
} }

View File

@ -846,5 +846,6 @@
"单词": "ord", "单词": "ord",
"成功添加后关闭窗口": "Stäng fönstret efter lyckat tillägg", "成功添加后关闭窗口": "Stäng fönstret efter lyckat tillägg",
"绑定窗口": "Bind fönster", "绑定窗口": "Bind fönster",
"(点击自己取消)": "(Klicka för att avbryta själv)" "(点击自己取消)": "(Klicka för att avbryta själv)",
"启动程序": "Starta programmet"
} }

View File

@ -846,5 +846,6 @@
"单词": "คำศัพท์", "单词": "คำศัพท์",
"成功添加后关闭窗口": "ปิดหน้าต่างหลังจากเพิ่มเรียบร้อยแล้ว", "成功添加后关闭窗口": "ปิดหน้าต่างหลังจากเพิ่มเรียบร้อยแล้ว",
"绑定窗口": "หน้าต่างที่ถูกผูกไว้", "绑定窗口": "หน้าต่างที่ถูกผูกไว้",
"(点击自己取消)": "(คลิกเพื่อยกเลิกด้วยตัวเอง)" "(点击自己取消)": "(คลิกเพื่อยกเลิกด้วยตัวเอง)",
"启动程序": "เริ่มโปรแกรม"
} }

View File

@ -846,5 +846,6 @@
"单词": "kelime", "单词": "kelime",
"成功添加后关闭窗口": "Başarılı eklendikten sonra pencereyi kapat", "成功添加后关闭窗口": "Başarılı eklendikten sonra pencereyi kapat",
"绑定窗口": "Bağlam Penceresi", "绑定窗口": "Bağlam Penceresi",
"(点击自己取消)": "(Kendin iptal etmek için tıklayın)" "(点击自己取消)": "(Kendin iptal etmek için tıklayın)",
"启动程序": "Programı başlat"
} }

View File

@ -846,5 +846,6 @@
"单词": "слово", "单词": "слово",
"成功添加后关闭窗口": "Закрити вікно після успішного додавання", "成功添加后关闭窗口": "Закрити вікно після успішного додавання",
"绑定窗口": "В єднати вікно", "绑定窗口": "В єднати вікно",
"(点击自己取消)": "(Натисніть, щоб скасувати самостійно)" "(点击自己取消)": "(Натисніть, щоб скасувати самостійно)",
"启动程序": "Запустити програму"
} }

View File

@ -846,5 +846,6 @@
"单词": "Từ", "单词": "Từ",
"成功添加后关闭窗口": "Đóng cửa sổ sau khi thêm thành công", "成功添加后关闭窗口": "Đóng cửa sổ sau khi thêm thành công",
"绑定窗口": "Cửa sổ bị ràng buộc", "绑定窗口": "Cửa sổ bị ràng buộc",
"(点击自己取消)": "(Click vào tự hủy)" "(点击自己取消)": "(Click vào tự hủy)",
"启动程序": "Khởi chạy chương trình"
} }

View File

@ -846,5 +846,6 @@
"单词": "", "单词": "",
"成功添加后关闭窗口": "", "成功添加后关闭窗口": "",
"绑定窗口": "", "绑定窗口": "",
"(点击自己取消)": "" "(点击自己取消)": "",
"启动程序": ""
} }

View File

@ -28,8 +28,8 @@ set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${CMAKE_SOURCE_DIR}/version)
include(generate_product_version) include(generate_product_version)
set(VERSION_MAJOR 5) set(VERSION_MAJOR 5)
set(VERSION_MINOR 31) set(VERSION_MINOR 32)
set(VERSION_PATCH 5) set(VERSION_PATCH 0)
add_library(pch pch.cpp) add_library(pch pch.cpp)
target_precompile_headers(pch PUBLIC pch.h) target_precompile_headers(pch PUBLIC pch.h)