/* * Copyright (C) 2015 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #define LOG_TAG "APM::AudioPolicyEngine/Strategy" #include "Strategy.h" using std::string; namespace android { namespace audio_policy { status_t Element::setIdentifier(routing_strategy identifier) { if (identifier >= NUM_STRATEGIES) { return BAD_VALUE; } mIdentifier = identifier; ALOGD("%s: Strategy %s identifier 0x%X", __FUNCTION__, getName().c_str(), identifier); return NO_ERROR; } /** * Set the device associated to this strategy. * It checks if the output device is valid but allows to set a NONE device * * @param[in] devices selected for the given strategy. * * @return NO_ERROR if the device is either valid or none, error code otherwise. */ template <> status_t Element::set(audio_devices_t devices) { if (!audio_is_output_devices(devices) && devices != AUDIO_DEVICE_NONE) { ALOGE("%s: trying to set an invalid device 0x%X for strategy %s", __FUNCTION__, devices, getName().c_str()); return BAD_VALUE; } ALOGD("%s: 0x%X for strategy %s", __FUNCTION__, devices, getName().c_str()); mApplicableDevices = devices; return NO_ERROR; } template <> audio_devices_t Element::get() const { ALOGV("%s: 0x%X for strategy %s", __FUNCTION__, mApplicableDevices, getName().c_str()); return mApplicableDevices; } } // namespace audio_policy } // namespace android