/* * Copyright (c) 2021 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #include "net/dcsctp/testing/data_generator.h" #include #include #include #include #include "absl/strings/string_view.h" #include "net/dcsctp/packet/data.h" #include "net/dcsctp/public/types.h" namespace dcsctp { constexpr PPID kPpid = PPID(53); Data DataGenerator::Ordered(std::vector payload, absl::string_view flags, const DataGeneratorOptions opts) { Data::IsBeginning is_beginning(flags.find('B') != std::string::npos); Data::IsEnd is_end(flags.find('E') != std::string::npos); if (is_beginning) { fsn_ = FSN(0); } else { fsn_ = FSN(*fsn_ + 1); } MID mid = opts.mid.value_or(mid_); Data ret = Data(opts.stream_id, SSN(static_cast(*mid)), mid, fsn_, opts.ppid, std::move(payload), is_beginning, is_end, IsUnordered(false)); if (is_end) { mid_ = MID(*mid + 1); } return ret; } Data DataGenerator::Unordered(std::vector payload, absl::string_view flags, const DataGeneratorOptions opts) { Data::IsBeginning is_beginning(flags.find('B') != std::string::npos); Data::IsEnd is_end(flags.find('E') != std::string::npos); if (is_beginning) { fsn_ = FSN(0); } else { fsn_ = FSN(*fsn_ + 1); } MID mid = opts.mid.value_or(mid_); Data ret = Data(opts.stream_id, SSN(0), mid, fsn_, kPpid, std::move(payload), is_beginning, is_end, IsUnordered(true)); if (is_end) { mid_ = MID(*mid + 1); } return ret; } } // namespace dcsctp