/* ============================================================================== This file is part of the JUCE library. Copyright (c) 2020 - Raw Material Software Limited JUCE is an open source library subject to commercial or open-source licensing. The code included in this file is provided under the terms of the ISC license http://www.isc.org/downloads/software-support-policy/isc-license. Permission To use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted provided that the above copyright notice and this permission notice appear in all copies. JUCE IS PROVIDED "AS IS" WITHOUT ANY WARRANTY, AND ALL WARRANTIES, WHETHER EXPRESSED OR IMPLIED, INCLUDING MERCHANTABILITY AND FITNESS FOR PURPOSE, ARE DISCLAIMED. ============================================================================== */ namespace juce { /** Base class for an entity that provides access to a blocks topology. @tags{Blocks} */ class TopologySource { public: //============================================================================== /** Destructor. */ virtual ~TopologySource() = default; /** Returns the current topology that this object manages. */ virtual BlockTopology getCurrentTopology() const = 0; /** Sets the TopologySource as active, occupying the midi port and trying to connect to the block devices */ virtual void setActive (bool shouldBeActive) = 0; /** Returns true, if the TopologySource is currently trying to connect the block devices */ virtual bool isActive() const = 0; /** Returns true if the topology is locked externally.*/ virtual bool isLockedFromOutside() const = 0; //============================================================================== /** Used to receive callbacks for topology changes */ struct Listener { virtual ~Listener() = default; /** Called for any change in topology - devices changed, connections changed, etc. */ virtual void topologyChanged() {} /** Called when a new block is added to the topology. */ virtual void blockAdded (const Block::Ptr) {} /** Called when a block is removed from the topology. */ virtual void blockRemoved (const Block::Ptr) {} /** Called when a known block is updated. This could be because details have been received asynchronously. E.g. Block name. */ virtual void blockUpdated (const Block::Ptr) {} }; void addListener (Listener* l) { listeners.add (l); } void removeListener (Listener* l) { listeners.remove (l); } /** Invoke this to force touches-off on all physical devices. */ virtual void cancelAllActiveTouches() noexcept {} /** Gets blocks from the current topology. */ Block::Array getBlocks() const { return getCurrentTopology().blocks; } /**Gets a block with given uid from the current topology*/ Block::Ptr getBlockWithUID (Block::UID uid) const { return getCurrentTopology().getBlockWithUID (uid); } protected: //============================================================================== ListenerList listeners; }; } // namespace juce