From b832ac858c680a69f9da8a5f1b08b3ab5dd1c652 Mon Sep 17 00:00:00 2001 From: shogo4405 Date: Wed, 2 Oct 2024 02:41:24 +0900 Subject: [PATCH] TS packet compatibility has been improved. --- Sources/ISO/PacketizedElementaryStream.swift | 28 ++++--------------- Sources/ISO/TSField.swift | 2 +- Sources/ISO/TSPacket.swift | 19 ++++++++----- .../ISO/PacketizedElementaryStreamTests.swift | 11 ++++++-- 4 files changed, 28 insertions(+), 32 deletions(-) diff --git a/Sources/ISO/PacketizedElementaryStream.swift b/Sources/ISO/PacketizedElementaryStream.swift index 9f3341dcf..2eeb2b8d5 100644 --- a/Sources/ISO/PacketizedElementaryStream.swift +++ b/Sources/ISO/PacketizedElementaryStream.swift @@ -270,13 +270,13 @@ struct PacketizedElementaryStream: PESPacketHeader { } func arrayOfPackets(_ PID: UInt16, PCR: UInt64?) -> [TSPacket] { - let payload: Data = self.payload + let payload = self.payload var packets: [TSPacket] = [] // start var packet = TSPacket() packet.pid = PID - if let PCR: UInt64 = PCR { + if let PCR { packet.adaptationFieldFlag = true packet.adaptationField = TSAdaptationField() packet.adaptationField?.pcrFlag = true @@ -284,11 +284,11 @@ struct PacketizedElementaryStream: PESPacketHeader { packet.adaptationField?.compute() } packet.payloadUnitStartIndicator = true - let position: Int = packet.fill(payload, useAdaptationField: true) + let position = packet.fill(payload, useAdaptationField: true) packets.append(packet) // middle - let r: Int = (payload.count - position) % 184 + let r = (payload.count - position) % 184 for index in stride(from: payload.startIndex.advanced(by: position), to: payload.endIndex.advanced(by: -r), by: 184) { var packet = TSPacket() packet.pid = PID @@ -300,28 +300,12 @@ struct PacketizedElementaryStream: PESPacketHeader { switch r { case 0: break - case 183: - let remain: Data = payload.subdata(in: payload.endIndex - r.. Int { - guard let data: Data = data else { + guard let data else { payload.append(Data(repeating: 0xff, count: remain)) return 0 } payloadFlag = true - let length: Int = min(data.count, remain, 182) + let length = min(data.count, remain, 183) payload.append(data[0..