Skip to content

File AccessArray.cpp

File List > astrea > trace > trace > risesets > AccessArray.cpp

Go to the documentation of this file

/*
 * The GNU Lesser General Public License (LGPL)
 *
 * Copyright (c) 2025 Jay Iuliano
 *
 * This file is part of Astrea.
 * Astrea is free software: you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License
 * as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
 * Astrea is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty
 * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details. You should
 * have received a copy of the GNU General Public License along with Astrea. If not, see <https://www.gnu.org/licenses/>.
 */

#include <trace/risesets/AccessArray.hpp>

namespace astrea {
namespace trace {

RiseSetArray& AccessArray::operator[](const std::size_t& senderId, const std::size_t& receiverId)
{
    return _accesses[IdPair(senderId, receiverId)];
}

const RiseSetArray& AccessArray::at(const std::size_t& senderId, const std::size_t& receiverId) const
{
    return _accesses.at(IdPair(senderId, receiverId));
}

bool AccessArray::contains(const IdPair& idPair) const { return _accesses.contains(idPair); }

void AccessArray::erase(const std::size_t& senderId, const std::size_t& receiverId)
{
    _accesses.erase(IdPair(senderId, receiverId));
}

std::size_t AccessArray::size() const { return _accesses.size(); }

RiseSetArray AccessArray::get_all_accesses_to_receiver(const std::size_t& receiverId) const
{
    RiseSetArray result;
    for (const auto& [ids, risesets] : _accesses) {
        if (ids.receiver == receiverId) { result |= risesets; }
    }
    return result;
}

RiseSetArray AccessArray::get_all_accesses_from_sender(const std::size_t& senderId) const
{
    RiseSetArray result;
    for (const auto& [ids, risesets] : _accesses) {
        if (ids.sender == senderId) { result |= risesets; }
    }
    return result;
}

bool AccessArray::operator==(const AccessArray& other) const { return _accesses == other._accesses; }

AccessArray& AccessArray::operator|=(const AccessArray& other)
{
    for (const auto& [ids, risesets] : other) {
        if (contains(ids)) { _accesses[ids] |= risesets; }
        else {
            _accesses[ids] = risesets;
        }
    }
    return *this;
}

AccessArray AccessArray::operator|(const AccessArray& other) const
{
    AccessArray result = *this;
    result |= other;
    return result;
}

AccessArray& AccessArray::operator&=(const AccessArray& other)
{
    for (const auto& [ids, risesets] : other) {
        if (contains(ids)) { _accesses[ids] &= risesets; }
    }
    return *this;
}

AccessArray AccessArray::operator&(const AccessArray& other) const
{
    AccessArray result = *this;
    result &= other;
    return result;
}

std::ostream& operator<<(std::ostream& os, const AccessArray& accessarray)
{
    for (const auto& [idPair, riseSetArray] : accessarray) {
        os << "(" << idPair.sender << ", " << idPair.receiver << ") -> " << riseSetArray << "\n";
    }
    return os;
}

} // namespace trace
} // namespace astrea