DXR is a code search and navigation tool aimed at making sense of large projects. It supports full-text and regex searches as well as structural queries.

Implementation

Mercurial (b6d82b1a6b02)

VCS Links

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

#ifndef FilteredContentIterator_h
#define FilteredContentIterator_h

#include "nsComposeTxtSrvFilter.h"
#include "nsCOMPtr.h"
#include "nsCycleCollectionParticipant.h"
#include "nsISupportsImpl.h"
#include "nscore.h"
#include "mozilla/ContentIterator.h"
#include "mozilla/UniquePtr.h"

class nsAtom;
class nsINode;
class nsRange;

namespace mozilla {

namespace dom {
class AbstractRange;
}

class FilteredContentIterator final {
 public:
  NS_INLINE_DECL_CYCLE_COLLECTING_NATIVE_REFCOUNTING(FilteredContentIterator)
  NS_DECL_CYCLE_COLLECTION_NATIVE_CLASS(FilteredContentIterator)

  explicit FilteredContentIterator(UniquePtr<nsComposeTxtSrvFilter> aFilter);

  nsresult Init(nsINode* aRoot);
  nsresult Init(const dom::AbstractRange* aAbstractRange);
  nsresult Init(nsINode* aStartContainer, uint32_t aStartOffset,
                nsINode* aEndContainer, uint32_t aEndOffset);
  nsresult Init(const RawRangeBoundary& aStartBoundary,
                const RawRangeBoundary& aEndBoundary);
  void First();
  void Last();
  void Next();
  void Prev();
  nsINode* GetCurrentNode();
  bool IsDone();
  nsresult PositionAt(nsINode* aCurNode);

  /* Helpers */
  bool DidSkip() { return mDidSkip; }
  void ClearDidSkip() { mDidSkip = false; }

 protected:
  FilteredContentIterator()
      : mDidSkip(false), mIsOutOfRange(false), mDirection{eDirNotSet} {}

  virtual ~FilteredContentIterator();

  /**
   * Callers must guarantee that mRange isn't nullptr and it's positioned.
   */
  nsresult InitWithRange();

  // enum to give us the direction
  typedef enum { eDirNotSet, eForward, eBackward } eDirectionType;
  nsresult AdvanceNode(nsINode* aNode, nsINode*& aNewNode, eDirectionType aDir);
  void CheckAdvNode(nsINode* aNode, bool& aDidSkip, eDirectionType aDir);
  nsresult SwitchDirections(bool aChangeToForward);

  ContentIteratorBase* MOZ_NON_OWNING_REF mCurrentIterator;
  PostContentIterator mPostIterator;
  PreContentIterator mPreIterator;

  RefPtr<nsAtom> mBlockQuoteAtom;
  RefPtr<nsAtom> mScriptAtom;
  RefPtr<nsAtom> mTextAreaAtom;
  RefPtr<nsAtom> mSelectAreaAtom;
  RefPtr<nsAtom> mMapAtom;

  UniquePtr<nsComposeTxtSrvFilter> mFilter;
  RefPtr<nsRange> mRange;
  bool mDidSkip;
  bool mIsOutOfRange;
  eDirectionType mDirection;
};

}  // namespace mozilla

#endif  // #ifndef FilteredContentIterator_h