mirror of
git://xwords.git.sourceforge.net/gitroot/xwords/xwords
synced 2025-01-22 07:28:16 +01:00
use ! with struct instead of ntohs
This commit is contained in:
parent
4c15723f90
commit
4583b5d88d
1 changed files with 9 additions and 28 deletions
|
@ -36,7 +36,7 @@ def post(req, params, timeoutSecs = 1):
|
||||||
return json.dumps(jobj)
|
return json.dumps(jobj)
|
||||||
|
|
||||||
def query(req, ids):
|
def query(req, ids):
|
||||||
print(ids)
|
print('ids', ids)
|
||||||
ids = json.loads(ids)
|
ids = json.loads(ids)
|
||||||
|
|
||||||
idsLen = 0
|
idsLen = 0
|
||||||
|
@ -47,29 +47,25 @@ def query(req, ids):
|
||||||
sock.connect(('127.0.0.1', 10998))
|
sock.connect(('127.0.0.1', 10998))
|
||||||
|
|
||||||
lenShort = 2 + idsLen + len(ids) + 1
|
lenShort = 2 + idsLen + len(ids) + 1
|
||||||
sock.send(struct.pack("hBBh", socket.htons(lenShort),
|
print(lenShort, PROTOCOL_VERSION, PRX_GET_MSGS, len(ids))
|
||||||
PROTOCOL_VERSION, PRX_GET_MSGS,
|
header = struct.Struct("!hBBh")
|
||||||
socket.htons(len(ids))))
|
assert header.size == 6
|
||||||
|
sock.send(header.pack(lenShort, PROTOCOL_VERSION, PRX_GET_MSGS, len(ids)))
|
||||||
|
|
||||||
for id in ids: sock.send(id + '\n')
|
for id in ids: sock.send(id + '\n')
|
||||||
|
|
||||||
unpacker = struct.Struct('2H') # 2s f')
|
unpacker = struct.Struct('!2H') # 2s f')
|
||||||
data = sock.recv(unpacker.size)
|
resLen, nameCount = unpacker.unpack(sock.recv(unpacker.size)) # problem when ids empty
|
||||||
resLen, nameCount = unpacker.unpack(data)
|
|
||||||
resLen = socket.ntohs(resLen)
|
|
||||||
nameCount = socket.ntohs(nameCount)
|
|
||||||
print('resLen:', resLen, 'nameCount:', nameCount)
|
print('resLen:', resLen, 'nameCount:', nameCount)
|
||||||
msgsLists = {}
|
msgsLists = {}
|
||||||
if nameCount == len(ids):
|
if nameCount == len(ids):
|
||||||
for ii in range(nameCount):
|
for ii in range(nameCount):
|
||||||
perGame = []
|
perGame = []
|
||||||
shortUnpacker = struct.Struct('H')
|
shortUnpacker = struct.Struct('!H')
|
||||||
countsThisGame, = shortUnpacker.unpack(sock.recv(shortUnpacker.size))
|
countsThisGame, = shortUnpacker.unpack(sock.recv(shortUnpacker.size)) # problem
|
||||||
countsThisGame = socket.ntohs(countsThisGame)
|
|
||||||
print('countsThisGame:', countsThisGame)
|
print('countsThisGame:', countsThisGame)
|
||||||
for jj in range(countsThisGame):
|
for jj in range(countsThisGame):
|
||||||
msgLen, = shortUnpacker.unpack(sock.recv(shortUnpacker.size))
|
msgLen, = shortUnpacker.unpack(sock.recv(shortUnpacker.size))
|
||||||
msgLen = socket.ntohs(msgLen)
|
|
||||||
print('msgLen:', msgLen)
|
print('msgLen:', msgLen)
|
||||||
msgs = []
|
msgs = []
|
||||||
if msgLen > 0:
|
if msgLen > 0:
|
||||||
|
@ -82,21 +78,6 @@ def query(req, ids):
|
||||||
|
|
||||||
return json.dumps(msgsLists)
|
return json.dumps(msgsLists)
|
||||||
|
|
||||||
# received = sock.recv(1024*4)
|
|
||||||
# print('len:', len(received))
|
|
||||||
# short resLen = dis.readShort(); // total message length
|
|
||||||
# short nameCount = dis.readShort();
|
|
||||||
|
|
||||||
|
|
||||||
def dosend(sock, bytes):
|
|
||||||
totalsent = 0
|
|
||||||
while totalsent < len(bytes):
|
|
||||||
sent = sock.send(bytes[totalsent:])
|
|
||||||
if sent == 0:
|
|
||||||
raise RuntimeError("socket connection broken")
|
|
||||||
totalsent = totalsent + sent
|
|
||||||
|
|
||||||
|
|
||||||
def main():
|
def main():
|
||||||
print(query(None, json.dumps(sys.argv[1:])))
|
print(query(None, json.dumps(sys.argv[1:])))
|
||||||
# Params = { 'data' : 'V2VkIE9jdCAxOCAwNjowNDo0OCBQRFQgMjAxNwo=' }
|
# Params = { 'data' : 'V2VkIE9jdCAxOCAwNjowNDo0OCBQRFQgMjAxNwo=' }
|
||||||
|
|
Loading…
Reference in a new issue