mirror of
https://github.com/HIllya51/LunaTranslator.git
synced 2025-01-15 00:43:59 +08:00
fix
This commit is contained in:
parent
220b8be23c
commit
27b6f0e1ba
@ -14,9 +14,6 @@ if __name__ == "__main__":
|
|||||||
|
|
||||||
sys.path.append("./")
|
sys.path.append("./")
|
||||||
sys.path.append("./userconfig")
|
sys.path.append("./userconfig")
|
||||||
sys.path.insert(
|
|
||||||
0, "./LunaTranslator/network/" + ["winhttp", "libcurl"][globalconfig["network"]]
|
|
||||||
)
|
|
||||||
|
|
||||||
import gobject
|
import gobject
|
||||||
|
|
||||||
|
@ -178,12 +178,7 @@ def setTab_proxy_lazy(self, basel):
|
|||||||
"网络请求",
|
"网络请求",
|
||||||
(
|
(
|
||||||
D_getsimplecombobox(
|
D_getsimplecombobox(
|
||||||
["winhttp", "libcurl"],
|
["winhttp", "libcurl"], globalconfig, "network"
|
||||||
globalconfig,
|
|
||||||
"network",
|
|
||||||
callback=functools.partial(
|
|
||||||
gobject.baseobject.showneedrestart, "网络请求"
|
|
||||||
),
|
|
||||||
),
|
),
|
||||||
5,
|
5,
|
||||||
),
|
),
|
||||||
|
@ -4,7 +4,7 @@ from threading import Thread
|
|||||||
from myutils.commonbase import proxysession
|
from myutils.commonbase import proxysession
|
||||||
from myutils.config import globalconfig, savehook_new_data
|
from myutils.config import globalconfig, savehook_new_data
|
||||||
from traceback import print_exc
|
from traceback import print_exc
|
||||||
from network.requests_common import NetWorkException
|
from requests import NetWorkException
|
||||||
|
|
||||||
|
|
||||||
class common:
|
class common:
|
||||||
|
@ -8,7 +8,7 @@ from myutils.config import (
|
|||||||
from myutils.utils import initanewitem, gamdidchangedtask
|
from myutils.utils import initanewitem, gamdidchangedtask
|
||||||
import functools
|
import functools
|
||||||
import time
|
import time
|
||||||
from network.requests_common import NetWorkException
|
from requests import NetWorkException
|
||||||
from qtsymbols import *
|
from qtsymbols import *
|
||||||
from gui.usefulwidget import getlineedit
|
from gui.usefulwidget import getlineedit
|
||||||
from gui.dialog_savedgame import getreflist, getalistname
|
from gui.dialog_savedgame import getreflist, getalistname
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import gobject, os
|
import gobject, os
|
||||||
from network.requests_common import NetWorkException
|
from requests import NetWorkException
|
||||||
from ctypes import (
|
from ctypes import (
|
||||||
CDLL,
|
CDLL,
|
||||||
c_void_p,
|
c_void_p,
|
||||||
@ -42,94 +42,94 @@ class curl_ws_frame(Structure):
|
|||||||
|
|
||||||
|
|
||||||
class CURLcode(c_int):
|
class CURLcode(c_int):
|
||||||
CURLE_OK = 0
|
OK = 0
|
||||||
CURLE_UNSUPPORTED_PROTOCOL = 1
|
UNSUPPORTED_PROTOCOL = 1
|
||||||
CURLE_FAILED_INIT = 2
|
FAILED_INIT = 2
|
||||||
CURLE_URL_MALFORMAT = 3
|
URL_MALFORMAT = 3
|
||||||
CURLE_COULDNT_RESOLVE_PROXY = 5
|
COULDNT_RESOLVE_PROXY = 5
|
||||||
CURLE_COULDNT_RESOLVE_HOST = 6
|
COULDNT_RESOLVE_HOST = 6
|
||||||
CURLE_COULDNT_CONNECT = 7
|
COULDNT_CONNECT = 7
|
||||||
CURLE_FTP_WEIRD_SERVER_REPLY = 8
|
FTP_WEIRD_SERVER_REPLY = 8
|
||||||
CURLE_REMOTE_ACCESS_DENIED = 9
|
REMOTE_ACCESS_DENIED = 9
|
||||||
CURLE_FTP_WEIRD_PASS_REPLY = 11
|
FTP_WEIRD_PASS_REPLY = 11
|
||||||
CURLE_FTP_WEIRD_PASV_REPLY = 13
|
FTP_WEIRD_PASV_REPLY = 13
|
||||||
CURLE_FTP_WEIRD_227_FORMAT = 14
|
FTP_WEIRD_227_FORMAT = 14
|
||||||
CURLE_FTP_CANT_GET_HOST = 15
|
FTP_CANT_GET_HOST = 15
|
||||||
CURLE_FTP_COULDNT_SET_TYPE = 17
|
FTP_COULDNT_SET_TYPE = 17
|
||||||
CURLE_PARTIAL_FILE = 18
|
PARTIAL_FILE = 18
|
||||||
CURLE_FTP_COULDNT_RETR_FILE = 19
|
FTP_COULDNT_RETR_FILE = 19
|
||||||
CURLE_QUOTE_ERROR = 21
|
QUOTE_ERROR = 21
|
||||||
CURLE_HTTP_RETURNED_ERROR = 22
|
HTTP_RETURNED_ERROR = 22
|
||||||
CURLE_WRITE_ERROR = 23
|
WRITE_ERROR = 23
|
||||||
CURLE_UPLOAD_FAILED = 25
|
UPLOAD_FAILED = 25
|
||||||
CURLE_READ_ERROR = 26
|
READ_ERROR = 26
|
||||||
CURLE_OUT_OF_MEMORY = 27
|
OUT_OF_MEMORY = 27
|
||||||
CURLE_OPERATION_TIMEDOUT = 28
|
OPERATION_TIMEDOUT = 28
|
||||||
CURLE_FTP_PORT_FAILED = 30
|
FTP_PORT_FAILED = 30
|
||||||
CURLE_FTP_COULDNT_USE_REST = 31
|
FTP_COULDNT_USE_REST = 31
|
||||||
CURLE_RANGE_ERROR = 33
|
RANGE_ERROR = 33
|
||||||
CURLE_HTTP_POST_ERROR = 34
|
HTTP_POST_ERROR = 34
|
||||||
CURLE_SSL_CONNECT_ERROR = 35
|
SSL_CONNECT_ERROR = 35
|
||||||
CURLE_BAD_DOWNLOAD_RESUME = 36
|
BAD_DOWNLOAD_RESUME = 36
|
||||||
CURLE_FILE_COULDNT_READ_FILE = 37
|
FILE_COULDNT_READ_FILE = 37
|
||||||
CURLE_LDAP_CANNOT_BIND = 38
|
LDAP_CANNOT_BIND = 38
|
||||||
CURLE_LDAP_SEARCH_FAILED = 39
|
LDAP_SEARCH_FAILED = 39
|
||||||
CURLE_FUNCTION_NOT_FOUND = 41
|
FUNCTION_NOT_FOUND = 41
|
||||||
CURLE_ABORTED_BY_CALLBACK = 42
|
ABORTED_BY_CALLBACK = 42
|
||||||
CURLE_BAD_FUNCTION_ARGUMENT = 43
|
BAD_FUNCTION_ARGUMENT = 43
|
||||||
CURLE_INTERFACE_FAILED = 45
|
INTERFACE_FAILED = 45
|
||||||
CURLE_TOO_MANY_REDIRECTS = 47
|
TOO_MANY_REDIRECTS = 47
|
||||||
CURLE_UNKNOWN_TELNET_OPTION = 48
|
UNKNOWN_TELNET_OPTION = 48
|
||||||
CURLE_TELNET_OPTION_SYNTAX = 49
|
TELNET_OPTION_SYNTAX = 49
|
||||||
CURLE_PEER_FAILED_VERIFICATION = 51
|
PEER_FAILED_VERIFICATION = 51
|
||||||
CURLE_GOT_NOTHING = 52
|
GOT_NOTHING = 52
|
||||||
CURLE_SSL_ENGINE_NOTFOUND = 53
|
SSL_ENGINE_NOTFOUND = 53
|
||||||
CURLE_SSL_ENGINE_SETFAILED = 54
|
SSL_ENGINE_SETFAILED = 54
|
||||||
CURLE_SEND_ERROR = 55
|
SEND_ERROR = 55
|
||||||
CURLE_RECV_ERROR = 56
|
RECV_ERROR = 56
|
||||||
CURLE_SSL_CERTPROBLEM = 58
|
SSL_CERTPROBLEM = 58
|
||||||
CURLE_SSL_CIPHER = 59
|
SSL_CIPHER = 59
|
||||||
CURLE_SSL_CACERT = 60
|
SSL_CACERT = 60
|
||||||
CURLE_BAD_CONTENT_ENCODING = 61
|
BAD_CONTENT_ENCODING = 61
|
||||||
CURLE_LDAP_INVALID_URL = 62
|
LDAP_INVALID_URL = 62
|
||||||
CURLE_FILESIZE_EXCEEDED = 63
|
FILESIZE_EXCEEDED = 63
|
||||||
CURLE_USE_SSL_FAILED = 64
|
USE_SSL_FAILED = 64
|
||||||
CURLE_SEND_FAIL_REWIND = 65
|
SEND_FAIL_REWIND = 65
|
||||||
CURLE_SSL_ENGINE_INITFAILED = 66
|
SSL_ENGINE_INITFAILED = 66
|
||||||
CURLE_LOGIN_DENIED = 67
|
LOGIN_DENIED = 67
|
||||||
CURLE_TFTP_NOTFOUND = 68
|
TFTP_NOTFOUND = 68
|
||||||
CURLE_TFTP_PERM = 69
|
TFTP_PERM = 69
|
||||||
CURLE_REMOTE_DISK_FULL = 70
|
REMOTE_DISK_FULL = 70
|
||||||
CURLE_TFTP_ILLEGAL = 71
|
TFTP_ILLEGAL = 71
|
||||||
CURLE_TFTP_UNKNOWNID = 72
|
TFTP_UNKNOWNID = 72
|
||||||
CURLE_REMOTE_FILE_EXISTS = 73
|
REMOTE_FILE_EXISTS = 73
|
||||||
CURLE_TFTP_NOSUCHUSER = 74
|
TFTP_NOSUCHUSER = 74
|
||||||
CURLE_CONV_FAILED = 75
|
CONV_FAILED = 75
|
||||||
CURLE_CONV_REQD = 76
|
CONV_REQD = 76
|
||||||
CURLE_SSL_CACERT_BADFILE = 77
|
SSL_CACERT_BADFILE = 77
|
||||||
CURLE_REMOTE_FILE_NOT_FOUND = 78
|
REMOTE_FILE_NOT_FOUND = 78
|
||||||
CURLE_SSH = 79
|
SSH = 79
|
||||||
CURLE_SSL_SHUTDOWN_FAILED = 80
|
SSL_SHUTDOWN_FAILED = 80
|
||||||
CURLE_AGAIN = 81
|
AGAIN = 81
|
||||||
CURLE_SSL_CRL_BADFILE = 82
|
SSL_CRL_BADFILE = 82
|
||||||
CURLE_SSL_ISSUER_ERROR = 83
|
SSL_ISSUER_ERROR = 83
|
||||||
CURLE_FTP_PRET_FAILED = 84
|
FTP_PRET_FAILED = 84
|
||||||
CURLE_RTSP_CSEQ_ERROR = 85
|
RTSP_CSEQ_ERROR = 85
|
||||||
CURLE_RTSP_SESSION_ERROR = 86
|
RTSP_SESSION_ERROR = 86
|
||||||
CURLE_FTP_BAD_FILE_LIST = 87
|
FTP_BAD_FILE_LIST = 87
|
||||||
CURLE_CHUNK_FAILED = 88
|
CHUNK_FAILED = 88
|
||||||
CURLE_NO_CONNECTION_AVAILABLE = 89
|
NO_CONNECTION_AVAILABLE = 89
|
||||||
CURLE_SSL_PINNEDPUBKEYNOTMATCH = 90
|
SSL_PINNEDPUBKEYNOTMATCH = 90
|
||||||
CURLE_SSL_INVALIDCERTSTATUS = 91
|
SSL_INVALIDCERTSTATUS = 91
|
||||||
CURLE_HTTP2_STREAM = 92
|
HTTP2_STREAM = 92
|
||||||
CURLE_RECURSIVE_API_CALL = 93
|
RECURSIVE_API_CALL = 93
|
||||||
CURLE_AUTH_ERROR = 94
|
AUTH_ERROR = 94
|
||||||
CURLE_HTTP3 = 95
|
HTTP3 = 95
|
||||||
CURLE_QUIC_CONNECT_ERROR = 96
|
QUIC_CONNECT_ERROR = 96
|
||||||
CURLE_PROXY = 97
|
PROXY = 97
|
||||||
CURLE_SSL_CLIENTCERT = 98
|
SSL_CLIENTCERT = 98
|
||||||
CURLE_UNRECOVERABLE_POLL = 99
|
UNRECOVERABLE_POLL = 99
|
||||||
CURL_LAST = 100
|
LAST = 100
|
||||||
|
|
||||||
|
|
||||||
class CURLoption(c_int):
|
class CURLoption(c_int):
|
||||||
@ -141,118 +141,118 @@ class CURLoption(c_int):
|
|||||||
CURLOPTTYPE_STRINGPOINT = CURLOPTTYPE_OBJECTPOINT
|
CURLOPTTYPE_STRINGPOINT = CURLOPTTYPE_OBJECTPOINT
|
||||||
CURLOPTTYPE_CBPOINT = CURLOPTTYPE_OBJECTPOINT
|
CURLOPTTYPE_CBPOINT = CURLOPTTYPE_OBJECTPOINT
|
||||||
|
|
||||||
CURLOPT_WRITEDATA = CURLOPTTYPE_CBPOINT + 1
|
WRITEDATA = CURLOPTTYPE_CBPOINT + 1
|
||||||
CURLOPT_URL = CURLOPTTYPE_STRINGPOINT + 2
|
URL = CURLOPTTYPE_STRINGPOINT + 2
|
||||||
CURLOPT_PORT = CURLOPTTYPE_LONG + 3
|
PORT = CURLOPTTYPE_LONG + 3
|
||||||
CURLOPT_PROXY = CURLOPTTYPE_STRINGPOINT + 4
|
PROXY = CURLOPTTYPE_STRINGPOINT + 4
|
||||||
CURLOPT_WRITEFUNCTION = CURLOPTTYPE_FUNCTIONPOINT + 11
|
WRITEFUNCTION = CURLOPTTYPE_FUNCTIONPOINT + 11
|
||||||
CURLOPT_POSTFIELDS = CURLOPTTYPE_OBJECTPOINT + 15
|
POSTFIELDS = CURLOPTTYPE_OBJECTPOINT + 15
|
||||||
CURLOPT_USERAGENT = CURLOPTTYPE_STRINGPOINT + 18
|
USERAGENT = CURLOPTTYPE_STRINGPOINT + 18
|
||||||
CURLOPT_COOKIE = CURLOPTTYPE_STRINGPOINT + 22
|
COOKIE = CURLOPTTYPE_STRINGPOINT + 22
|
||||||
CURLOPT_HTTPHEADER = CURLOPTTYPE_SLISTPOINT + 23
|
HTTPHEADER = CURLOPTTYPE_SLISTPOINT + 23
|
||||||
CURLOPT_HEADERDATA = CURLOPTTYPE_CBPOINT + 29
|
HEADERDATA = CURLOPTTYPE_CBPOINT + 29
|
||||||
CURLOPT_COOKIEFILE = CURLOPTTYPE_STRINGPOINT + 31
|
COOKIEFILE = CURLOPTTYPE_STRINGPOINT + 31
|
||||||
CURLOPT_CUSTOMREQUEST = CURLOPTTYPE_STRINGPOINT + 36
|
CUSTOMREQUEST = CURLOPTTYPE_STRINGPOINT + 36
|
||||||
CURLOPT_POST = CURLOPTTYPE_LONG + 47
|
POST = CURLOPTTYPE_LONG + 47
|
||||||
CURLOPT_FOLLOWLOCATION = CURLOPTTYPE_LONG + 52
|
FOLLOWLOCATION = CURLOPTTYPE_LONG + 52
|
||||||
CURLOPT_POSTFIELDSIZE = CURLOPTTYPE_LONG + 60
|
POSTFIELDSIZE = CURLOPTTYPE_LONG + 60
|
||||||
CURLOPT_SSL_VERIFYPEER = CURLOPTTYPE_LONG + 64
|
SSL_VERIFYPEER = CURLOPTTYPE_LONG + 64
|
||||||
CURLOPT_MAXREDIRS = CURLOPTTYPE_LONG + 68
|
MAXREDIRS = CURLOPTTYPE_LONG + 68
|
||||||
CURLOPT_HEADERFUNCTION = CURLOPTTYPE_FUNCTIONPOINT + 79
|
HEADERFUNCTION = CURLOPTTYPE_FUNCTIONPOINT + 79
|
||||||
CURLOPT_HTTPGET = CURLOPTTYPE_LONG + 80
|
HTTPGET = CURLOPTTYPE_LONG + 80
|
||||||
CURLOPT_SSL_VERIFYHOST = CURLOPTTYPE_LONG + 81
|
SSL_VERIFYHOST = CURLOPTTYPE_LONG + 81
|
||||||
CURLOPT_COOKIEJAR = CURLOPTTYPE_STRINGPOINT + 82
|
COOKIEJAR = CURLOPTTYPE_STRINGPOINT + 82
|
||||||
CURLOPT_COOKIESESSION = CURLOPTTYPE_LONG + 96
|
COOKIESESSION = CURLOPTTYPE_LONG + 96
|
||||||
CURLOPT_SHARE = CURLOPTTYPE_OBJECTPOINT + 100
|
SHARE = CURLOPTTYPE_OBJECTPOINT + 100
|
||||||
CURLOPT_ACCEPT_ENCODING = CURLOPTTYPE_STRINGPOINT + 102
|
ACCEPT_ENCODING = CURLOPTTYPE_STRINGPOINT + 102
|
||||||
CURLOPT_CONNECT_ONLY = CURLOPTTYPE_LONG + 141
|
CONNECT_ONLY = CURLOPTTYPE_LONG + 141
|
||||||
CURLOPT_TIMEOUT_MS = CURLOPTTYPE_LONG + 155
|
TIMEOUT_MS = CURLOPTTYPE_LONG + 155
|
||||||
CURLOPT_CONNECTTIMEOUT_MS = CURLOPTTYPE_LONG + 156
|
CONNECTTIMEOUT_MS = CURLOPTTYPE_LONG + 156
|
||||||
|
|
||||||
|
|
||||||
class CURLINFO(c_int):
|
class CURLINFO(c_int):
|
||||||
CURLINFO_STRING = 0x100000
|
STRING = 0x100000
|
||||||
CURLINFO_LONG = 0x200000
|
LONG = 0x200000
|
||||||
CURLINFO_DOUBLE = 0x300000
|
DOUBLE = 0x300000
|
||||||
CURLINFO_SLIST = 0x400000
|
SLIST = 0x400000
|
||||||
CURLINFO_PTR = 0x400000
|
PTR = 0x400000
|
||||||
CURLINFO_SOCKET = 0x500000
|
SOCKET = 0x500000
|
||||||
CURLINFO_OFF_T = 0x600000
|
OFF_T = 0x600000
|
||||||
CURLINFO_MASK = 0x0FFFFF
|
MASK = 0x0FFFFF
|
||||||
CURLINFO_TYPEMASK = 0xF00000
|
TYPEMASK = 0xF00000
|
||||||
CURLINFO_NONE = 0
|
NONE = 0
|
||||||
CURLINFO_EFFECTIVE_URL = CURLINFO_STRING + 1
|
EFFECTIVE_URL = STRING + 1
|
||||||
CURLINFO_RESPONSE_CODE = CURLINFO_LONG + 2
|
RESPONSE_CODE = LONG + 2
|
||||||
CURLINFO_TOTAL_TIME = CURLINFO_DOUBLE + 3
|
TOTAL_TIME = DOUBLE + 3
|
||||||
CURLINFO_NAMELOOKUP_TIME = CURLINFO_DOUBLE + 4
|
NAMELOOKUP_TIME = DOUBLE + 4
|
||||||
CURLINFO_CONNECT_TIME = CURLINFO_DOUBLE + 5
|
CONNECT_TIME = DOUBLE + 5
|
||||||
CURLINFO_PRETRANSFER_TIME = CURLINFO_DOUBLE + 6
|
PRETRANSFER_TIME = DOUBLE + 6
|
||||||
CURLINFO_SIZE_UPLOAD = CURLINFO_DOUBLE + 7
|
SIZE_UPLOAD = DOUBLE + 7
|
||||||
CURLINFO_SIZE_UPLOAD_T = CURLINFO_OFF_T + 7
|
SIZE_UPLOAD_T = OFF_T + 7
|
||||||
CURLINFO_SIZE_DOWNLOAD = CURLINFO_DOUBLE + 8
|
SIZE_DOWNLOAD = DOUBLE + 8
|
||||||
CURLINFO_SIZE_DOWNLOAD_T = CURLINFO_OFF_T + 8
|
SIZE_DOWNLOAD_T = OFF_T + 8
|
||||||
CURLINFO_SPEED_DOWNLOAD = CURLINFO_DOUBLE + 9
|
SPEED_DOWNLOAD = DOUBLE + 9
|
||||||
CURLINFO_SPEED_DOWNLOAD_T = CURLINFO_OFF_T + 9
|
SPEED_DOWNLOAD_T = OFF_T + 9
|
||||||
CURLINFO_SPEED_UPLOAD = CURLINFO_DOUBLE + 10
|
SPEED_UPLOAD = DOUBLE + 10
|
||||||
CURLINFO_SPEED_UPLOAD_T = CURLINFO_OFF_T + 10
|
SPEED_UPLOAD_T = OFF_T + 10
|
||||||
CURLINFO_HEADER_SIZE = CURLINFO_LONG + 11
|
HEADER_SIZE = LONG + 11
|
||||||
CURLINFO_REQUEST_SIZE = CURLINFO_LONG + 12
|
REQUEST_SIZE = LONG + 12
|
||||||
CURLINFO_SSL_VERIFYRESULT = CURLINFO_LONG + 13
|
SSL_VERIFYRESULT = LONG + 13
|
||||||
CURLINFO_FILETIME = CURLINFO_LONG + 14
|
FILETIME = LONG + 14
|
||||||
CURLINFO_FILETIME_T = CURLINFO_OFF_T + 14
|
FILETIME_T = OFF_T + 14
|
||||||
CURLINFO_CONTENT_LENGTH_DOWNLOAD = CURLINFO_DOUBLE + 15
|
CONTENT_LENGTH_DOWNLOAD = DOUBLE + 15
|
||||||
CURLINFO_CONTENT_LENGTH_DOWNLOAD_T = CURLINFO_OFF_T + 15
|
CONTENT_LENGTH_DOWNLOAD_T = OFF_T + 15
|
||||||
CURLINFO_CONTENT_LENGTH_UPLOAD = CURLINFO_DOUBLE + 16
|
CONTENT_LENGTH_UPLOAD = DOUBLE + 16
|
||||||
CURLINFO_CONTENT_LENGTH_UPLOAD_T = CURLINFO_OFF_T + 16
|
CONTENT_LENGTH_UPLOAD_T = OFF_T + 16
|
||||||
CURLINFO_STARTTRANSFER_TIME = CURLINFO_DOUBLE + 17
|
STARTTRANSFER_TIME = DOUBLE + 17
|
||||||
CURLINFO_CONTENT_TYPE = CURLINFO_STRING + 18
|
CONTENT_TYPE = STRING + 18
|
||||||
CURLINFO_REDIRECT_TIME = CURLINFO_DOUBLE + 19
|
REDIRECT_TIME = DOUBLE + 19
|
||||||
CURLINFO_REDIRECT_COUNT = CURLINFO_LONG + 20
|
REDIRECT_COUNT = LONG + 20
|
||||||
CURLINFO_PRIVATE = CURLINFO_STRING + 21
|
PRIVATE = STRING + 21
|
||||||
CURLINFO_HTTP_CONNECTCODE = CURLINFO_LONG + 22
|
HTTP_CONNECTCODE = LONG + 22
|
||||||
CURLINFO_HTTPAUTH_AVAIL = CURLINFO_LONG + 23
|
HTTPAUTH_AVAIL = LONG + 23
|
||||||
CURLINFO_PROXYAUTH_AVAIL = CURLINFO_LONG + 24
|
PROXYAUTH_AVAIL = LONG + 24
|
||||||
CURLINFO_OS_ERRNO = CURLINFO_LONG + 25
|
OS_ERRNO = LONG + 25
|
||||||
CURLINFO_NUM_CONNECTS = CURLINFO_LONG + 26
|
NUM_CONNECTS = LONG + 26
|
||||||
CURLINFO_SSL_ENGINES = CURLINFO_SLIST + 27
|
SSL_ENGINES = SLIST + 27
|
||||||
CURLINFO_COOKIELIST = CURLINFO_SLIST + 28
|
COOKIELIST = SLIST + 28
|
||||||
CURLINFO_LASTSOCKET = CURLINFO_LONG + 29
|
LASTSOCKET = LONG + 29
|
||||||
CURLINFO_FTP_ENTRY_PATH = CURLINFO_STRING + 30
|
FTP_ENTRY_PATH = STRING + 30
|
||||||
CURLINFO_REDIRECT_URL = CURLINFO_STRING + 31
|
REDIRECT_URL = STRING + 31
|
||||||
CURLINFO_PRIMARY_IP = CURLINFO_STRING + 32
|
PRIMARY_IP = STRING + 32
|
||||||
CURLINFO_APPCONNECT_TIME = CURLINFO_DOUBLE + 33
|
APPCONNECT_TIME = DOUBLE + 33
|
||||||
CURLINFO_CERTINFO = CURLINFO_PTR + 34
|
CERTINFO = PTR + 34
|
||||||
CURLINFO_CONDITION_UNMET = CURLINFO_LONG + 35
|
CONDITION_UNMET = LONG + 35
|
||||||
CURLINFO_RTSP_SESSION_ID = CURLINFO_STRING + 36
|
RTSP_SESSION_ID = STRING + 36
|
||||||
CURLINFO_RTSP_CLIENT_CSEQ = CURLINFO_LONG + 37
|
RTSP_CLIENT_CSEQ = LONG + 37
|
||||||
CURLINFO_RTSP_SERVER_CSEQ = CURLINFO_LONG + 38
|
RTSP_SERVER_CSEQ = LONG + 38
|
||||||
CURLINFO_RTSP_CSEQ_RECV = CURLINFO_LONG + 39
|
RTSP_CSEQ_RECV = LONG + 39
|
||||||
CURLINFO_PRIMARY_PORT = CURLINFO_LONG + 40
|
PRIMARY_PORT = LONG + 40
|
||||||
CURLINFO_LOCAL_IP = CURLINFO_STRING + 41
|
LOCAL_IP = STRING + 41
|
||||||
CURLINFO_LOCAL_PORT = CURLINFO_LONG + 42
|
LOCAL_PORT = LONG + 42
|
||||||
CURLINFO_TLS_SESSION = CURLINFO_PTR + 43
|
TLS_SESSION = PTR + 43
|
||||||
CURLINFO_ACTIVESOCKET = CURLINFO_SOCKET + 44
|
ACTIVESOCKET = SOCKET + 44
|
||||||
CURLINFO_TLS_SSL_PTR = CURLINFO_PTR + 45
|
TLS_SSL_PTR = PTR + 45
|
||||||
CURLINFO_HTTP_VERSION = CURLINFO_LONG + 46
|
HTTP_VERSION = LONG + 46
|
||||||
CURLINFO_PROXY_SSL_VERIFYRESULT = CURLINFO_LONG + 47
|
PROXY_SSL_VERIFYRESULT = LONG + 47
|
||||||
CURLINFO_PROTOCOL = CURLINFO_LONG + 48
|
PROTOCOL = LONG + 48
|
||||||
CURLINFO_SCHEME = CURLINFO_STRING + 49
|
SCHEME = STRING + 49
|
||||||
CURLINFO_TOTAL_TIME_T = CURLINFO_OFF_T + 50
|
TOTAL_TIME_T = OFF_T + 50
|
||||||
CURLINFO_NAMELOOKUP_TIME_T = CURLINFO_OFF_T + 51
|
NAMELOOKUP_TIME_T = OFF_T + 51
|
||||||
CURLINFO_CONNECT_TIME_T = CURLINFO_OFF_T + 52
|
CONNECT_TIME_T = OFF_T + 52
|
||||||
CURLINFO_PRETRANSFER_TIME_T = CURLINFO_OFF_T + 53
|
PRETRANSFER_TIME_T = OFF_T + 53
|
||||||
CURLINFO_STARTTRANSFER_TIME_T = CURLINFO_OFF_T + 54
|
STARTTRANSFER_TIME_T = OFF_T + 54
|
||||||
CURLINFO_REDIRECT_TIME_T = CURLINFO_OFF_T + 55
|
REDIRECT_TIME_T = OFF_T + 55
|
||||||
CURLINFO_APPCONNECT_TIME_T = CURLINFO_OFF_T + 56
|
APPCONNECT_TIME_T = OFF_T + 56
|
||||||
CURLINFO_RETRY_AFTER = CURLINFO_OFF_T + 57
|
RETRY_AFTER = OFF_T + 57
|
||||||
CURLINFO_EFFECTIVE_METHOD = CURLINFO_STRING + 58
|
EFFECTIVE_METHOD = STRING + 58
|
||||||
CURLINFO_PROXY_ERROR = CURLINFO_LONG + 59
|
PROXY_ERROR = LONG + 59
|
||||||
CURLINFO_REFERER = CURLINFO_STRING + 60
|
REFERER = STRING + 60
|
||||||
CURLINFO_CAINFO = CURLINFO_STRING + 61
|
CAINFO = STRING + 61
|
||||||
CURLINFO_CAPATH = CURLINFO_STRING + 62
|
CAPATH = STRING + 62
|
||||||
CURLINFO_XFER_ID = CURLINFO_OFF_T + 63
|
XFER_ID = OFF_T + 63
|
||||||
CURLINFO_CONN_ID = CURLINFO_OFF_T + 64
|
CONN_ID = OFF_T + 64
|
||||||
CURLINFO_LASTONE = 64
|
LASTONE = 64
|
||||||
|
|
||||||
|
|
||||||
curl_global_init = libcurl.curl_global_init
|
curl_global_init = libcurl.curl_global_init
|
||||||
@ -325,7 +325,7 @@ class CURLException(NetWorkException):
|
|||||||
self.errorcode = code.value
|
self.errorcode = code.value
|
||||||
error = curl_easy_strerror(code).decode("utf8")
|
error = curl_easy_strerror(code).decode("utf8")
|
||||||
for _ in dir(CURLcode):
|
for _ in dir(CURLcode):
|
||||||
if _.startswith("CURLE_") and code.value == getattr(CURLcode, _):
|
if _.startswith("") and code.value == getattr(CURLcode, _):
|
||||||
error = str(code.value) + " " + _ + " : " + error
|
error = str(code.value) + " " + _ + " : " + error
|
||||||
break
|
break
|
||||||
else:
|
else:
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
from libcurl import *
|
from .libcurl import *
|
||||||
import threading, functools, queue
|
import threading, functools, queue
|
||||||
from ctypes import c_long, cast, pointer, POINTER, c_char
|
from ctypes import c_long, cast, pointer, POINTER, c_char
|
||||||
from network.requests_common import *
|
from requests import ResponseBase, Timeout, Requester_common
|
||||||
from traceback import print_exc
|
from traceback import print_exc
|
||||||
|
|
||||||
|
|
||||||
@ -45,7 +45,7 @@ def ExceptionFilter(func):
|
|||||||
_ = func(*args, **kwargs)
|
_ = func(*args, **kwargs)
|
||||||
return _
|
return _
|
||||||
except CURLException as e:
|
except CURLException as e:
|
||||||
if e.errorcode == CURLcode.CURLE_OPERATION_TIMEDOUT:
|
if e.errorcode == CURLcode.OPERATION_TIMEDOUT:
|
||||||
raise Timeout(e)
|
raise Timeout(e)
|
||||||
else:
|
else:
|
||||||
raise e
|
raise e
|
||||||
@ -53,8 +53,7 @@ def ExceptionFilter(func):
|
|||||||
return _wrapper
|
return _wrapper
|
||||||
|
|
||||||
|
|
||||||
class Session(Sessionbase):
|
class Requester(Requester_common):
|
||||||
|
|
||||||
def raise_for_status(self):
|
def raise_for_status(self):
|
||||||
if self.last_error:
|
if self.last_error:
|
||||||
raise CURLException(self.last_error)
|
raise CURLException(self.last_error)
|
||||||
@ -62,7 +61,7 @@ class Session(Sessionbase):
|
|||||||
def _getStatusCode(self, curl):
|
def _getStatusCode(self, curl):
|
||||||
status_code = c_long()
|
status_code = c_long()
|
||||||
self.last_error = curl_easy_getinfo(
|
self.last_error = curl_easy_getinfo(
|
||||||
curl, CURLINFO.CURLINFO_RESPONSE_CODE, pointer(status_code)
|
curl, CURLINFO.RESPONSE_CODE, pointer(status_code)
|
||||||
)
|
)
|
||||||
self.raise_for_status()
|
self.raise_for_status()
|
||||||
return status_code.value
|
return status_code.value
|
||||||
@ -70,17 +69,17 @@ class Session(Sessionbase):
|
|||||||
def _set_proxy(self, curl, proxy):
|
def _set_proxy(self, curl, proxy):
|
||||||
if proxy:
|
if proxy:
|
||||||
self.last_error = curl_easy_setopt(
|
self.last_error = curl_easy_setopt(
|
||||||
curl, CURLoption.CURLOPT_PROXY, proxy.encode("utf8")
|
curl, CURLoption.PROXY, proxy.encode("utf8")
|
||||||
)
|
)
|
||||||
self.raise_for_status()
|
self.raise_for_status()
|
||||||
|
|
||||||
def _set_verify(self, curl, verify):
|
def _set_verify(self, curl, verify):
|
||||||
if verify == False:
|
if verify == False:
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_SSL_VERIFYPEER, 0)
|
curl_easy_setopt(curl, CURLoption.SSL_VERIFYPEER, 0)
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_SSL_VERIFYHOST, 0)
|
curl_easy_setopt(curl, CURLoption.SSL_VERIFYHOST, 0)
|
||||||
else:
|
else:
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_SSL_VERIFYPEER, 1)
|
curl_easy_setopt(curl, CURLoption.SSL_VERIFYPEER, 1)
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_SSL_VERIFYHOST, 2)
|
curl_easy_setopt(curl, CURLoption.SSL_VERIFYHOST, 2)
|
||||||
|
|
||||||
def _perform(self, curl):
|
def _perform(self, curl):
|
||||||
self.last_error = curl_easy_perform(curl)
|
self.last_error = curl_easy_perform(curl)
|
||||||
@ -88,11 +87,39 @@ class Session(Sessionbase):
|
|||||||
|
|
||||||
def _set_allow_redirects(self, curl, allow_redirects):
|
def _set_allow_redirects(self, curl, allow_redirects):
|
||||||
|
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_FOLLOWLOCATION, int(allow_redirects))
|
curl_easy_setopt(curl, CURLoption.FOLLOWLOCATION, int(allow_redirects))
|
||||||
# curl_easy_setopt(curl, CURLoption.CURLOPT_MAXREDIRS, 100) #默认50够了
|
# curl_easy_setopt(curl, CURLoption.MAXREDIRS, 100) #默认50够了
|
||||||
|
|
||||||
|
def __WriteMemoryCallback(self, headerqueue, que, contents, size, nmemb, userp):
|
||||||
|
if headerqueue:
|
||||||
|
headerqueue.put(0)
|
||||||
|
realsize = size * nmemb
|
||||||
|
bs = cast(contents, POINTER(c_char))[:realsize]
|
||||||
|
if isinstance(que, queue.Queue):
|
||||||
|
que.put(bs)
|
||||||
|
elif isinstance(que, list):
|
||||||
|
que.append(bs)
|
||||||
|
return realsize
|
||||||
|
|
||||||
|
def __getrealheader(self, headerqueue):
|
||||||
|
if isinstance(headerqueue, queue.Queue):
|
||||||
|
header = ""
|
||||||
|
while True:
|
||||||
|
_headerb = headerqueue.get()
|
||||||
|
if _headerb == 0:
|
||||||
|
break
|
||||||
|
elif _headerb == 1:
|
||||||
|
self.raise_for_status()
|
||||||
|
_headerb = _headerb.decode("utf8")
|
||||||
|
if _headerb.startswith("HTTP/"):
|
||||||
|
header = ""
|
||||||
|
header += _headerb
|
||||||
|
return header
|
||||||
|
elif isinstance(headerqueue, list):
|
||||||
|
return b"".join(headerqueue).decode("utf8")
|
||||||
|
|
||||||
@ExceptionFilter
|
@ExceptionFilter
|
||||||
def request_impl(
|
def request(
|
||||||
self,
|
self,
|
||||||
method,
|
method,
|
||||||
scheme,
|
scheme,
|
||||||
@ -111,85 +138,75 @@ class Session(Sessionbase):
|
|||||||
allow_redirects,
|
allow_redirects,
|
||||||
):
|
):
|
||||||
curl = AutoCURLHandle(curl_easy_init())
|
curl = AutoCURLHandle(curl_easy_init())
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_COOKIEJAR, "")
|
curl_easy_setopt(curl, CURLoption.COOKIEJAR, "")
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_USERAGENT, self.UA.encode("utf8"))
|
curl_easy_setopt(
|
||||||
if cookies:
|
curl, CURLoption.USERAGENT, headers["User-Agent"].encode("utf8")
|
||||||
cookies.update(self.cookies)
|
)
|
||||||
else:
|
|
||||||
cookies = self.cookies
|
|
||||||
|
|
||||||
if cookies:
|
if cookies:
|
||||||
cookie = self._parsecookie(cookies)
|
cookie = self._parsecookie(cookies)
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_COOKIE, cookie.encode("utf8"))
|
curl_easy_setopt(curl, CURLoption.COOKIE, cookie.encode("utf8"))
|
||||||
if timeout:
|
if timeout:
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_TIMEOUT_MS, timeout)
|
curl_easy_setopt(curl, CURLoption.TIMEOUT_MS, timeout)
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_CONNECTTIMEOUT_MS, timeout)
|
curl_easy_setopt(curl, CURLoption.CONNECTTIMEOUT_MS, timeout)
|
||||||
curl_easy_setopt(
|
curl_easy_setopt(
|
||||||
curl,
|
curl,
|
||||||
CURLoption.CURLOPT_ACCEPT_ENCODING,
|
CURLoption.ACCEPT_ENCODING,
|
||||||
headers["Accept-Encoding"].encode("utf8"),
|
headers["Accept-Encoding"].encode("utf8"),
|
||||||
)
|
)
|
||||||
|
|
||||||
curl_easy_setopt(
|
curl_easy_setopt(curl, CURLoption.CUSTOMREQUEST, method.upper().encode("utf8"))
|
||||||
curl, CURLoption.CURLOPT_CUSTOMREQUEST, method.upper().encode("utf8")
|
|
||||||
)
|
|
||||||
|
|
||||||
self.last_error = curl_easy_setopt(
|
self.last_error = curl_easy_setopt(curl, CURLoption.URL, url.encode("utf8"))
|
||||||
curl, CURLoption.CURLOPT_URL, url.encode("utf8")
|
|
||||||
)
|
|
||||||
self.raise_for_status()
|
self.raise_for_status()
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_PORT, port)
|
curl_easy_setopt(curl, CURLoption.PORT, port)
|
||||||
|
|
||||||
lheaders = Autoslist()
|
lheaders = Autoslist()
|
||||||
for _ in self._parseheader(headers, None):
|
for _ in self._parseheader(headers, None):
|
||||||
lheaders = curl_slist_append(
|
lheaders = curl_slist_append(
|
||||||
cast(lheaders, POINTER(curl_slist)), _.encode("utf8")
|
cast(lheaders, POINTER(curl_slist)), _.encode("utf8")
|
||||||
)
|
)
|
||||||
self.last_error = curl_easy_setopt(
|
self.last_error = curl_easy_setopt(curl, CURLoption.HTTPHEADER, lheaders)
|
||||||
curl, CURLoption.CURLOPT_HTTPHEADER, lheaders
|
|
||||||
)
|
|
||||||
self.raise_for_status()
|
self.raise_for_status()
|
||||||
|
|
||||||
self._set_verify(curl, verify)
|
self._set_verify(curl, verify)
|
||||||
self._set_proxy(curl, proxy)
|
self._set_proxy(curl, proxy)
|
||||||
self._set_allow_redirects(curl, allow_redirects)
|
self._set_allow_redirects(curl, allow_redirects)
|
||||||
if datalen:
|
if datalen:
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_POSTFIELDS, dataptr)
|
curl_easy_setopt(curl, CURLoption.POSTFIELDS, dataptr)
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_POSTFIELDSIZE, datalen)
|
curl_easy_setopt(curl, CURLoption.POSTFIELDSIZE, datalen)
|
||||||
|
|
||||||
resp = Response()
|
resp = Response()
|
||||||
resp.keeprefs.append(curl)
|
resp.keeprefs.append(curl)
|
||||||
|
|
||||||
if stream:
|
if stream:
|
||||||
|
|
||||||
def WriteMemoryCallback(headerqueue, queue, contents, size, nmemb, userp):
|
|
||||||
if headerqueue:
|
|
||||||
headerqueue.put(0)
|
|
||||||
realsize = size * nmemb
|
|
||||||
queue.put(cast(contents, POINTER(c_char))[:realsize])
|
|
||||||
return realsize
|
|
||||||
|
|
||||||
_content = []
|
|
||||||
_headers = []
|
|
||||||
headerqueue = queue.Queue()
|
headerqueue = queue.Queue()
|
||||||
|
_notif = headerqueue
|
||||||
|
else:
|
||||||
|
headerqueue = []
|
||||||
|
_notif = None
|
||||||
|
resp.queue = []
|
||||||
keepref1 = WRITEFUNCTION(
|
keepref1 = WRITEFUNCTION(
|
||||||
functools.partial(WriteMemoryCallback, headerqueue, resp.queue)
|
functools.partial(self.__WriteMemoryCallback, _notif, resp.queue)
|
||||||
)
|
)
|
||||||
keepref2 = WRITEFUNCTION(
|
keepref2 = WRITEFUNCTION(
|
||||||
functools.partial(WriteMemoryCallback, None, headerqueue)
|
functools.partial(self.__WriteMemoryCallback, None, headerqueue)
|
||||||
)
|
)
|
||||||
curl_easy_setopt(
|
curl_easy_setopt(
|
||||||
curl,
|
curl,
|
||||||
CURLoption.CURLOPT_WRITEFUNCTION,
|
CURLoption.WRITEFUNCTION,
|
||||||
cast(keepref1, c_void_p).value,
|
cast(keepref1, c_void_p).value,
|
||||||
)
|
)
|
||||||
|
|
||||||
curl_easy_setopt(
|
curl_easy_setopt(
|
||||||
curl,
|
curl,
|
||||||
CURLoption.CURLOPT_HEADERFUNCTION,
|
CURLoption.HEADERFUNCTION,
|
||||||
cast(keepref2, c_void_p).value,
|
cast(keepref2, c_void_p).value,
|
||||||
)
|
)
|
||||||
resp.keeprefs += [keepref1, keepref2]
|
resp.keeprefs += [keepref1, keepref2]
|
||||||
|
|
||||||
|
if stream:
|
||||||
|
|
||||||
def ___perform():
|
def ___perform():
|
||||||
error = False
|
error = False
|
||||||
try:
|
try:
|
||||||
@ -205,50 +222,15 @@ class Session(Sessionbase):
|
|||||||
|
|
||||||
threading.Thread(target=___perform, daemon=True).start()
|
threading.Thread(target=___perform, daemon=True).start()
|
||||||
|
|
||||||
headerb = ""
|
|
||||||
while True:
|
|
||||||
_headerb = headerqueue.get()
|
|
||||||
if _headerb == 0:
|
|
||||||
break
|
|
||||||
elif _headerb == 1:
|
|
||||||
self.raise_for_status()
|
|
||||||
_headerb = _headerb.decode("utf8")
|
|
||||||
if _headerb.startswith("HTTP/"):
|
|
||||||
headerb = ""
|
|
||||||
headerb += _headerb
|
|
||||||
resp.headers = self._update_header_cookie(headerb)
|
|
||||||
resp.status_code = self._getStatusCode(curl)
|
|
||||||
else:
|
else:
|
||||||
|
|
||||||
def WriteMemoryCallback(saver, contents, size, nmemb, userp):
|
|
||||||
realsize = size * nmemb
|
|
||||||
saver.append(cast(contents, POINTER(c_char))[:realsize])
|
|
||||||
return realsize
|
|
||||||
|
|
||||||
_content = []
|
|
||||||
_headers = []
|
|
||||||
keepref1 = WRITEFUNCTION(functools.partial(WriteMemoryCallback, _content))
|
|
||||||
keepref2 = WRITEFUNCTION(functools.partial(WriteMemoryCallback, _headers))
|
|
||||||
|
|
||||||
curl_easy_setopt(
|
|
||||||
curl,
|
|
||||||
CURLoption.CURLOPT_WRITEFUNCTION,
|
|
||||||
cast(keepref1, c_void_p).value,
|
|
||||||
)
|
|
||||||
curl_easy_setopt(
|
|
||||||
curl,
|
|
||||||
CURLoption.CURLOPT_HEADERFUNCTION,
|
|
||||||
cast(keepref2, c_void_p).value,
|
|
||||||
)
|
|
||||||
resp.keeprefs += [keepref1, keepref2]
|
|
||||||
self._perform(curl)
|
self._perform(curl)
|
||||||
resp.content = b"".join(_content)
|
header = self.__getrealheader(headerqueue)
|
||||||
resp.headers = self._update_header_cookie(b"".join(_headers).decode("utf8"))
|
if not stream:
|
||||||
|
resp.content = b"".join(resp.queue)
|
||||||
|
|
||||||
|
resp.headers, resp.cookies = self._parseheader2dict(header)
|
||||||
resp.status_code = self._getStatusCode(curl)
|
resp.status_code = self._getStatusCode(curl)
|
||||||
|
|
||||||
resp.last_error = self.last_error
|
resp.last_error = self.last_error
|
||||||
resp.cookies = self.cookies
|
|
||||||
return resp
|
return resp
|
||||||
|
|
||||||
|
|
||||||
Sessionimpl[0] = Session
|
|
@ -1,5 +1,5 @@
|
|||||||
from ctypes import c_void_p, cast, c_size_t, pointer, create_string_buffer, POINTER
|
from ctypes import c_void_p, cast, c_size_t, pointer, create_string_buffer, POINTER
|
||||||
from libcurl import *
|
from .libcurl import *
|
||||||
from urllib.parse import urlsplit
|
from urllib.parse import urlsplit
|
||||||
import time
|
import time
|
||||||
|
|
||||||
@ -26,7 +26,7 @@ class WebSocket:
|
|||||||
error = curl_ws_recv(
|
error = curl_ws_recv(
|
||||||
self.curl, buffer, (10240), pointer(rlen), pointer(meta)
|
self.curl, buffer, (10240), pointer(rlen), pointer(meta)
|
||||||
)
|
)
|
||||||
if error.value == CURLcode.CURLE_AGAIN:
|
if error.value == CURLcode.AGAIN:
|
||||||
time.sleep(0.01)
|
time.sleep(0.01)
|
||||||
elif error:
|
elif error:
|
||||||
raise CURLException(error)
|
raise CURLException(error)
|
||||||
@ -57,7 +57,7 @@ class WebSocket:
|
|||||||
if http_proxy_host is None or http_proxy_port is None:
|
if http_proxy_host is None or http_proxy_port is None:
|
||||||
return
|
return
|
||||||
proxy = "{}:{}".format(http_proxy_host, http_proxy_port)
|
proxy = "{}:{}".format(http_proxy_host, http_proxy_port)
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_PROXY, proxy.encode("utf8"))
|
curl_easy_setopt(curl, CURLoption.PROXY, proxy.encode("utf8"))
|
||||||
|
|
||||||
def _parseurl2serverandpath(self, url):
|
def _parseurl2serverandpath(self, url):
|
||||||
url = url.strip()
|
url = url.strip()
|
||||||
@ -86,19 +86,19 @@ class WebSocket:
|
|||||||
|
|
||||||
def _set_verify(self, curl, verify):
|
def _set_verify(self, curl, verify):
|
||||||
if verify == False:
|
if verify == False:
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_SSL_VERIFYPEER, 0)
|
curl_easy_setopt(curl, CURLoption.SSL_VERIFYPEER, 0)
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_SSL_VERIFYHOST, 0)
|
curl_easy_setopt(curl, CURLoption.SSL_VERIFYHOST, 0)
|
||||||
else:
|
else:
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_SSL_VERIFYPEER, 1)
|
curl_easy_setopt(curl, CURLoption.SSL_VERIFYPEER, 1)
|
||||||
curl_easy_setopt(curl, CURLoption.CURLOPT_SSL_VERIFYHOST, 2)
|
curl_easy_setopt(curl, CURLoption.SSL_VERIFYHOST, 2)
|
||||||
|
|
||||||
def connect(self, url, header=None, http_proxy_host=None, http_proxy_port=None):
|
def connect(self, url, header=None, http_proxy_host=None, http_proxy_port=None):
|
||||||
https, server, port, path = self._parseurl2serverandpath(url)
|
https, server, port, path = self._parseurl2serverandpath(url)
|
||||||
self.curl = AutoCURLHandle(curl_easy_init())
|
self.curl = AutoCURLHandle(curl_easy_init())
|
||||||
curl_easy_setopt(self.curl, CURLoption.CURLOPT_URL, url.encode("utf8"))
|
curl_easy_setopt(self.curl, CURLoption.URL, url.encode("utf8"))
|
||||||
|
|
||||||
curl_easy_setopt(self.curl, CURLoption.CURLOPT_CONNECT_ONLY, 2)
|
curl_easy_setopt(self.curl, CURLoption.CONNECT_ONLY, 2)
|
||||||
curl_easy_setopt(self.curl, CURLoption.CURLOPT_PORT, port)
|
curl_easy_setopt(self.curl, CURLoption.PORT, port)
|
||||||
self._setproxy(self.curl, http_proxy_host, http_proxy_port)
|
self._setproxy(self.curl, http_proxy_host, http_proxy_port)
|
||||||
self._set_verify(self.curl, False)
|
self._set_verify(self.curl, False)
|
||||||
lheaders = Autoslist()
|
lheaders = Autoslist()
|
||||||
@ -107,14 +107,8 @@ class WebSocket:
|
|||||||
lheaders = curl_slist_append(
|
lheaders = curl_slist_append(
|
||||||
cast(lheaders, POINTER(curl_slist)), _.encode("utf8")
|
cast(lheaders, POINTER(curl_slist)), _.encode("utf8")
|
||||||
)
|
)
|
||||||
curl_easy_setopt(self.curl, CURLoption.CURLOPT_HTTPHEADER, lheaders)
|
curl_easy_setopt(self.curl, CURLoption.HTTPHEADER, lheaders)
|
||||||
|
|
||||||
error = curl_easy_perform(self.curl)
|
error = curl_easy_perform(self.curl)
|
||||||
if error:
|
if error:
|
||||||
raise CURLException(error)
|
raise CURLException(error)
|
||||||
|
|
||||||
|
|
||||||
def create_connection(url, **x):
|
|
||||||
_ = WebSocket()
|
|
||||||
_.connect(url)
|
|
||||||
return _
|
|
||||||
|
@ -1,12 +1,14 @@
|
|||||||
from winhttp import *
|
from .winhttp import *
|
||||||
from network.requests_common import *
|
from requests import ResponseBase, Timeout, Requester_common
|
||||||
|
from traceback import print_exc
|
||||||
import gzip, zlib
|
import gzip, zlib
|
||||||
from ctypes import pointer, create_string_buffer, create_unicode_buffer
|
from ctypes import pointer, create_string_buffer, create_unicode_buffer
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from brotli_dec import decompress
|
from .brotli_dec import decompress
|
||||||
except:
|
except:
|
||||||
pass
|
from traceback import print_exc
|
||||||
|
print_exc()
|
||||||
|
|
||||||
|
|
||||||
class Response(ResponseBase):
|
class Response(ResponseBase):
|
||||||
@ -58,20 +60,7 @@ def ExceptionFilter(func):
|
|||||||
return _wrapper
|
return _wrapper
|
||||||
|
|
||||||
|
|
||||||
class Session(Sessionbase):
|
class Requester(Requester_common):
|
||||||
def __init__(self) -> None:
|
|
||||||
super().__init__()
|
|
||||||
self.hSession = AutoWinHttpHandle(
|
|
||||||
WinHttpOpen(
|
|
||||||
self.UA,
|
|
||||||
WINHTTP_ACCESS_TYPE_DEFAULT_PROXY,
|
|
||||||
WINHTTP_NO_PROXY_NAME,
|
|
||||||
WINHTTP_NO_PROXY_BYPASS,
|
|
||||||
0,
|
|
||||||
)
|
|
||||||
)
|
|
||||||
if self.hSession == 0:
|
|
||||||
raise WinhttpException(GetLastError())
|
|
||||||
|
|
||||||
def _getheaders(self, hreq):
|
def _getheaders(self, hreq):
|
||||||
dwSize = DWORD()
|
dwSize = DWORD()
|
||||||
@ -138,7 +127,7 @@ class Session(Sessionbase):
|
|||||||
)
|
)
|
||||||
|
|
||||||
@ExceptionFilter
|
@ExceptionFilter
|
||||||
def request_impl(
|
def request(
|
||||||
self,
|
self,
|
||||||
method,
|
method,
|
||||||
scheme,
|
scheme,
|
||||||
@ -146,7 +135,7 @@ class Session(Sessionbase):
|
|||||||
port,
|
port,
|
||||||
param,
|
param,
|
||||||
url,
|
url,
|
||||||
headers,
|
_headers,
|
||||||
cookies,
|
cookies,
|
||||||
dataptr,
|
dataptr,
|
||||||
datalen,
|
datalen,
|
||||||
@ -156,12 +145,22 @@ class Session(Sessionbase):
|
|||||||
timeout,
|
timeout,
|
||||||
allow_redirects,
|
allow_redirects,
|
||||||
):
|
):
|
||||||
headers = self._parseheader(headers, cookies)
|
headers = self._parseheader(_headers, cookies)
|
||||||
flag = WINHTTP_FLAG_SECURE if scheme == "https" else 0
|
flag = WINHTTP_FLAG_SECURE if scheme == "https" else 0
|
||||||
# print(server,port,param,dataptr)
|
# print(server,port,param,dataptr)
|
||||||
headers = "\r\n".join(headers)
|
headers = "\r\n".join(headers)
|
||||||
|
hSession = AutoWinHttpHandle(
|
||||||
hConnect = AutoWinHttpHandle(WinHttpConnect(self.hSession, server, port, 0))
|
WinHttpOpen(
|
||||||
|
_headers["User-Agent"],
|
||||||
|
WINHTTP_ACCESS_TYPE_DEFAULT_PROXY,
|
||||||
|
WINHTTP_NO_PROXY_NAME,
|
||||||
|
WINHTTP_NO_PROXY_BYPASS,
|
||||||
|
0,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
if hSession == 0:
|
||||||
|
raise WinhttpException(GetLastError())
|
||||||
|
hConnect = AutoWinHttpHandle(WinHttpConnect(hSession, server, port, 0))
|
||||||
if hConnect == 0:
|
if hConnect == 0:
|
||||||
raise WinhttpException(GetLastError())
|
raise WinhttpException(GetLastError())
|
||||||
hRequest = AutoWinHttpHandle(
|
hRequest = AutoWinHttpHandle(
|
||||||
@ -191,16 +190,14 @@ class Session(Sessionbase):
|
|||||||
succ = WinHttpReceiveResponse(hRequest, None)
|
succ = WinHttpReceiveResponse(hRequest, None)
|
||||||
if succ == 0:
|
if succ == 0:
|
||||||
raise WinhttpException(GetLastError())
|
raise WinhttpException(GetLastError())
|
||||||
|
|
||||||
headers = self._update_header_cookie(self._getheaders(hRequest))
|
|
||||||
resp = Response()
|
resp = Response()
|
||||||
|
resp.headers, resp.cookies = self._parseheader2dict(self._getheaders(hRequest))
|
||||||
|
|
||||||
resp.status_code = self._getStatusCode(hRequest)
|
resp.status_code = self._getStatusCode(hRequest)
|
||||||
resp.headers = headers
|
|
||||||
resp.cookies = self.cookies
|
|
||||||
if stream:
|
if stream:
|
||||||
|
resp.hSession = hSession
|
||||||
resp.hconn = hConnect
|
resp.hconn = hConnect
|
||||||
resp.hreq = hRequest
|
resp.hreq = hRequest
|
||||||
resp.keepref = self
|
|
||||||
return resp
|
return resp
|
||||||
availableSize = DWORD()
|
availableSize = DWORD()
|
||||||
downloadedSize = DWORD()
|
downloadedSize = DWORD()
|
||||||
@ -219,7 +216,7 @@ class Session(Sessionbase):
|
|||||||
raise WinhttpException(GetLastError())
|
raise WinhttpException(GetLastError())
|
||||||
downloadeddata += buff[: downloadedSize.value]
|
downloadeddata += buff[: downloadedSize.value]
|
||||||
|
|
||||||
resp.content = self.decompress(downloadeddata, headers)
|
resp.content = self.decompress(downloadeddata, resp.headers)
|
||||||
|
|
||||||
return resp
|
return resp
|
||||||
|
|
||||||
@ -237,7 +234,5 @@ class Session(Sessionbase):
|
|||||||
data = decompress(data)
|
data = decompress(data)
|
||||||
return data
|
return data
|
||||||
except:
|
except:
|
||||||
|
print_exc()
|
||||||
raise Exception("unenable to decompress {}".format(encode))
|
raise Exception("unenable to decompress {}".format(encode))
|
||||||
|
|
||||||
|
|
||||||
Sessionimpl[0] = Session
|
|
@ -1,4 +1,4 @@
|
|||||||
from winhttp import *
|
from .winhttp import *
|
||||||
from urllib.parse import urlsplit
|
from urllib.parse import urlsplit
|
||||||
from ctypes import pointer, create_string_buffer
|
from ctypes import pointer, create_string_buffer
|
||||||
|
|
||||||
@ -156,9 +156,3 @@ class WebSocket:
|
|||||||
|
|
||||||
if self.hWebSocketHandle == 0:
|
if self.hWebSocketHandle == 0:
|
||||||
raise WinhttpException(GetLastError())
|
raise WinhttpException(GetLastError())
|
||||||
|
|
||||||
|
|
||||||
def create_connection(url, **x):
|
|
||||||
_ = WebSocket()
|
|
||||||
_.connect(url)
|
|
||||||
return _
|
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
from ctypes import windll, POINTER, pointer, Structure, sizeof
|
from ctypes import windll, POINTER, pointer, Structure, sizeof
|
||||||
from ctypes.wintypes import LPCWSTR, DWORD, LPVOID, WORD, BOOL, LPCVOID, LPWSTR, USHORT
|
from ctypes.wintypes import LPCWSTR, DWORD, LPVOID, WORD, BOOL, LPCVOID, LPWSTR, USHORT
|
||||||
from network.requests_common import NetWorkException
|
from requests import NetWorkException
|
||||||
|
|
||||||
|
|
||||||
class WinhttpException(NetWorkException):
|
class WinhttpException(NetWorkException):
|
||||||
|
@ -3,6 +3,7 @@ from collections.abc import Mapping, MutableMapping
|
|||||||
from collections import OrderedDict
|
from collections import OrderedDict
|
||||||
from urllib.parse import urlencode, urlsplit
|
from urllib.parse import urlencode, urlsplit
|
||||||
from functools import partial
|
from functools import partial
|
||||||
|
from myutils.config import globalconfig
|
||||||
|
|
||||||
|
|
||||||
class NetWorkException(Exception):
|
class NetWorkException(Exception):
|
||||||
@ -59,11 +60,10 @@ class CaseInsensitiveDict(MutableMapping):
|
|||||||
|
|
||||||
|
|
||||||
class ResponseBase:
|
class ResponseBase:
|
||||||
def __init__(self):
|
headers = CaseInsensitiveDict()
|
||||||
self.headers = CaseInsensitiveDict()
|
cookies = {}
|
||||||
self.cookies = {}
|
status_code = 0
|
||||||
self.status_code = 0
|
content = b""
|
||||||
self.content = b"{}"
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def text(self):
|
def text(self):
|
||||||
@ -118,9 +118,49 @@ class ResponseBase:
|
|||||||
yield pending
|
yield pending
|
||||||
|
|
||||||
|
|
||||||
class Sessionbase:
|
class Requester_common:
|
||||||
|
|
||||||
|
def request(self, *argc) -> ResponseBase: ...
|
||||||
|
|
||||||
|
def _parseheader(self, headers, cookies):
|
||||||
|
_x = []
|
||||||
|
|
||||||
|
if cookies:
|
||||||
|
cookie = self._parsecookie(cookies)
|
||||||
|
headers.update({"Cookie": cookie})
|
||||||
|
for k in sorted(headers.keys()):
|
||||||
|
_x.append("{}: {}".format(k, headers[k]))
|
||||||
|
return _x
|
||||||
|
|
||||||
|
def _parsecookie(self, cookie):
|
||||||
|
_c = []
|
||||||
|
for k, v in cookie.items():
|
||||||
|
_c.append("{}={}".format(k, v))
|
||||||
|
return "; ".join(_c)
|
||||||
|
|
||||||
|
def _parseheader2dict(self, headerstr):
|
||||||
|
# print(headerstr)
|
||||||
|
header = CaseInsensitiveDict()
|
||||||
|
cookie = {}
|
||||||
|
for line in headerstr.split("\r\n")[1:]:
|
||||||
|
idx = line.find(": ")
|
||||||
|
if idx == -1:
|
||||||
|
continue
|
||||||
|
if line[:idx].lower() == "set-cookie":
|
||||||
|
_c = line[idx + 2 :].split("; ")[0]
|
||||||
|
_idx = _c.find("=")
|
||||||
|
cookie[_c[:_idx]] = _c[_idx + 1 :]
|
||||||
|
else:
|
||||||
|
header[line[:idx]] = line[idx + 2 :]
|
||||||
|
return CaseInsensitiveDict(header), cookie
|
||||||
|
|
||||||
|
|
||||||
|
class Session:
|
||||||
def __init__(self) -> None:
|
def __init__(self) -> None:
|
||||||
|
self.requester = None
|
||||||
|
self.requester_type = None
|
||||||
self.UA = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"
|
self.UA = "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"
|
||||||
|
|
||||||
self.last_error = 0
|
self.last_error = 0
|
||||||
self.cookies = {}
|
self.cookies = {}
|
||||||
self.headers = CaseInsensitiveDict(
|
self.headers = CaseInsensitiveDict(
|
||||||
@ -211,45 +251,12 @@ class Sessionbase:
|
|||||||
url = scheme + "://" + server + path
|
url = scheme + "://" + server + path
|
||||||
return scheme, server, port, path, url
|
return scheme, server, port, path, url
|
||||||
|
|
||||||
def _parseheader(self, headers, cookies):
|
def loadrequester(self) -> Requester_common:
|
||||||
_x = []
|
if globalconfig["network"] == 1:
|
||||||
|
from network.libcurl.requester import Requester
|
||||||
if cookies:
|
elif globalconfig["network"] == 0:
|
||||||
cookie = self._parsecookie(cookies)
|
from network.winhttp.requester import Requester
|
||||||
headers.update({"Cookie": cookie})
|
return Requester()
|
||||||
for k in sorted(headers.keys()):
|
|
||||||
_x.append("{}: {}".format(k, headers[k]))
|
|
||||||
return _x
|
|
||||||
|
|
||||||
def _parsecookie(self, cookie):
|
|
||||||
_c = []
|
|
||||||
for k, v in cookie.items():
|
|
||||||
_c.append("{}={}".format(k, v))
|
|
||||||
return "; ".join(_c)
|
|
||||||
|
|
||||||
def _update_header_cookie(self, headerstr):
|
|
||||||
headers, cookies = self._parseheader2dict(headerstr)
|
|
||||||
self.cookies.update(cookies)
|
|
||||||
return headers
|
|
||||||
|
|
||||||
def _parseheader2dict(self, headerstr):
|
|
||||||
# print(headerstr)
|
|
||||||
header = CaseInsensitiveDict()
|
|
||||||
cookie = {}
|
|
||||||
for line in headerstr.split("\r\n")[1:]:
|
|
||||||
idx = line.find(": ")
|
|
||||||
if idx == -1:
|
|
||||||
continue
|
|
||||||
if line[:idx].lower() == "set-cookie":
|
|
||||||
_c = line[idx + 2 :].split("; ")[0]
|
|
||||||
_idx = _c.find("=")
|
|
||||||
cookie[_c[:_idx]] = _c[_idx + 1 :]
|
|
||||||
else:
|
|
||||||
header[line[:idx]] = line[idx + 2 :]
|
|
||||||
return CaseInsensitiveDict(header), cookie
|
|
||||||
|
|
||||||
def request_impl(self, *args):
|
|
||||||
pass
|
|
||||||
|
|
||||||
def request(
|
def request(
|
||||||
self,
|
self,
|
||||||
@ -298,7 +305,9 @@ class Sessionbase:
|
|||||||
except:
|
except:
|
||||||
print("Error invalid timeout", timeout)
|
print("Error invalid timeout", timeout)
|
||||||
timeout = None
|
timeout = None
|
||||||
_ = self.request_impl(
|
if cookies:
|
||||||
|
self.cookies.update(cookies)
|
||||||
|
response = self.loadrequester().request(
|
||||||
method,
|
method,
|
||||||
scheme,
|
scheme,
|
||||||
server,
|
server,
|
||||||
@ -306,7 +315,7 @@ class Sessionbase:
|
|||||||
param,
|
param,
|
||||||
url,
|
url,
|
||||||
headers,
|
headers,
|
||||||
cookies,
|
self.cookies,
|
||||||
dataptr,
|
dataptr,
|
||||||
datalen,
|
datalen,
|
||||||
proxy,
|
proxy,
|
||||||
@ -315,8 +324,9 @@ class Sessionbase:
|
|||||||
timeout,
|
timeout,
|
||||||
allow_redirects,
|
allow_redirects,
|
||||||
)
|
)
|
||||||
|
self.cookies.update(response.cookies)
|
||||||
return _
|
response.cookies.update(self.cookies)
|
||||||
|
return response
|
||||||
|
|
||||||
def get(self, url, **kwargs):
|
def get(self, url, **kwargs):
|
||||||
return self.request("GET", url, **kwargs)
|
return self.request("GET", url, **kwargs)
|
||||||
@ -334,16 +344,13 @@ class Sessionbase:
|
|||||||
return self.request("DELETE", url, **kwargs)
|
return self.request("DELETE", url, **kwargs)
|
||||||
|
|
||||||
|
|
||||||
Sessionimpl = [Sessionbase]
|
|
||||||
|
|
||||||
|
|
||||||
def request(method, url, **kwargs):
|
def request(method, url, **kwargs):
|
||||||
with Sessionimpl[0]() as session:
|
with Session() as session:
|
||||||
return session.request(method=method, url=url, **kwargs)
|
return session.request(method=method, url=url, **kwargs)
|
||||||
|
|
||||||
|
|
||||||
def session():
|
def session():
|
||||||
with Sessionimpl[0]() as session:
|
with Session() as session:
|
||||||
return session
|
return session
|
||||||
|
|
||||||
|
|
@ -2,7 +2,7 @@ from translator.basetranslator_dev import basetransdev
|
|||||||
|
|
||||||
|
|
||||||
class TS(basetransdev):
|
class TS(basetransdev):
|
||||||
target_url = "https://fanyi.baidu.com/mtpe-individual/multimodal#/"
|
target_url = "https://fanyi.baidu.com/mtpe-individual/multimodal"
|
||||||
|
|
||||||
def langmap(self):
|
def langmap(self):
|
||||||
return {
|
return {
|
||||||
@ -20,7 +20,7 @@ class TS(basetransdev):
|
|||||||
"""document.querySelector("#editor-text > div.AZLVLJHb > div.Ssl84aLh > span").click()"""
|
"""document.querySelector("#editor-text > div.AZLVLJHb > div.Ssl84aLh > span").click()"""
|
||||||
)
|
)
|
||||||
self.Runtime_evaluate(
|
self.Runtime_evaluate(
|
||||||
"""document.querySelector("#editor-text > div.AZLVLJHb > div.Ssl84aLh > div > div > div").click()"""
|
"""document.querySelector("#editor-text > div.AZLVLJHb > div.Ssl84aLh > div.NNh5PamB.GEptIbSX > div > div").click()"""
|
||||||
)
|
)
|
||||||
self.send_keys(content)
|
self.send_keys(content)
|
||||||
return self.wait_for_result(
|
return self.wait_for_result(
|
||||||
|
12
LunaTranslator/LunaTranslator/websocket.py
Normal file
12
LunaTranslator/LunaTranslator/websocket.py
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
from myutils.config import globalconfig
|
||||||
|
|
||||||
|
|
||||||
|
def create_connection(url, header=None, http_proxy_host=None, http_proxy_port=None):
|
||||||
|
if globalconfig["network"] == 1:
|
||||||
|
from network.libcurl.websocket import WebSocket
|
||||||
|
elif globalconfig["network"] == 0:
|
||||||
|
from network.winhttp.websocket import WebSocket
|
||||||
|
|
||||||
|
_ = WebSocket()
|
||||||
|
_.connect(url, header, http_proxy_host, http_proxy_port)
|
||||||
|
return _
|
@ -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 7)
|
set(VERSION_MINOR 8)
|
||||||
set(VERSION_PATCH 2)
|
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)
|
||||||
|
@ -38,7 +38,7 @@
|
|||||||
#include <mshtml.h>
|
#include <mshtml.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
#include <map>
|
||||||
#include <winbase.h>
|
#include <winbase.h>
|
||||||
#include <wincon.h>
|
#include <wincon.h>
|
||||||
|
|
||||||
|
@ -57,34 +57,25 @@ int wmain(int argc, wchar_t *argv[])
|
|||||||
if (checkisapatch())
|
if (checkisapatch())
|
||||||
return 1;
|
return 1;
|
||||||
auto argv0 = std::wstring(argv[1]);
|
auto argv0 = std::wstring(argv[1]);
|
||||||
if (argv0 == L"dllinject")
|
typedef int (*wmaint)(int, wchar_t **);
|
||||||
return dllinjectwmain(argc - 1, argv + 1);
|
std::map<std::wstring, wmaint> fm = {
|
||||||
if (argv0 == L"ntleas")
|
{L"dllinject", dllinjectwmain},
|
||||||
return ntleaswmain(argc - 1, argv + 1);
|
{L"ntleas", ntleaswmain},
|
||||||
if (argv0 == L"listpm")
|
{L"listpm", listprocessmodule},
|
||||||
return listprocessmodule(argc - 1, argv + 1);
|
{L"update", updatewmain},
|
||||||
if (argv0 == L"update")
|
|
||||||
return updatewmain(argc - 1, argv + 1);
|
|
||||||
#ifndef _WIN64
|
#ifndef _WIN64
|
||||||
else if (argv0 == L"mainmp3")
|
{L"mainmp3", mainmp3},
|
||||||
return mainmp3(argc - 1, argv + 1);
|
{L"LR", LRwmain},
|
||||||
else if (argv0 == L"LR")
|
{L"le", lewmain},
|
||||||
return LRwmain(argc - 1, argv + 1);
|
{L"jbj7", jbjwmain},
|
||||||
else if (argv0 == L"le")
|
{L"dreye", dreyewmain},
|
||||||
return lewmain(argc - 1, argv + 1);
|
{L"kingsoft", kingsoftwmain},
|
||||||
else if (argv0 == L"jbj7")
|
{L"voiceroid2", voiceroid2wmain},
|
||||||
return jbjwmain(argc - 1, argv + 1);
|
{L"neospeech", neospeech},
|
||||||
else if (argv0 == L"dreye")
|
{L"neospeechlist", neospeechlist},
|
||||||
return dreyewmain(argc - 1, argv + 1);
|
|
||||||
else if (argv0 == L"kingsoft")
|
|
||||||
return kingsoftwmain(argc - 1, argv + 1);
|
|
||||||
else if (argv0 == L"voiceroid2")
|
|
||||||
return voiceroid2wmain(argc - 1, argv + 1);
|
|
||||||
else if (argv0 == L"neospeech")
|
|
||||||
return neospeech(argc - 1, argv + 1);
|
|
||||||
else if (argv0 == L"neospeechlist")
|
|
||||||
return neospeechlist(argc - 1, argv + 1);
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#endif // !_WIN64
|
#endif // !_WIN64
|
||||||
|
};
|
||||||
|
return fm[argv0](argc - 1, argv + 1);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user