summaryrefslogtreecommitdiffstats
path: root/chromium/third_party/WebKit/Source/core/editing/EditCommand.h
diff options
context:
space:
mode:
Diffstat (limited to 'chromium/third_party/WebKit/Source/core/editing/EditCommand.h')
-rw-r--r--chromium/third_party/WebKit/Source/core/editing/EditCommand.h14
1 files changed, 9 insertions, 5 deletions
diff --git a/chromium/third_party/WebKit/Source/core/editing/EditCommand.h b/chromium/third_party/WebKit/Source/core/editing/EditCommand.h
index e9dc8bea960..4b9a2ec49dd 100644
--- a/chromium/third_party/WebKit/Source/core/editing/EditCommand.h
+++ b/chromium/third_party/WebKit/Source/core/editing/EditCommand.h
@@ -28,6 +28,7 @@
#include "core/editing/EditAction.h"
#include "core/editing/VisibleSelection.h"
+#include "platform/heap/Handle.h"
#ifndef NDEBUG
#include "wtf/HashSet.h"
@@ -39,7 +40,7 @@ class CompositeEditCommand;
class Document;
class Element;
-class EditCommand : public RefCounted<EditCommand> {
+class EditCommand : public RefCountedWillBeGarbageCollectedFinalized<EditCommand> {
public:
virtual ~EditCommand();
@@ -52,11 +53,12 @@ public:
virtual bool isSimpleEditCommand() const { return false; }
virtual bool isCompositeEditCommand() const { return false; }
- virtual bool isEditCommandComposition() const { return false; }
bool isTopLevelCommand() const { return !m_parent; }
virtual void doApply() = 0;
+ virtual void trace(Visitor*);
+
protected:
explicit EditCommand(Document&);
EditCommand(Document*, const VisibleSelection&, const VisibleSelection&);
@@ -64,13 +66,15 @@ protected:
Document& document() const { return *m_document.get(); }
CompositeEditCommand* parent() const { return m_parent; }
void setStartingSelection(const VisibleSelection&);
+ void setStartingSelection(const VisiblePosition&);
void setEndingSelection(const VisibleSelection&);
+ void setEndingSelection(const VisiblePosition&);
private:
- RefPtr<Document> m_document;
+ RefPtrWillBeMember<Document> m_document;
VisibleSelection m_startingSelection;
VisibleSelection m_endingSelection;
- CompositeEditCommand* m_parent;
+ RawPtrWillBeMember<CompositeEditCommand> m_parent;
};
enum ShouldAssumeContentIsAlwaysEditable {
@@ -87,7 +91,7 @@ protected:
explicit SimpleEditCommand(Document& document) : EditCommand(document) { }
private:
- virtual bool isSimpleEditCommand() const OVERRIDE { return true; }
+ virtual bool isSimpleEditCommand() const OVERRIDE FINAL { return true; }
};
DEFINE_TYPE_CASTS(SimpleEditCommand, EditCommand, command, command->isSimpleEditCommand(), command.isSimpleEditCommand());