ICommand.h 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. //-----------------------------------------------------------------------------
  2. // (c) 2006 by Basler Vision Technologies
  3. // Section: Vision Components
  4. // Project: GenApi
  5. // Author: Hartmut Nebelung
  6. // $Header$
  7. //
  8. // License: This file is published under the license of the EMVA GenICam Standard Group.
  9. // A text file describing the legal terms is included in your installation as 'GenICam_license.pdf'.
  10. // If for some reason you are missing this file please contact the EMVA or visit the website
  11. // (http://www.genicam.org) for a full copy.
  12. //
  13. // THIS SOFTWARE IS PROVIDED BY THE EMVA GENICAM STANDARD GROUP "AS IS"
  14. // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
  15. // THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  16. // PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE EMVA GENICAM STANDARD GROUP
  17. // OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
  18. // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
  19. // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
  20. // OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
  21. // WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  22. // ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  23. // POSSIBILITY OF SUCH DAMAGE.
  24. //-----------------------------------------------------------------------------
  25. /*!
  26. \file
  27. \brief Definition of ICommand interface
  28. \ingroup GenApi_PublicInterface
  29. */
  30. #ifndef GENAPI_ICOMMAND_H
  31. #define GENAPI_ICOMMAND_H
  32. #include <GenApi/GenApiDll.h>
  33. #include <GenApi/Types.h>
  34. #include <GenApi/IValue.h>
  35. #ifdef _MSC_VER
  36. # pragma warning ( push )
  37. # pragma warning ( disable : 4251 ) // XXX needs to have dll-interface to be used by clients of class YYY
  38. #endif
  39. namespace GENAPI_NAMESPACE
  40. {
  41. //*************************************************************
  42. // ICommand interface
  43. //*************************************************************
  44. //! Interface for command like properties
  45. //! \ingroup GenApi_PublicInterface
  46. interface GENAPI_DECL_ABSTRACT ICommand : virtual public IValue
  47. {
  48. public:
  49. //! Execute the command
  50. /*!
  51. \param Verify Enables AccessMode and Range verification (default = true)
  52. */
  53. virtual void Execute(bool Verify = true) = 0;
  54. //! Execute the command
  55. virtual void operator()() = 0;
  56. //! Query whether the command is executed
  57. /*!
  58. \param Verify Enables Range verification (default = false). The AccessMode is always checked
  59. \return True if the Execute command has finished; false otherwise
  60. */
  61. virtual bool IsDone(bool Verify = true) = 0;
  62. };
  63. //*************************************************************
  64. // CCommandRef class
  65. //*************************************************************
  66. #ifndef DOXYGEN_IGNORE
  67. /**
  68. \internal
  69. \brief Reference to an IInteger pointer
  70. \ingroup GenApi_PublicImpl
  71. */
  72. template <class T>
  73. class CCommandRefT : public CValueRefT<T>
  74. {
  75. typedef CValueRefT<T> ref;
  76. public:
  77. /*--------------------------------------------------------*/
  78. // ICommand
  79. /*--------------------------------------------------------*/
  80. //! Execute the command
  81. virtual void Execute(bool Verify = true)
  82. {
  83. if(ref::m_Ptr)
  84. return ref::m_Ptr->Execute(Verify);
  85. else
  86. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  87. }
  88. //! Execute the command
  89. virtual void operator()()
  90. {
  91. if(ref::m_Ptr)
  92. ref::m_Ptr->operator()();
  93. else
  94. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  95. }
  96. //! Query whether the command is executed
  97. virtual bool IsDone(bool Verify = true)
  98. {
  99. if(ref::m_Ptr)
  100. return ref::m_Ptr->IsDone(Verify);
  101. else
  102. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  103. }
  104. };
  105. //! Reference to an ICommand pointer
  106. //! \ingroup GenApi_PublicImpl
  107. typedef CCommandRefT<ICommand> CCommandRef;
  108. #endif
  109. }
  110. #ifdef _MSC_VER
  111. # pragma warning ( pop )
  112. #endif
  113. #endif // ifndef GENAPI_ICOMMAND_H