issues/509 ……

This commit is contained in:
恍兮惚兮 2024-01-30 15:14:57 +08:00
parent dee058f3d0
commit 79db38e5f6
3 changed files with 42 additions and 20 deletions

View File

@ -41,6 +41,7 @@ class MAINUI() :
def __init__(self,app) -> None: def __init__(self,app) -> None:
super().__init__() super().__init__()
self.lasttranslatorindex=0 self.lasttranslatorindex=0
self.usefultranslators=0
self.app=app self.app=app
self.translators={} self.translators={}
self.cishus={} self.cishus={}
@ -167,7 +168,7 @@ class MAINUI() :
return return
if text=='' or len(text)>100000: if text=='' or len(text)>100000:
if embedcallback: if embedcallback:
embedcallback('zhs', text) embedcallback('')
return return
try: try:
@ -187,7 +188,7 @@ class MAINUI() :
if text=='' or (is_auto_run and (text==self.currenttext or len(text)>(max(globalconfig['maxoriginlength'],globalconfig['maxlength'])))): if text=='' or (is_auto_run and (text==self.currenttext or len(text)>(max(globalconfig['maxoriginlength'],globalconfig['maxlength'])))):
if embedcallback: if embedcallback:
embedcallback('zhs', text) embedcallback('')
return return
@ -237,6 +238,7 @@ class MAINUI() :
skip=is_auto_run and (len(text_solved)<globalconfig['minlength'] or len(text_solved)>globalconfig['maxlength'] ) skip=is_auto_run and (len(text_solved)<globalconfig['minlength'] or len(text_solved)>globalconfig['maxlength'] )
self.premtalready=['premt'] self.premtalready=['premt']
self.usefultranslators=len(self.translators)
if 'premt' in self.translators: if 'premt' in self.translators:
try: try:
res=self.translators['premt'].translate(text_solved) res=self.translators['premt'].translate(text_solved)
@ -270,16 +272,26 @@ class MAINUI() :
break break
def GetTranslationCallback(self,onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res,embedcallback): def GetTranslationCallback(self,onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res,embedcallback):
if embedcallback is None and currentsignature!=self.currentsignature: self.usefultranslators-=1
return if embedcallback is None and currentsignature!=self.currentsignature:return
if currentsignature==self.currentsignature: embedtrans=self.GetTranslationCallback_(onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res)
if type(res)==str:
if res.startswith('<msg_translator>'):
if embedtrans is None and self.usefultranslators==0:
embedtrans=''
if embedcallback and embedtrans is not None:
embedcallback(embedtrans)
def GetTranslationCallback_(self,onlytrans,classname,currentsignature,optimization_params,_showrawfunction,_showrawfunction_sig,contentraw,res):
if type(res)==str:
if res.startswith('<msg_translator>'):
if currentsignature==self.currentsignature:
self.translation_ui.displaystatus.emit(globalconfig['fanyi'][classname]['name']+' '+res[len('<msg_translator>'):],'red',onlytrans,False) self.translation_ui.displaystatus.emit(globalconfig['fanyi'][classname]['name']+' '+res[len('<msg_translator>'):],'red',onlytrans,False)
return return
res=self.solveaftertrans(res,optimization_params) res=self.solveaftertrans(res,optimization_params)
@ -296,15 +308,15 @@ class MAINUI() :
if currentsignature==self.currentsignature and globalconfig['showfanyi']: if currentsignature==self.currentsignature and globalconfig['showfanyi']:
self.translation_ui.displayres.emit(globalconfig['fanyi'][classname]['name'],globalconfig['fanyi'][classname]['color'],res,onlytrans) self.translation_ui.displayres.emit(globalconfig['fanyi'][classname]['name'],globalconfig['fanyi'][classname]['color'],res,onlytrans)
if embedcallback:
if globalconfig['embedded']['as_fast_as_posible'] or classname==list(globalconfig['fanyi'])[globalconfig['embedded']['translator']]:
embedcallback('zhs', kanjitrans(zhconv.convert(res,'zh-tw')) if globalconfig['embedded']['trans_kanji'] else res)
try: try:
self.textsource.sqlqueueput((contentraw,classname,res)) self.textsource.sqlqueueput((contentraw,classname,res))
except:pass except:pass
if globalconfig['embedded']['as_fast_as_posible'] or classname==list(globalconfig['fanyi'])[globalconfig['embedded']['translator']]:
return (kanjitrans(zhconv.convert(res,'zh-tw')) if globalconfig['embedded']['trans_kanji'] else res)
@threader @threader
def autoreadcheckname(self): def autoreadcheckname(self):
try: try:

View File

@ -205,17 +205,27 @@ class Sessionbase:
headers,dataptr,datalen=self._parsedata(data,headers,json) headers,dataptr,datalen=self._parsedata(data,headers,json)
proxy= proxies.get(scheme,None) if proxies else None proxy= proxies.get(scheme,None) if proxies else None
if timeout: if timeout:
timeout = int(timeout * 1000) # convert to milliseconds if isinstance(timeout,(float,int)):
timeout = int(timeout * 1000) # convert to milliseconds
else:
try:
timeout=max(int(_ * 1000) for _ in timeout)
except:
print("Error invalid timeout",timeout)
timeout=None
_= self.request_impl(method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout) _= self.request_impl(method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout)
if _.status_code==301: if allow_redirects and (_.status_code==301 or _.status_code==302):
location=_.headers['Location'] location=_.headers['Location']
if location.startswith('/'):#vndb if location.startswith('/'):#vndb
url=url=scheme+'://'+server+location url=url=scheme+'://'+server+location
param=location param=location
_= self.request_impl(method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify) elif location.startswith('http'):#https://api.github.com/repos/XXX/XXX/zipball
scheme,server,port,param,url=self._parseurl(location,None)
else: else:
raise Exception('301 redirect '+location) raise Exception('redirect {}: {}'.format(_.status_code,location))
_= self.request_impl(method,scheme,server,port,param,url,headers,cookies,dataptr,datalen,proxy,stream,verify,timeout)
return _ return _
def get(self, url, **kwargs): def get(self, url, **kwargs):
return self.request("GET", url, **kwargs) return self.request("GET", url, **kwargs)

View File

@ -215,7 +215,7 @@ class texthook(basetext ):
if self.checkisusingembed(tp.addr,tp.ctx,tp.ctx2): if self.checkisusingembed(tp.addr,tp.ctx,tp.ctx2):
self.newline.put((text,False, functools.partial(self.embedcallback,text),True)) self.newline.put((text,False, functools.partial(self.embedcallback,text),True))
def embedcallback(self,text,_unused,trans): def embedcallback(self,text,trans):
for pid in self.connectedpids: for pid in self.connectedpids:
self.Luna_embedcallback(pid,text,trans) self.Luna_embedcallback(pid,text,trans)