-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[Chef] Fix basicvideoplayer device type (#32091)
* [Chef] Fix basicvideoplayer device type This was actually a squashed and rebased commit for PR #31987 since it mixed with unwanted commit from other people due to conflicts during rebasing * Rename Data() function to GetXxxxName() function * Use `StringBuilder` instead of std::stringstream * Simplify codes without unnecessary return variables * Remove unused static_cast * Simplify the keypad keycode handling * Restyled by clang-format * Enable Chef BasicVideoPlayer in cloud build * Remove unused GetInputName & GetOutputName function * Using struct InputData&OuptutData to refine logics in Chef common/clusters/audio-output/AudioOutputManager.* and common/clusters/media-input/MediaInputManager.* * Add break in default section * Fix recordingFlag type and remove EMBER_ZCL_STATUS_SUCCESS * Use std::numeric_limits<uint32_t>::max() as endTime default * Remove some unneeded namespace declaration * Restyled by clang-format * Restyled by clang-format --------- Co-authored-by: Restyled.io <[email protected]>
- Loading branch information
Showing
26 changed files
with
3,069 additions
and
499 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
83 changes: 83 additions & 0 deletions
83
examples/chef/common/clusters/audio-output/AudioOutputManager.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
/* | ||
* | ||
* Copyright (c) 2021 Project CHIP Authors | ||
* All rights reserved. | ||
* | ||
* 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. | ||
*/ | ||
|
||
#include <app/util/config.h> | ||
#ifdef MATTER_DM_PLUGIN_AUDIO_OUTPUT_SERVER | ||
#include "AudioOutputManager.h" | ||
|
||
using namespace std; | ||
using namespace chip::app; | ||
using namespace chip::app::Clusters::AudioOutput; | ||
using chip::app::AttributeValueEncoder; | ||
|
||
AudioOutputManager::AudioOutputManager() | ||
{ | ||
struct OutputData outputData1(1, chip::app::Clusters::AudioOutput::OutputTypeEnum::kHdmi, "HDMI 1"); | ||
mOutputs.push_back(outputData1); | ||
struct OutputData outputData2(2, chip::app::Clusters::AudioOutput::OutputTypeEnum::kHdmi, "HDMI 2"); | ||
mOutputs.push_back(outputData2); | ||
struct OutputData outputData3(3, chip::app::Clusters::AudioOutput::OutputTypeEnum::kHdmi, "HDMI 3"); | ||
mOutputs.push_back(outputData3); | ||
|
||
mCurrentOutput = 1; | ||
} | ||
|
||
uint8_t AudioOutputManager::HandleGetCurrentOutput() | ||
{ | ||
return mCurrentOutput; | ||
} | ||
|
||
CHIP_ERROR AudioOutputManager::HandleGetOutputList(AttributeValueEncoder & aEncoder) | ||
{ | ||
return aEncoder.EncodeList([this](const auto & encoder) -> CHIP_ERROR { | ||
for (auto const & outputData : mOutputs) | ||
{ | ||
ReturnErrorOnFailure(encoder.Encode(outputData.GetEncodable())); | ||
} | ||
return CHIP_NO_ERROR; | ||
}); | ||
} | ||
|
||
bool AudioOutputManager::HandleRenameOutput(const uint8_t & index, const chip::CharSpan & newName) | ||
{ | ||
for (auto & outputData : mOutputs) | ||
{ | ||
if (outputData.index == index) | ||
{ | ||
outputData.Rename(newName); | ||
return true; | ||
} | ||
} | ||
|
||
return false; | ||
} | ||
|
||
bool AudioOutputManager::HandleSelectOutput(const uint8_t & index) | ||
{ | ||
for (auto & outputData : mOutputs) | ||
{ | ||
if (outputData.index == index) | ||
{ | ||
mCurrentOutput = index; | ||
return true; | ||
} | ||
} | ||
|
||
return false; | ||
} | ||
#endif // MATTER_DM_PLUGIN_AUDIO_OUTPUT_SERVER |
Oops, something went wrong.