IString.h 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  1. //-----------------------------------------------------------------------------
  2. // (c) 2006 by Basler Vision Technologies
  3. // Section: Vision Components
  4. // Project: GenApi
  5. // Author: Margret Albrecht
  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 IString
  28. \ingroup GenApi_PublicInterface
  29. */
  30. #ifndef GENAPI_ISTRING_H
  31. #define GENAPI_ISTRING_H
  32. #include <Base/GCString.h>
  33. #include <GenApi/GenApiDll.h>
  34. #include <GenApi/Types.h>
  35. #include <GenApi/IValue.h>
  36. #pragma warning ( push )
  37. #pragma warning ( disable : 4251 ) // XXX needs to have dll-interface to be used by clients of class YYY
  38. namespace GENAPI_NAMESPACE
  39. {
  40. //*************************************************************
  41. // IString interface
  42. //*************************************************************
  43. /**
  44. \brief Interface for string properties
  45. \ingroup GenApi_PublicInterface
  46. */
  47. interface GENAPI_DECL_ABSTRACT IString : virtual public IValue
  48. {
  49. //! Set node value
  50. /*!
  51. \param Value The value to set
  52. \param Verify Enables AccessMode and Range verification (default = true)
  53. */
  54. virtual void SetValue(const GENICAM_NAMESPACE::gcstring& Value, bool Verify = true) = 0;
  55. //! Set node value
  56. virtual IString& operator=(const GENICAM_NAMESPACE::gcstring& Value) = 0;
  57. //! Get node value
  58. /*!
  59. \param Verify Enables Range verification (default = false). The AccessMode is always checked
  60. \param IgnoreCache If true the value is read ignoring any caches (default = false)
  61. \return The value read
  62. */
  63. virtual GENICAM_NAMESPACE::gcstring GetValue(bool Verify = false, bool IgnoreCache = false) = 0;
  64. //! Get node value
  65. virtual GENICAM_NAMESPACE::gcstring operator()() = 0;
  66. //! Get node value
  67. virtual GENICAM_NAMESPACE::gcstring operator*() = 0;
  68. //! Retrieves the maximum length of the string in bytes
  69. virtual int64_t GetMaxLength() = 0;
  70. };
  71. //*************************************************************
  72. // CStringRef class
  73. //*************************************************************
  74. #ifndef DOXYGEN_IGNORE
  75. /**
  76. \internal
  77. \brief Reference to an IEnumEntry pointer
  78. \ingroup GenApi_PublicImpl
  79. */
  80. template <class T>
  81. class CStringRefT : public CValueRefT<T>
  82. {
  83. typedef CValueRefT<T> ref;
  84. public:
  85. /*--------------------------------------------------------*/
  86. // IString
  87. /*--------------------------------------------------------*/
  88. //! Set node value
  89. virtual void SetValue(const GENICAM_NAMESPACE::gcstring& Value, bool Verify = true)
  90. {
  91. if(ref::m_Ptr)
  92. return ref::m_Ptr->SetValue(Value, Verify);
  93. else
  94. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  95. }
  96. //! Set node value
  97. virtual IString& operator=(const GENICAM_NAMESPACE::gcstring& Value)
  98. {
  99. if(ref::m_Ptr)
  100. return ref::m_Ptr->operator=(Value);
  101. else
  102. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  103. }
  104. //! Get node value
  105. virtual GENICAM_NAMESPACE::gcstring GetValue(bool Verify = false, bool IgnoreCache = false)
  106. {
  107. if(ref::m_Ptr)
  108. return ref::m_Ptr->GetValue(Verify, IgnoreCache);
  109. else
  110. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  111. }
  112. //! Get node value
  113. virtual GENICAM_NAMESPACE::gcstring operator()()
  114. {
  115. if(ref::m_Ptr)
  116. return ref::m_Ptr->operator()();
  117. else
  118. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  119. }
  120. //! Get node value
  121. virtual GENICAM_NAMESPACE::gcstring operator*()
  122. {
  123. if(ref::m_Ptr)
  124. return ref::m_Ptr-> operator*();
  125. else
  126. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  127. }
  128. //! Get max length of string
  129. virtual int64_t GetMaxLength()
  130. {
  131. if(ref::m_Ptr)
  132. return ref::m_Ptr->GetMaxLength();
  133. else
  134. throw ACCESS_EXCEPTION("Feature not present (reference not valid)");
  135. }
  136. };
  137. //! Reference to an IString pointer
  138. //! \ingroup GenApi_PublicImpl
  139. typedef CStringRefT<IString> CStringRef;
  140. #endif
  141. }
  142. #pragma warning ( pop )
  143. #endif // ifndef GENAPI_ISTRING_H