/src/xmlpatterns/functions/qsequencegeneratingfns_p.h

https://bitbucket.org/ultra_iter/qt-vtl · C Header · 167 lines · 52 code · 19 blank · 96 comment · 0 complexity · 01a973f3cb1fe0c89f13a90d62984de8 MD5 · raw file

  1. /****************************************************************************
  2. **
  3. ** Copyright (C) 2012 Nokia Corporation and/or its subsidiary(-ies).
  4. ** All rights reserved.
  5. ** Contact: Nokia Corporation (qt-info@nokia.com)
  6. **
  7. ** This file is part of the QtXmlPatterns module of the Qt Toolkit.
  8. **
  9. ** $QT_BEGIN_LICENSE:LGPL$
  10. ** GNU Lesser General Public License Usage
  11. ** This file may be used under the terms of the GNU Lesser General Public
  12. ** License version 2.1 as published by the Free Software Foundation and
  13. ** appearing in the file LICENSE.LGPL included in the packaging of this
  14. ** file. Please review the following information to ensure the GNU Lesser
  15. ** General Public License version 2.1 requirements will be met:
  16. ** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
  17. **
  18. ** In addition, as a special exception, Nokia gives you certain additional
  19. ** rights. These rights are described in the Nokia Qt LGPL Exception
  20. ** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
  21. **
  22. ** GNU General Public License Usage
  23. ** Alternatively, this file may be used under the terms of the GNU General
  24. ** Public License version 3.0 as published by the Free Software Foundation
  25. ** and appearing in the file LICENSE.GPL included in the packaging of this
  26. ** file. Please review the following information to ensure the GNU General
  27. ** Public License version 3.0 requirements will be met:
  28. ** http://www.gnu.org/copyleft/gpl.html.
  29. **
  30. ** Other Usage
  31. ** Alternatively, this file may be used in accordance with the terms and
  32. ** conditions contained in a signed written agreement between you and Nokia.
  33. **
  34. **
  35. **
  36. **
  37. **
  38. ** $QT_END_LICENSE$
  39. **
  40. ****************************************************************************/
  41. //
  42. // W A R N I N G
  43. // -------------
  44. //
  45. // This file is not part of the Qt API. It exists purely as an
  46. // implementation detail. This header file may change from version to
  47. // version without notice, or even be removed.
  48. //
  49. // We mean it.
  50. #ifndef Patternist_SequenceGeneratingFNs_H
  51. #define Patternist_SequenceGeneratingFNs_H
  52. #include "qanyuri_p.h"
  53. #include "qcontextnodechecker_p.h"
  54. #include "qstaticbaseuricontainer_p.h"
  55. /**
  56. * @file
  57. * @short Contains classes implementing the functions found in
  58. * <a href="http://www.w3.org/TR/xpath-functions/#fns-that-generate-sequences">XQuery 1.0 and
  59. * XPath 2.0 Functions and Operators, 15.5 Functions and Operators that Generate Sequences</a>.
  60. *
  61. * @ingroup Patternist_functions
  62. */
  63. QT_BEGIN_HEADER
  64. QT_BEGIN_NAMESPACE
  65. namespace QPatternist
  66. {
  67. /**
  68. * @short Implements the function <tt>fn:id()</tt>.
  69. *
  70. * @ingroup Patternist_functions
  71. * @author Frans Englich <frans.englich@nokia.com>
  72. */
  73. class IdFN : public ContextNodeChecker
  74. {
  75. public:
  76. IdFN();
  77. typedef QPair<DynamicContext::Ptr, const QAbstractXmlNodeModel *> IDContext;
  78. virtual Item::Iterator::Ptr evaluateSequence(const DynamicContext::Ptr &context) const;
  79. inline Item mapToItem(const QString &id,
  80. const IDContext &context) const;
  81. virtual Expression::Ptr typeCheck(const StaticContext::Ptr &context,
  82. const SequenceType::Ptr &reqType);
  83. private:
  84. typedef QExplicitlySharedDataPointer<const IdFN> ConstPtr;
  85. bool m_hasCreatedSorter;
  86. };
  87. /**
  88. * @short Implements the function <tt>fn:idref()</tt>.
  89. *
  90. * @ingroup Patternist_functions
  91. * @author Frans Englich <frans.englich@nokia.com>
  92. */
  93. class IdrefFN : public ContextNodeChecker
  94. {
  95. public:
  96. virtual Item::Iterator::Ptr evaluateSequence(const DynamicContext::Ptr &context) const;
  97. };
  98. /**
  99. * @short Implements the function <tt>fn:doc()</tt>.
  100. *
  101. * @ingroup Patternist_functions
  102. * @author Frans Englich <frans.englich@nokia.com>
  103. */
  104. class DocFN : public StaticBaseUriContainer
  105. {
  106. public:
  107. virtual Item evaluateSingleton(const DynamicContext::Ptr &context) const;
  108. /**
  109. * The implementation of this function is placed in a different compilation unit,
  110. * namely qsequencefns.cpp, to workaround a compiler bug on
  111. * solaris-cc-64, suspected to be related to the instantiation of QUrl::toQUrl().
  112. *
  113. * @see <a
  114. * href="http://onesearch.sun.com/search/onesearch/index.jsp?qt=6532605&site=sunsolve&otf=ss&col=support-sunsolve&otf=sunsolve&site=ss&col=search-sunsolve">Sun,
  115. * multiply-defined label for template instance, bug 6532605</a>
  116. */
  117. virtual Expression::Ptr typeCheck(const StaticContext::Ptr &context,
  118. const SequenceType::Ptr &reqType);
  119. virtual SequenceType::Ptr staticType() const;
  120. private:
  121. SequenceType::Ptr m_type;
  122. };
  123. /**
  124. * @short Implements the function <tt>fn:doc-available()</tt>.
  125. *
  126. * @ingroup Patternist_functions
  127. * @author Frans Englich <frans.englich@nokia.com>
  128. */
  129. class DocAvailableFN : public StaticBaseUriContainer
  130. {
  131. public:
  132. virtual bool evaluateEBV(const DynamicContext::Ptr &context) const;
  133. };
  134. /**
  135. * @short Implements the function <tt>fn:collection()</tt>.
  136. *
  137. * @ingroup Patternist_functions
  138. * @author Frans Englich <frans.englich@nokia.com>
  139. */
  140. class CollectionFN : public FunctionCall
  141. {
  142. public:
  143. virtual Item::Iterator::Ptr evaluateSequence(const DynamicContext::Ptr &context) const;
  144. };
  145. }
  146. QT_END_NAMESPACE
  147. QT_END_HEADER
  148. #endif