diff --git a/sdk/objc/api/peerconnection/RTCStatisticsReport.mm b/sdk/objc/api/peerconnection/RTCStatisticsReport.mm index bfe2424553..eaf2097cce 100644 --- a/sdk/objc/api/peerconnection/RTCStatisticsReport.mm +++ b/sdk/objc/api/peerconnection/RTCStatisticsReport.mm @@ -17,105 +17,91 @@ namespace webrtc { /** Converts a single value to a suitable NSNumber, NSString or NSArray containing NSNumbers or NSStrings, or NSDictionary of NSString keys to NSNumber values.*/ -NSObject *ValueFromStatsMember(const RTCStatsMemberInterface *member) { - if (member->is_defined()) { - switch (member->type()) { - case RTCStatsMemberInterface::kBool: - return [NSNumber numberWithBool:*member->cast_to>()]; - case RTCStatsMemberInterface::kInt32: - return [NSNumber numberWithInt:*member->cast_to>()]; - case RTCStatsMemberInterface::kUint32: - return [NSNumber numberWithUnsignedInt:*member->cast_to>()]; - case RTCStatsMemberInterface::kInt64: - return [NSNumber numberWithLong:*member->cast_to>()]; - case RTCStatsMemberInterface::kUint64: - return [NSNumber numberWithUnsignedLong:*member->cast_to>()]; - case RTCStatsMemberInterface::kDouble: - return [NSNumber numberWithDouble:*member->cast_to>()]; - case RTCStatsMemberInterface::kString: - return [NSString stringForStdString:*member->cast_to>()]; - case RTCStatsMemberInterface::kSequenceBool: { - std::vector sequence = *member->cast_to>>(); - NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; - for (auto item : sequence) { - [array addObject:[NSNumber numberWithBool:item]]; - } - return [array copy]; - } - case RTCStatsMemberInterface::kSequenceInt32: { - std::vector sequence = *member->cast_to>>(); - NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; - for (const auto &item : sequence) { - [array addObject:[NSNumber numberWithInt:item]]; - } - return [array copy]; - } - case RTCStatsMemberInterface::kSequenceUint32: { - std::vector sequence = *member->cast_to>>(); - NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; - for (const auto &item : sequence) { - [array addObject:[NSNumber numberWithUnsignedInt:item]]; - } - return [array copy]; - } - case RTCStatsMemberInterface::kSequenceInt64: { - std::vector sequence = *member->cast_to>>(); - NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; - for (const auto &item : sequence) { - [array addObject:[NSNumber numberWithLong:item]]; - } - return [array copy]; - } - case RTCStatsMemberInterface::kSequenceUint64: { - std::vector sequence = *member->cast_to>>(); - NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; - for (const auto &item : sequence) { - [array addObject:[NSNumber numberWithUnsignedLong:item]]; - } - return [array copy]; - } - case RTCStatsMemberInterface::kSequenceDouble: { - std::vector sequence = *member->cast_to>>(); - NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; - for (const auto &item : sequence) { - [array addObject:[NSNumber numberWithDouble:item]]; - } - return [array copy]; - } - case RTCStatsMemberInterface::kSequenceString: { - std::vector sequence = - *member->cast_to>>(); - NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; - for (const auto &item : sequence) { - [array addObject:[NSString stringForStdString:item]]; - } - return [array copy]; - } - case RTCStatsMemberInterface::kMapStringUint64: { - std::map map = - *member->cast_to>>(); - NSMutableDictionary *dictionary = - [NSMutableDictionary dictionaryWithCapacity:map.size()]; - for (const auto &item : map) { - dictionary[[NSString stringForStdString:item.first]] = @(item.second); - } - return [dictionary copy]; - } - case RTCStatsMemberInterface::kMapStringDouble: { - std::map map = - *member->cast_to>>(); - NSMutableDictionary *dictionary = - [NSMutableDictionary dictionaryWithCapacity:map.size()]; - for (const auto &item : map) { - dictionary[[NSString stringForStdString:item.first]] = @(item.second); - } - return [dictionary copy]; - } - default: - RTC_DCHECK_NOTREACHED(); - } +NSObject *ValueFromStatsAttribute(const Attribute &attribute) { + if (!attribute.has_value()) { + return nil; } - + if (attribute.holds_alternative()) { + return [NSNumber numberWithBool:attribute.get()]; + } else if (attribute.holds_alternative()) { + return [NSNumber numberWithInt:attribute.get()]; + } else if (attribute.holds_alternative()) { + return [NSNumber numberWithUnsignedInt:attribute.get()]; + } else if (attribute.holds_alternative()) { + return [NSNumber numberWithLong:attribute.get()]; + } else if (attribute.holds_alternative()) { + return [NSNumber numberWithUnsignedLong:attribute.get()]; + } else if (attribute.holds_alternative()) { + return [NSNumber numberWithDouble:attribute.get()]; + } else if (attribute.holds_alternative()) { + return [NSString stringForStdString:attribute.get()]; + } else if (attribute.holds_alternative>()) { + std::vector sequence = attribute.get>(); + NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; + for (auto item : sequence) { + [array addObject:[NSNumber numberWithBool:item]]; + } + return [array copy]; + } else if (attribute.holds_alternative>()) { + std::vector sequence = attribute.get>(); + NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; + for (const auto &item : sequence) { + [array addObject:[NSNumber numberWithInt:item]]; + } + return [array copy]; + } else if (attribute.holds_alternative>()) { + std::vector sequence = attribute.get>(); + NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; + for (const auto &item : sequence) { + [array addObject:[NSNumber numberWithUnsignedInt:item]]; + } + return [array copy]; + } else if (attribute.holds_alternative>()) { + std::vector sequence = attribute.get>(); + NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; + for (const auto &item : sequence) { + [array addObject:[NSNumber numberWithLong:item]]; + } + return [array copy]; + } else if (attribute.holds_alternative>()) { + std::vector sequence = attribute.get>(); + NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; + for (const auto &item : sequence) { + [array addObject:[NSNumber numberWithUnsignedLong:item]]; + } + return [array copy]; + } else if (attribute.holds_alternative>()) { + std::vector sequence = attribute.get>(); + NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; + for (const auto &item : sequence) { + [array addObject:[NSNumber numberWithDouble:item]]; + } + return [array copy]; + } else if (attribute.holds_alternative>()) { + std::vector sequence = attribute.get>(); + NSMutableArray *array = [NSMutableArray arrayWithCapacity:sequence.size()]; + for (const auto &item : sequence) { + [array addObject:[NSString stringForStdString:item]]; + } + return [array copy]; + } else if (attribute.holds_alternative>()) { + std::map map = attribute.get>(); + NSMutableDictionary *dictionary = + [NSMutableDictionary dictionaryWithCapacity:map.size()]; + for (const auto &item : map) { + dictionary[[NSString stringForStdString:item.first]] = @(item.second); + } + return [dictionary copy]; + } else if (attribute.holds_alternative>()) { + std::map map = attribute.get>(); + NSMutableDictionary *dictionary = + [NSMutableDictionary dictionaryWithCapacity:map.size()]; + for (const auto &item : map) { + dictionary[[NSString stringForStdString:item.first]] = @(item.second); + } + return [dictionary copy]; + } + RTC_DCHECK_NOTREACHED(); return nil; } } // namespace webrtc @@ -134,10 +120,11 @@ NSObject *ValueFromStatsMember(const RTCStatsMemberInterface *member) { _type = [NSString stringWithCString:statistics.type() encoding:NSUTF8StringEncoding]; NSMutableDictionary *values = [NSMutableDictionary dictionary]; - for (const webrtc::RTCStatsMemberInterface *member : statistics.Members()) { - NSObject *value = ValueFromStatsMember(member); + for (const auto &attribute : statistics.Attributes()) { + NSObject *value = ValueFromStatsAttribute(attribute); if (value) { - NSString *name = [NSString stringWithCString:member->name() encoding:NSUTF8StringEncoding]; + NSString *name = [NSString stringWithCString:attribute.name() + encoding:NSUTF8StringEncoding]; RTC_DCHECK(name.length > 0); RTC_DCHECK(!values[name]); values[name] = value;