PortWriteList.h 3.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. //-----------------------------------------------------------------------------
  2. // (c) 2009 by Basler Vision Technologies
  3. // Section: Vision Components
  4. // Project: GenApi
  5. // Author: Fritz Dierks
  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 interface IPort
  28. \ingroup GenApi_PublicInterface
  29. */
  30. #ifndef GENAPI_PORTWRITELIST_H
  31. #define GENAPI_PORTWRITELIST_H
  32. #include <GenApi/IPortRecorder.h>
  33. #include <list>
  34. #ifdef _MSC_VER
  35. # pragma warning ( push )
  36. # pragma warning ( disable : 4251 ) // XXX needs to have dll-interface to be used by clients of class YYY
  37. #endif
  38. namespace GENAPI_NAMESPACE
  39. {
  40. //! Container holding a list of port write commands
  41. class GENAPI_DECL CPortWriteList : public IPortWriteList
  42. {
  43. public:
  44. //! Constructor
  45. CPortWriteList();
  46. //! Destructor
  47. ~CPortWriteList();
  48. /*---------------------------------------------------------------*/
  49. // IPortWriteList
  50. /*---------------------------------------------------------------*/
  51. //! Writes a chunk of bytes to the port
  52. virtual void Write(const void *pBuffer, int64_t Address, int64_t Length);
  53. //! Replays the write command to the given port interface
  54. virtual void Replay(IPort* pPort);
  55. //! Sets a cookie in case the port implementation want to cache a command list
  56. // Default = -1
  57. virtual void SetCookie(const int64_t Value);
  58. //! Gets the cookie a port implementation may have set for caching a command list
  59. virtual int64_t GetCookie();
  60. protected:
  61. //! The data associated with a write command
  62. typedef struct
  63. {
  64. int64_t Address;
  65. int64_t Length;
  66. char *pData;
  67. } WriteCommand_t;
  68. //! a list holding the write commands
  69. std::list<WriteCommand_t> *m_pWriteCommands;
  70. //! A cookie helper for caching
  71. int64_t m_Cookie;
  72. };
  73. }
  74. #ifdef _MSC_VER
  75. # pragma warning ( pop )
  76. #endif
  77. #endif // ifndef GENAPI_PORTWRITELIST_H