Skip to content

Commit 879b07a

Browse files
committed
use boost optional
1 parent b1f2aa0 commit 879b07a

File tree

6 files changed

+23
-22
lines changed

6 files changed

+23
-22
lines changed

src/viam/sdk/components/audio_out.hpp

Lines changed: 6 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -3,9 +3,10 @@
33
/// @brief Defines an `AudioOut` component.
44
#pragma once
55

6-
#include <memory>
76
#include <string>
87

8+
#include <boost/optional/optional.hpp>
9+
910
#include <viam/sdk/common/audio.hpp>
1011
#include <viam/sdk/common/proto_value.hpp>
1112
#include <viam/sdk/common/utils.hpp>
@@ -29,19 +30,19 @@ class AudioOut : public Component {
2930
/// @brief Play audio data
3031
/// @param audio_data The audio data to play as bytes
3132
/// @param info Optional info about the audio_data (codec, sample rate, channels). Required for
32-
/// raw PCM data, pass nullptr if not needed.
33+
/// raw PCM data.
3334
inline void play(std::vector<uint8_t> const& audio_data,
34-
std::shared_ptr<audio_info> info = nullptr) {
35+
boost::optional<audio_info> info) {
3536
return play(audio_data, info, {});
3637
}
3738

3839
/// @brief Play audio through the audioout component
3940
/// @param audio_data The audio data to play
4041
/// @param info Optional info about the audio_data (codec, sample rate, channels). Required for
41-
/// raw PCM data, pass nullptr if not needed.
42+
/// raw PCM data.
4243
/// @param extra Any additional arguments to the method
4344
virtual void play(std::vector<uint8_t> const& audio_data,
44-
std::shared_ptr<audio_info> info,
45+
boost::optional<audio_info> info,
4546
const ProtoStruct& extra) = 0;
4647

4748
/// @brief Returns properties of the audio out device (supported codecs, sample rate, number of

src/viam/sdk/components/private/audio_out_client.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -26,7 +26,7 @@ AudioOutClient::AudioOutClient(std::string name, std::shared_ptr<grpc::Channel>
2626
channel_(std::move(channel)) {}
2727

2828
void AudioOutClient::play(std::vector<uint8_t> const& audio_data,
29-
std::shared_ptr<audio_info> info,
29+
boost::optional<audio_info> info,
3030
const ProtoStruct& extra) {
3131
return make_client_helper(this, *stub_, &StubType::Play)
3232
.with(extra,

src/viam/sdk/components/private/audio_out_client.hpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -22,7 +22,7 @@ class AudioOutClient : public AudioOut {
2222
AudioOutClient(std::string name, std::shared_ptr<grpc::Channel> channel);
2323

2424
void play(std::vector<uint8_t> const& audio_data,
25-
std::shared_ptr<audio_info> info,
25+
boost::optional<audio_info> info,
2626
const ProtoStruct& extra) override;
2727
audio_properties get_properties(const ProtoStruct& extra) override;
2828
ProtoStruct do_command(const ProtoStruct& command) override;

src/viam/sdk/components/private/audio_out_server.cpp

Lines changed: 7 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -22,14 +22,15 @@ ::grpc::Status AudioOutServer::Play(::grpc::ServerContext*,
2222
const std::string& audio_data_str = request->audio_data();
2323
audio_data.assign(audio_data_str.c_str(), audio_data_str.c_str() + audio_data_str.size());
2424

25-
std::shared_ptr<audio_info> info_ptr;
25+
boost::optional<audio_info> info;
2626
if (request->has_audio_info()) {
27-
info_ptr = std::make_shared<audio_info>();
28-
info_ptr->codec = request->audio_info().codec();
29-
info_ptr->sample_rate_hz = request->audio_info().sample_rate_hz();
30-
info_ptr->num_channels = request->audio_info().num_channels();
27+
info.emplace(audio_info{
28+
request->audio_info().codec(),
29+
request->audio_info().sample_rate_hz(),
30+
request->audio_info().num_channels()
31+
});
3132
}
32-
audio_out->play(audio_data, info_ptr, helper.getExtra());
33+
audio_out->play(audio_data, info, helper.getExtra());
3334
});
3435
}
3536

src/viam/sdk/tests/mocks/mock_audio_out.cpp

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@ namespace audioout {
1313
using namespace viam::sdk;
1414

1515
void MockAudioOut::play(std::vector<uint8_t> const& audio_data,
16-
std::shared_ptr<audio_info> info,
16+
boost::optional<audio_info> info,
1717
const ProtoStruct& extra) {
1818
last_played_audio_ = audio_data;
1919
last_played_audio_info_ = info;

src/viam/sdk/tests/test_audio_out.cpp

Lines changed: 7 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -33,15 +33,14 @@ BOOST_AUTO_TEST_CASE(test_play) {
3333
audio_data.push_back(3);
3434
audio_data.push_back(4);
3535

36-
auto info = std::make_shared<audio_info>();
37-
info->codec = audio_codecs::PCM_16;
38-
info->sample_rate_hz = 44100;
39-
info->num_channels = 1;
36+
audio_info info;
37+
info.codec = audio_codecs::PCM_16;
38+
info.sample_rate_hz = 44100;
39+
info.num_channels = 1;
4040

4141
client.play(audio_data, info, {});
4242
BOOST_CHECK(mock->last_played_audio_ == audio_data);
43-
BOOST_CHECK(mock->last_played_audio_info_ != nullptr);
44-
BOOST_CHECK(*mock->last_played_audio_info_ == *info);
43+
BOOST_CHECK(*mock->last_played_audio_info_ == info);
4544
});
4645
}
4746

@@ -54,9 +53,9 @@ BOOST_AUTO_TEST_CASE(test_play_no_audio_info) {
5453
audio_data.push_back(4);
5554
audio_data.push_back(4);
5655

57-
client.play(audio_data, nullptr, {});
56+
client.play(audio_data, {}, {});
5857
BOOST_CHECK(mock->last_played_audio_ == audio_data);
59-
BOOST_CHECK(mock->last_played_audio_info_ == nullptr);
58+
BOOST_CHECK(!mock->last_played_audio_info_);
6059
});
6160
}
6261

0 commit comments

Comments
 (0)