|
- /*
- ==============================================================================
-
- This file is part of the JUCE library.
- Copyright (c) 2017 - ROLI Ltd.
-
- 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.
-
- ==============================================================================
- */
-
-
- /** Base class for an entity that provides access to a blocks topology. */
- class TopologySource
- {
- public:
- //==========================================================================
- /** Destructor. */
- virtual ~TopologySource() {}
-
- /** Returns the current topology that this object manages. */
- virtual BlockTopology getCurrentTopology() const = 0;
-
- //==========================================================================
- struct Listener
- {
- virtual ~Listener() {}
- virtual void topologyChanged() = 0;
- };
-
- 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 {}
-
- protected:
- //==========================================================================
- juce::ListenerList<Listener> listeners;
- };
|