blob: fc5f7d34d5b208ff435578034477c2989ef4a4e3 [file] [log] [blame]
/*
*
* Copyright (c) 2021 Project CHIP Authors
*
* 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.
*/
/**
* @file
* General faults could be detected by the Node.
*/
#pragma once
#include <lib/core/CHIPError.h>
#include <lib/support/CodeUtils.h>
namespace chip {
namespace DeviceLayer {
static constexpr size_t kMaxHardwareFaults = 11;
static constexpr size_t kMaxRadioFaults = 7;
static constexpr size_t kMaxNetworkFaults = 4;
template <size_t N>
class GeneralFaults
{
public:
/* The iterator */
class Iterator
{
public:
Iterator(const GeneralFaults<N> * GeneralFaults, int index);
uint8_t operator*() const;
Iterator & operator++();
bool operator!=(const Iterator & other) const;
private:
const GeneralFaults<N> * mGeneralFaultsPtr;
int mIndex = -1;
};
GeneralFaults() = default;
~GeneralFaults() { mSize = 0; }
CHIP_ERROR add(const uint8_t value);
const uint8_t * data() const { return mData; }
size_t size() const;
uint8_t operator[](int index) const;
Iterator begin() const;
Iterator end() const;
private:
uint8_t mData[N];
int mSize = 0;
};
/*
* GeneralFaults methods
**/
template <size_t N>
inline CHIP_ERROR GeneralFaults<N>::add(const uint8_t value)
{
if (mSize == N)
{
return CHIP_ERROR_NO_MEMORY;
}
// add the new element
mData[mSize] = value;
++mSize;
return CHIP_NO_ERROR;
}
template <size_t N>
inline size_t GeneralFaults<N>::size() const
{
return static_cast<size_t>(mSize);
}
template <size_t N>
inline uint8_t GeneralFaults<N>::operator[](int index) const
{
VerifyOrDie(index < mSize);
return mData[index];
}
template <size_t N>
inline typename GeneralFaults<N>::Iterator GeneralFaults<N>::begin() const
{
return GeneralFaults<N>::Iterator{ this, 0 };
}
template <size_t N>
inline typename GeneralFaults<N>::Iterator GeneralFaults<N>::end() const
{
return GeneralFaults<N>::Iterator{ this, mSize };
}
/*
* Iterator methods
**/
template <size_t N>
inline GeneralFaults<N>::Iterator::Iterator(const GeneralFaults<N> * pGeneralFaults, int index) :
mGeneralFaultsPtr(pGeneralFaults), mIndex(index)
{}
template <size_t N>
inline uint8_t GeneralFaults<N>::Iterator::operator*() const
{
return mGeneralFaultsPtr->operator[](mIndex);
}
template <size_t N>
inline typename GeneralFaults<N>::Iterator & GeneralFaults<N>::Iterator::operator++()
{
++mIndex;
return *this;
}
template <size_t N>
inline bool GeneralFaults<N>::Iterator::operator!=(const GeneralFaults<N>::Iterator & other) const
{
return mIndex != other.mIndex;
}
} // namespace DeviceLayer
} // namespace chip