Merge "audio: Add vendor tags handling for AIDL" am: a3a1c665fb

Original change: https://android-review.googlesource.com/c/platform/hardware/interfaces/+/2479295

Change-Id: Ib4dfa979c57815a0cf203c6362492f5c5b44a4d0
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
Treehugger Robot
2023-03-09 18:54:21 +00:00
committed by Automerger Merge Worker
2 changed files with 14 additions and 1 deletions

View File

@@ -19,6 +19,7 @@
#include <algorithm>
#include <array>
#include <initializer_list>
#include <regex>
#include <type_traits>
#include <aidl/android/media/audio/common/AudioChannelLayout.h>
@@ -133,6 +134,18 @@ constexpr bool isValidAudioMode(::aidl::android::media::audio::common::AudioMode
kValidAudioModes.end();
}
static inline bool maybeVendorExtension(const std::string& s) {
// Only checks whether the string starts with the "vendor prefix".
static const std::string vendorPrefix = "VX_";
return s.size() > vendorPrefix.size() && s.substr(0, vendorPrefix.size()) == vendorPrefix;
}
static inline bool isVendorExtension(const std::string& s) {
// Must be the same as defined in {Playback|Record}TrackMetadata.aidl
static const std::regex vendorExtension("VX_[A-Z0-9]{3,}_[_A-Z0-9]+");
return std::regex_match(s.begin(), s.end(), vendorExtension);
}
// The helper functions defined below are only applicable to the case when an enum type
// specifies zero-based bit positions, not bit masks themselves. This is why instantiation
// is restricted to certain enum types.

View File

@@ -81,7 +81,7 @@ struct HidlUtils {
#endif
#if MAJOR_VERSION >= 7
static constexpr char sAudioTagSeparator = ';';
static constexpr char sAudioTagSeparator = AUDIO_ATTRIBUTES_TAGS_SEPARATOR;
static status_t audioChannelMaskFromHal(audio_channel_mask_t halChannelMask, bool isInput,
AudioChannelMask* channelMask);