ensure all multiaddress routines use Result

This commit is contained in:
Giovanni Petrantoni 2020-10-30 23:50:04 +09:00
parent 75b023c9e5
commit 3d9948a65e

View File

@ -841,7 +841,7 @@ proc init*(mtype: typedesc[MultiAddress]): MultiAddress =
proc init*(mtype: typedesc[MultiAddress], proc init*(mtype: typedesc[MultiAddress],
address: ValidIpAddress, address: ValidIpAddress,
protocol: IpTransportProtocol, protocol: IpTransportProtocol,
port: Port): MultiAddress = port: Port): MaResult[MultiAddress] =
let let
familyProto = case address.family familyProto = case address.family
of IpAddressFamily.IPv4: getProtocol("ip4") of IpAddressFamily.IPv4: getProtocol("ip4")
@ -854,15 +854,17 @@ proc init*(mtype: typedesc[MultiAddress],
var data = initVBuffer() var data = initVBuffer()
data.write(familyProto.mcodec) data.write(familyProto.mcodec)
var written = familyProto.coder.stringToBuffer($address, data) var written = familyProto.coder.stringToBuffer($address, data)
doAssert written, if not written:
"Merely writing a string to a buffer should always be possible, address: " & $address return err("multiaddress: Merely writing a string to a buffer should always be possible, address")
data.write(protoProto.mcodec) data.write(protoProto.mcodec)
written = protoProto.coder.stringToBuffer($port, data) written = protoProto.coder.stringToBuffer($port, data)
doAssert written, if not written:
"Merely writing a string to a buffer should always be possible, port: " & $address return err("multiaddress: Merely writing a string to a buffer should always be possible, port")
data.finish() data.finish()
MultiAddress(data: data) ok(MultiAddress(data: data))
proc init*(mtype: typedesc[MultiAddress], address: TransportAddress, proc init*(mtype: typedesc[MultiAddress], address: TransportAddress,
protocol = IPPROTO_TCP): MaResult[MultiAddress] = protocol = IPPROTO_TCP): MaResult[MultiAddress] =