本文整理匯總了Python中pyasn1.compat.octets.int2oct方法的典型用法代碼示例。如果您正苦於以下問題:Python octets.int2oct方法的具體用法?Python octets.int2oct怎麽用?Python octets.int2oct使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類pyasn1.compat.octets
的用法示例。
在下文中一共展示了octets.int2oct方法的9個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: encodeValue
# 需要導入模塊: from pyasn1.compat import octets [as 別名]
# 或者: from pyasn1.compat.octets import int2oct [as 別名]
def encodeValue(self, encodeFun, value, defMode, maxChunkSize):
if not maxChunkSize or len(value) <= maxChunkSize*8:
out_len = (len(value) + 7) // 8
out_list = out_len * [0]
j = 7
i = -1
for val in value:
j += 1
if j == 8:
i += 1
j = 0
out_list[i] = out_list[i] | val << (7-j)
return int2oct(7-j) + ints2octs(out_list), 0
else:
pos = 0; substrate = null
while 1:
# count in octets
v = value.clone(value[pos*8:pos*8+maxChunkSize*8])
if not v:
break
substrate = substrate + encodeFun(v, defMode, maxChunkSize)
pos = pos + maxChunkSize
return substrate, 1
示例2: encodeValue
# 需要導入模塊: from pyasn1.compat import octets [as 別名]
# 或者: from pyasn1.compat.octets import int2oct [as 別名]
def encodeValue(self, encodeFun, value, defMode, maxChunkSize):
if not maxChunkSize or len(value) <= maxChunkSize * 8:
out_len = (len(value) + 7) // 8
out_list = out_len * [0]
j = 7
i = -1
for val in value:
j += 1
if j == 8:
i += 1
j = 0
out_list[i] |= val << (7 - j)
return int2oct(7 - j) + ints2octs(out_list), 0
else:
pos = 0
substrate = null
while True:
# count in octets
v = value.clone(value[pos * 8:pos * 8 + maxChunkSize * 8])
if not v:
break
substrate = substrate + encodeFun(v, defMode, maxChunkSize)
pos += maxChunkSize
return substrate, 1
示例3: encodeValue
# 需要導入模塊: from pyasn1.compat import octets [as 別名]
# 或者: from pyasn1.compat.octets import int2oct [as 別名]
def encodeValue(self, encodeFun, value, defMode, maxChunkSize):
if not maxChunkSize or len(value) <= maxChunkSize*8:
r = {}; l = len(value); p = 0; j = 7
while p < l:
i, j = divmod(p, 8)
r[i] = r.get(i,0) | value[p]<<(7-j)
p = p + 1
keys = list(r); keys.sort()
return int2oct(7-j) + ints2octs([r[k] for k in keys]), 0
else:
pos = 0; substrate = null
while 1:
# count in octets
v = value.clone(value[pos*8:pos*8+maxChunkSize*8])
if not v:
break
substrate = substrate + encodeFun(v, defMode, maxChunkSize)
pos = pos + maxChunkSize
return substrate, 1
示例4: encodeValue
# 需要導入模塊: from pyasn1.compat import octets [as 別名]
# 或者: from pyasn1.compat.octets import int2oct [as 別名]
def encodeValue(self, value, encodeFun, **options):
valueLength = len(value)
if valueLength % 8:
alignedValue = value << (8 - valueLength % 8)
else:
alignedValue = value
maxChunkSize = options.get('maxChunkSize', 0)
if not maxChunkSize or len(alignedValue) <= maxChunkSize * 8:
substrate = alignedValue.asOctets()
return int2oct(len(substrate) * 8 - valueLength) + substrate, False, True
# strip off explicit tags
alignedValue = alignedValue.clone(
tagSet=tag.TagSet(value.tagSet.baseTag, value.tagSet.baseTag)
)
stop = 0
substrate = null
while stop < valueLength:
start = stop
stop = min(start + maxChunkSize * 8, valueLength)
substrate += encodeFun(alignedValue[start:stop], **options)
return substrate, True, True
示例5: encodeTag
# 需要導入模塊: from pyasn1.compat import octets [as 別名]
# 或者: from pyasn1.compat.octets import int2oct [as 別名]
def encodeTag(self, t, isConstructed):
tagClass, tagFormat, tagId = t.asTuple() # this is a hotspot
v = tagClass | tagFormat
if isConstructed:
v = v|tag.tagFormatConstructed
if tagId < 31:
return int2oct(v|tagId)
else:
s = int2oct(tagId&0x7f)
tagId = tagId >> 7
while tagId:
s = int2oct(0x80|(tagId&0x7f)) + s
tagId = tagId >> 7
return int2oct(v|0x1F) + s
示例6: encodeLength
# 需要導入模塊: from pyasn1.compat import octets [as 別名]
# 或者: from pyasn1.compat.octets import int2oct [as 別名]
def encodeLength(self, length, defMode):
if not defMode and self.supportIndefLenMode:
return int2oct(0x80)
if length < 0x80:
return int2oct(length)
else:
substrate = null
while length:
substrate = int2oct(length&0xff) + substrate
length = length >> 8
substrateLen = len(substrate)
if substrateLen > 126:
raise Error('Length octets overflow (%d)' % substrateLen)
return int2oct(0x80 | substrateLen) + substrate
示例7: encodeValue
# 需要導入模塊: from pyasn1.compat import octets [as 別名]
# 或者: from pyasn1.compat.octets import int2oct [as 別名]
def encodeValue(self, encodeFun, client, defMode, maxChunkSize):
if client == 0:
substrate = int2oct(0)
else:
substrate = int2oct(255)
return substrate, 0
示例8: encodeTag
# 需要導入模塊: from pyasn1.compat import octets [as 別名]
# 或者: from pyasn1.compat.octets import int2oct [as 別名]
def encodeTag(self, t, isConstructed):
tagClass, tagFormat, tagId = t.asTuple() # this is a hotspot
v = tagClass | tagFormat
if isConstructed:
v = v | tag.tagFormatConstructed
if tagId < 31:
return int2oct(v | tagId)
else:
s = int2oct(tagId & 0x7f)
tagId >>= 7
while tagId:
s = int2oct(0x80 | (tagId & 0x7f)) + s
tagId >>= 7
return int2oct(v | 0x1F) + s
示例9: encodeLength
# 需要導入模塊: from pyasn1.compat import octets [as 別名]
# 或者: from pyasn1.compat.octets import int2oct [as 別名]
def encodeLength(self, length, defMode):
if not defMode and self.supportIndefLenMode:
return int2oct(0x80)
if length < 0x80:
return int2oct(length)
else:
substrate = null
while length:
substrate = int2oct(length & 0xff) + substrate
length >>= 8
substrateLen = len(substrate)
if substrateLen > 126:
raise error.PyAsn1Error('Length octets overflow (%d)' % substrateLen)
return int2oct(0x80 | substrateLen) + substrate