RecursiveDirectoryIteratorImpl.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. //
  2. // RecursiveDirectoryIteratorImpl.h
  3. //
  4. // $Id$
  5. //
  6. // Library: Foundation
  7. // Package: Filesystem
  8. // Module: RecursiveDirectoryIterator
  9. //
  10. // Definition of the RecursiveDirectoryIteratorImpl class.
  11. //
  12. // Copyright (c) 2012, Applied Informatics Software Engineering GmbH.
  13. // and Contributors.
  14. //
  15. // Permission is hereby granted, free of charge, to any person or organization
  16. // obtaining a copy of the software and accompanying documentation covered by
  17. // this license (the "Software") to use, reproduce, display, distribute,
  18. // execute, and transmit the Software, and to prepare derivative works of the
  19. // Software, and to permit third-parties to whom the Software is furnished to
  20. // do so, all subject to the following:
  21. //
  22. // The copyright notices in the Software and this entire statement, including
  23. // the above license grant, this restriction and the following disclaimer,
  24. // must be included in all copies of the Software, in whole or in part, and
  25. // all derivative works of the Software, unless such copies or derivative
  26. // works are solely in the form of machine-executable object code generated by
  27. // a source language processor.
  28. //
  29. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  30. // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
  31. // FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
  32. // SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
  33. // FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
  34. // ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
  35. // DEALINGS IN THE SOFTWARE.
  36. //
  37. #ifndef Foundation_RecursiveDirectoryIteratorImpl_INCLUDE
  38. #define Foundation_RecursiveDirectoryIteratorImpl_INCLUDE
  39. #include "Poco/Foundation.h"
  40. #include "Poco/RecursiveDirectoryIteratorStrategies.h"
  41. #include <stack>
  42. #include <functional>
  43. namespace Poco
  44. {
  45. class ChildrenFirstTraverse;
  46. class SiblingsFirstTraverse;
  47. template<class TTraverseStrategy = ChildrenFirstTraverse>
  48. class RecursiveDirectoryIteratorImpl
  49. {
  50. public:
  51. enum
  52. {
  53. D_INFINITE = 0
  54. };
  55. /// Constant for infinite traverse depth.
  56. RecursiveDirectoryIteratorImpl(const std::string& path, UInt16 maxDepth = D_INFINITE)
  57. : _maxDepth(maxDepth), _traverseStrategy(std::ptr_fun(depthFun), _maxDepth), _isFinished(false), _rc(1)
  58. {
  59. _itStack.push(DirectoryIterator(path));
  60. _current = _itStack.top()->path();
  61. }
  62. ~RecursiveDirectoryIteratorImpl()
  63. {
  64. }
  65. inline void duplicate()
  66. {
  67. ++_rc;
  68. }
  69. inline void release()
  70. {
  71. if (--_rc == 0)
  72. delete this;
  73. }
  74. inline UInt16 depth() const
  75. {
  76. return depthFun(_itStack);
  77. }
  78. inline UInt16 maxDepth() const
  79. {
  80. return _maxDepth;
  81. }
  82. inline const std::string& get() const
  83. {
  84. return _current;
  85. }
  86. const std::string& next()
  87. {
  88. if (_isFinished)
  89. return _current;
  90. _current = _traverseStrategy.next(&_itStack, &_isFinished);
  91. return _current;
  92. }
  93. private:
  94. typedef std::stack<DirectoryIterator> Stack;
  95. static UInt16 depthFun(const Stack& stack)
  96. /// Function which implements the logic of determining
  97. /// recursion depth.
  98. {
  99. return stack.size();
  100. }
  101. UInt16 _maxDepth;
  102. TTraverseStrategy _traverseStrategy;
  103. bool _isFinished;
  104. Stack _itStack;
  105. std::string _current;
  106. int _rc;
  107. };
  108. } // namespace Poco
  109. #endif // Foundation_RecursiveDirectoryIteratorImpl_INCLUDE