本文整理匯總了Python中marshal.dumps方法的典型用法代碼示例。如果您正苦於以下問題:Python marshal.dumps方法的具體用法?Python marshal.dumps怎麽用?Python marshal.dumps使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類marshal
的用法示例。
在下文中一共展示了marshal.dumps方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: run_code
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def run_code(self, function, *args, **kwargs):
log.debug("%s() args:%s kwargs:%s on target", function.func_name, args, kwargs)
data = {"cmd":self.CODE,
"code":marshal.dumps(function.func_code),
"name":function.func_name,
"args":args,
"kwargs":kwargs,
"defaults":function.__defaults__,
"closure":function.__closure__}
self.send_data(data)
log.debug("waiting for code to execute...")
data = self.recv_data()
if data["cmd"] == self.EXCEPT:
log.debug("received exception")
raise self._process_target_except(data)
assert data["cmd"] == self.RETURN
return data["value"]
示例2: forked_run_report
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def forked_run_report(item):
# for now, we run setup/teardown in the subprocess
# XXX optionally allow sharing of setup/teardown
from _pytest.runner import runtestprotocol
EXITSTATUS_TESTEXIT = 4
import marshal
def runforked():
try:
reports = runtestprotocol(item, log=False)
except KeyboardInterrupt:
os._exit(EXITSTATUS_TESTEXIT)
return marshal.dumps([serialize_report(x) for x in reports])
ff = py.process.ForkedFunc(runforked)
result = ff.waitfinish()
if result.retval is not None:
report_dumps = marshal.loads(result.retval)
return [runner.TestReport(**x) for x in report_dumps]
else:
if result.exitstatus == EXITSTATUS_TESTEXIT:
pytest.exit("forked test item %s raised Exit" % (item,))
return [report_process_crash(item, result)]
示例3: _write_pyc
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def _write_pyc(state, co, source_stat, pyc):
# Technically, we don't have to have the same pyc format as
# (C)Python, since these "pycs" should never be seen by builtin
# import. However, there's little reason deviate.
try:
with atomicwrites.atomic_write(pyc, mode="wb", overwrite=True) as fp:
fp.write(importlib.util.MAGIC_NUMBER)
# as of now, bytecode header expects 32-bit numbers for size and mtime (#4903)
mtime = int(source_stat.st_mtime) & 0xFFFFFFFF
size = source_stat.st_size & 0xFFFFFFFF
# "<LL" stands for 2 unsigned longs, little-ending
fp.write(struct.pack("<LL", mtime, size))
fp.write(marshal.dumps(co))
except EnvironmentError as e:
state.trace("error writing pyc file at {}: errno={}".format(pyc, e.errno))
# we ignore any failure to write the cache file
# there are many reasons, permission-denied, __pycache__ being a
# file etc.
return False
return True
示例4: func_dump
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def func_dump(func):
"""Serializes a user defined function.
Arguments:
func: the function to serialize.
Returns:
A tuple `(code, defaults, closure)`.
"""
code = marshal.dumps(func.__code__).decode('raw_unicode_escape')
defaults = func.__defaults__
if func.__closure__:
closure = tuple(c.cell_contents for c in func.__closure__)
else:
closure = None
return code, defaults, closure
示例5: test_file_multiple_reads
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def test_file_multiple_reads(self):
"""calling load w/ a file should only advance the length of the file"""
l = []
for i in xrange(10):
l.append(marshal.dumps({i:i}))
data = ''.join(l)
with open('tempfile.txt', 'w') as f:
f.write(data)
with open('tempfile.txt') as f:
for i in xrange(10):
obj = marshal.load(f)
self.assertEqual(obj, {i:i})
self.delete_files('tempfile.txt')
示例6: convert_pyc_file
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def convert_pyc_file(to_opcodes, pyc_file):
pyc_code_obj_in = unmarshal_pyc_code(pyc_file)
# recursively look for code objects
# should also rebuild code object
code_object_out = recurse_convert_code_objects(pyc_code_obj_in, to_opcodes)
magic = '\x03\xf3\x0d\x0a' # 62211 version
time = '\x00'*4
new_pyc_out = magic + time + marshal.dumps(code_object_out)
filename = os.path.basename(pyc_code_obj_in.co_filename)
filename = filename.replace(".pyc", "_converted.pyc")
output_filename = os.path.dirname(pyc_file) + "\\" + filename
with open(output_filename, 'wb') as f:
f.write(new_pyc_out)
return output_filename
示例7: send_rpc_request
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def send_rpc_request(sock, req_obj, unknown):
marsh = marshal.dumps(req_obj) # python object
# build out the header
header = "\x78\x01\x01" + struct.pack('<h', len(marsh))
header += chr(unknown) # not sure exactly what this is
header += "\xff"
# add the ADLER32 checksum
checksum = struct.pack('>i', zlib.adler32(marsh))
post_data = header + marsh + checksum
message = build_post(post_data)
try:
sock.send(message)
resp = sock.recv(1024)
if resp is None:
print("Did not receive a response from server.")
except Exception as e:
print("Error with request:")
print(e)
示例8: send_rpc_request
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def send_rpc_request(sock, req_obj, unknown):
marsh = marshal.dumps(req_obj) # python object
# build out the header
header = "\x78\x01\x01" + struct.pack('<h', len(marsh))
header += chr(unknown) # not sure exactly what this is
header += "\xff"
# add the ADLER32 checksum
checksum = struct.pack('>i', zlib.adler32(marsh))
post_data = header + marsh + checksum
message = build_post(post_data)
try:
sock.send(message)
#print("Sent request.")
resp = sock.recv(1024)
if resp is None:
print("Did not receive a response from server.")
except Exception as e:
print("Error with request:")
print(e)
示例9: func_dump
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def func_dump(func):
"""Serializes a user defined function.
# Arguments
func: the function to serialize.
# Returns
A tuple `(code, defaults, closure)`.
"""
raw_code = marshal.dumps(func.__code__)
code = codecs.encode(raw_code, 'base64').decode('ascii')
defaults = func.__defaults__
if func.__closure__:
closure = tuple(c.cell_contents for c in func.__closure__)
else:
closure = None
return code, defaults, closure
示例10: putmessage
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def putmessage(self, message):
self.debug("putmessage:%d:" % message[0])
try:
s = pickle.dumps(message)
except pickle.PicklingError:
print >>sys.__stderr__, "Cannot pickle:", repr(message)
raise
s = struct.pack("<i", len(s)) + s
while len(s) > 0:
try:
r, w, x = select.select([], [self.sock], [])
n = self.sock.send(s[:BUFSIZE])
except (AttributeError, TypeError):
raise IOError, "socket no longer exists"
except socket.error:
raise
else:
s = s[n:]
示例11: send_data
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def send_data(self, data):
is_ack = (data["cmd"] == self.ACK)
data = pickle.dumps(data, pickle.HIGHEST_PROTOCOL)
data_len = len(data)
assert data_len < 0xFFFFFFFF, "Transfer too large!"
log.debug("-> sending %d bytes", data_len)
self.conn.sendall(struct.pack("I", data_len))
self.conn.sendall(data)
if not is_ack:
assert self.recv_data()["cmd"] == self.ACK
log.debug("ACK received")
示例12: __init__
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def __init__(self, function):
#print(function.__closure__)
self.func_code = marshal.dumps(function.func_code)
示例13: marshal_dump
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def marshal_dump(code, f):
if isinstance(f, file):
marshal.dump(code, f)
else:
f.write(marshal.dumps(code))
示例14: _child
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def _child(self, nice_level, child_on_start, child_on_exit):
# right now we need to call a function, but first we need to
# map all IO that might happen
sys.stdout = stdout = get_unbuffered_io(1, self.STDOUT)
sys.stderr = stderr = get_unbuffered_io(2, self.STDERR)
retvalf = self.RETVAL.open("wb")
EXITSTATUS = 0
try:
if nice_level:
os.nice(nice_level)
try:
if child_on_start is not None:
child_on_start()
retval = self.fun(*self.args, **self.kwargs)
retvalf.write(marshal.dumps(retval))
if child_on_exit is not None:
child_on_exit()
except:
excinfo = py.code.ExceptionInfo()
stderr.write(str(excinfo._getreprcrash()))
EXITSTATUS = self.EXITSTATUS_EXCEPTION
finally:
stdout.close()
stderr.close()
retvalf.close()
os.close(1)
os.close(2)
os._exit(EXITSTATUS)
示例15: _compile
# 需要導入模塊: import marshal [as 別名]
# 或者: from marshal import dumps [as 別名]
def _compile(*filenames: str):
for filename in filenames:
code = compile_ex_python_from_filename(filename)
timestamp = struct.pack('i', int(time.time()))
marshalled_code_object = marshal.dumps(code)
filename, ext = os.path.splitext(filename)
filename = filename + '.pyc'
with Path(filename).open('wb') as f:
f.write(MAGIC_NUMBER)
f.write(timestamp)
f.write(b'A\x00\x00\x00')
f.write(marshalled_code_object)