Use string_view when adding nodes/generators #cleanup
PiperOrigin-RevId: 480721234
This commit is contained in:
parent
02746d0700
commit
179824a21d
|
@ -440,8 +440,9 @@ class Graph {
|
||||||
// Creates a node of a specific type. Should be used for pure interfaces,
|
// Creates a node of a specific type. Should be used for pure interfaces,
|
||||||
// which do not have a built-in type string.
|
// which do not have a built-in type string.
|
||||||
template <class Calc>
|
template <class Calc>
|
||||||
Node<Calc>& AddNode(const std::string& type) {
|
Node<Calc>& AddNode(absl::string_view type) {
|
||||||
auto node = std::make_unique<Node<Calc>>(type);
|
auto node =
|
||||||
|
std::make_unique<Node<Calc>>(std::string(type.data(), type.size()));
|
||||||
auto node_p = node.get();
|
auto node_p = node.get();
|
||||||
nodes_.emplace_back(std::move(node));
|
nodes_.emplace_back(std::move(node));
|
||||||
return *node_p;
|
return *node_p;
|
||||||
|
@ -449,16 +450,18 @@ class Graph {
|
||||||
|
|
||||||
// Creates a generic node, with no compile-time checking of inputs and
|
// Creates a generic node, with no compile-time checking of inputs and
|
||||||
// outputs. This can be used for calculators whose contract is not visible.
|
// outputs. This can be used for calculators whose contract is not visible.
|
||||||
GenericNode& AddNode(const std::string& type) {
|
GenericNode& AddNode(absl::string_view type) {
|
||||||
auto node = std::make_unique<GenericNode>(type);
|
auto node =
|
||||||
|
std::make_unique<GenericNode>(std::string(type.data(), type.size()));
|
||||||
auto node_p = node.get();
|
auto node_p = node.get();
|
||||||
nodes_.emplace_back(std::move(node));
|
nodes_.emplace_back(std::move(node));
|
||||||
return *node_p;
|
return *node_p;
|
||||||
}
|
}
|
||||||
|
|
||||||
// For legacy PacketGenerators.
|
// For legacy PacketGenerators.
|
||||||
PacketGenerator& AddPacketGenerator(const std::string& type) {
|
PacketGenerator& AddPacketGenerator(absl::string_view type) {
|
||||||
auto node = std::make_unique<PacketGenerator>(type);
|
auto node = std::make_unique<PacketGenerator>(
|
||||||
|
std::string(type.data(), type.size()));
|
||||||
auto node_p = node.get();
|
auto node_p = node.get();
|
||||||
packet_gens_.emplace_back(std::move(node));
|
packet_gens_.emplace_back(std::move(node));
|
||||||
return *node_p;
|
return *node_p;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user