//-----------------------------------------------------------------------------
// (c) 2006 by Basler Vision Technologies
// Section: Vision Components
// Project: GenApi
// Author: Fritz Dierks
// $Header$
//
// License: This file is published under the license of the EMVA GenICam Standard Group.
// A text file describing the legal terms is included in your installation as 'GenICam_license.pdf'.
// If for some reason you are missing this file please contact the EMVA or visit the website
// (http://www.genicam.org) for a full copy.
//
// THIS SOFTWARE IS PROVIDED BY THE EMVA GENICAM STANDARD GROUP "AS IS"
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
// THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
// PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE EMVA GENICAM STANDARD GROUP
// OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
// OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
// POSSIBILITY OF SUCH DAMAGE.
//-----------------------------------------------------------------------------
/*!
\file
\brief Definition of interface INodeMap
\ingroup GenApi_PublicInterface
*/
#ifndef GENAPI_INODEMAP_H
#define GENAPI_INODEMAP_H
#include
#include
#include
#include
#ifdef _MSC_VER
# pragma warning ( push )
# pragma warning ( disable : 4251 ) // XXX needs to have dll-interface to be used by clients of class YYY
#endif
namespace GENAPI_NAMESPACE
{
//*************************************************************
// INodeMap interface
//*************************************************************
/**
\brief Interface to access the node map
\ingroup GenApi_PublicInterface
*/
interface GENAPI_DECL_ABSTRACT INodeMap
{
//! Retrieves all nodes in the node map
virtual void GetNodes(NodeList_t &Nodes) const = 0;
//! Retrieves the node from the central map by Name
virtual INode* GetNode( const GENICAM_NAMESPACE::gcstring& Name) const = 0;
//! Invalidates all nodes
virtual void InvalidateNodes() const = 0;
//! Connects a port to a port node with given name
virtual bool Connect( IPort* pPort, const GENICAM_NAMESPACE::gcstring& PortName) const = 0;
//! Connects a port to the standard port "Device"
virtual bool Connect( IPort* pPort) const = 0;
//! Get device name
/*! The device name identifies a device instance, e.g. for debugging purposes.
The default ist "Device". */
virtual GENICAM_NAMESPACE::gcstring GetDeviceName() = 0;
//! Fires nodes which have a polling time
virtual void Poll( int64_t ElapsedTime ) = 0;
//! Returns the lock which guards the node map
virtual CLock& GetLock() const = 0;
//! Get the number of nodes in the map
virtual uint64_t GetNumNodes() const = 0;
//! Parse all Swissknife equations
virtual bool ParseSwissKnifes( GENICAM_NAMESPACE::gcstring_vector *pErrorList = NULL ) const = 0;
};
}
#ifdef _MSC_VER
# pragma warning ( pop )
#endif
#endif // ifndef GENAPI_INODEMAP_H