Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(20)

Side by Side Diff: Source/core/html/shadow/PickerIndicatorElement.h

Issue 273653003: Oilpan: Prepare to move PickerIndicatorElement to Oilpan heap. (Closed) Base URL: svn://svn.chromium.org/blink/trunk
Patch Set: Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | Source/core/html/shadow/PickerIndicatorElement.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 /* 1 /*
2 * Copyright (C) 2012 Google Inc. All rights reserved. 2 * Copyright (C) 2012 Google Inc. All rights reserved.
3 * 3 *
4 * Redistribution and use in source and binary forms, with or without 4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are 5 * modification, are permitted provided that the following conditions are
6 * met: 6 * met:
7 * 7 *
8 * * Redistributions of source code must retain the above copyright 8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer. 9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above 10 * * Redistributions in binary form must reproduce the above
(...skipping 24 matching lines...) Expand all
35 #include "core/html/HTMLDivElement.h" 35 #include "core/html/HTMLDivElement.h"
36 #include "platform/DateTimeChooser.h" 36 #include "platform/DateTimeChooser.h"
37 #include "platform/DateTimeChooserClient.h" 37 #include "platform/DateTimeChooserClient.h"
38 38
39 namespace WebCore { 39 namespace WebCore {
40 40
41 class HTMLInputElement; 41 class HTMLInputElement;
42 class PagePopup; 42 class PagePopup;
43 43
44 class PickerIndicatorElement FINAL : public HTMLDivElement, public DateTimeChoos erClient { 44 class PickerIndicatorElement FINAL : public HTMLDivElement, public DateTimeChoos erClient {
45 WILL_BE_USING_GARBAGE_COLLECTED_MIXIN(PickerIndicatorElement);
45 public: 46 public:
46 // PickerIndicatorOwner implementer must call removePickerIndicatorOwner whe n 47 // PickerIndicatorOwner implementer must call removePickerIndicatorOwner whe n
47 // it doesn't handle event, e.g. at destruction. 48 // it doesn't handle event, e.g. at destruction.
48 class PickerIndicatorOwner { 49 class PickerIndicatorOwner : public WillBeGarbageCollectedMixin {
49 public: 50 public:
50 virtual ~PickerIndicatorOwner() { } 51 virtual ~PickerIndicatorOwner() { }
51 virtual bool isPickerIndicatorOwnerDisabledOrReadOnly() const = 0; 52 virtual bool isPickerIndicatorOwnerDisabledOrReadOnly() const = 0;
52 // FIXME: Remove. Deprecated in favor of double version. 53 // FIXME: Remove. Deprecated in favor of double version.
53 virtual void pickerIndicatorChooseValue(const String&) = 0; 54 virtual void pickerIndicatorChooseValue(const String&) = 0;
54 virtual void pickerIndicatorChooseValue(double) = 0; 55 virtual void pickerIndicatorChooseValue(double) = 0;
55 virtual bool setupDateTimeChooserParameters(DateTimeChooserParameters&) = 0; 56 virtual bool setupDateTimeChooserParameters(DateTimeChooserParameters&) = 0;
56 }; 57 };
57 58
58 static PassRefPtr<PickerIndicatorElement> create(Document&, PickerIndicatorO wner&); 59 static PassRefPtrWillBeRawPtr<PickerIndicatorElement> create(Document&, Pick erIndicatorOwner&);
59 virtual ~PickerIndicatorElement(); 60 virtual ~PickerIndicatorElement();
61 virtual void trace(Visitor*) OVERRIDE;
62
60 void openPopup(); 63 void openPopup();
61 void closePopup(); 64 void closePopup();
62 virtual bool willRespondToMouseClickEvents() OVERRIDE; 65 virtual bool willRespondToMouseClickEvents() OVERRIDE;
63 void removePickerIndicatorOwner() { m_pickerIndicatorOwner = 0; } 66 void removePickerIndicatorOwner() { m_pickerIndicatorOwner = nullptr; }
64 67
65 // DateTimeChooserClient implementation. 68 // DateTimeChooserClient implementation.
66 virtual void didChooseValue(const String&) OVERRIDE; 69 virtual void didChooseValue(const String&) OVERRIDE;
67 virtual void didChooseValue(double) OVERRIDE; 70 virtual void didChooseValue(double) OVERRIDE;
68 virtual void didEndChooser() OVERRIDE; 71 virtual void didEndChooser() OVERRIDE;
69 72
70 private: 73 private:
71 PickerIndicatorElement(Document&, PickerIndicatorOwner&); 74 PickerIndicatorElement(Document&, PickerIndicatorOwner&);
72 virtual RenderObject* createRenderer(RenderStyle*) OVERRIDE; 75 virtual RenderObject* createRenderer(RenderStyle*) OVERRIDE;
73 virtual void defaultEventHandler(Event*) OVERRIDE; 76 virtual void defaultEventHandler(Event*) OVERRIDE;
74 virtual void detach(const AttachContext& = AttachContext()) OVERRIDE; 77 virtual void detach(const AttachContext& = AttachContext()) OVERRIDE;
75 virtual bool isPickerIndicatorElement() const OVERRIDE; 78 virtual bool isPickerIndicatorElement() const OVERRIDE;
76 79
77 HTMLInputElement* hostInput(); 80 HTMLInputElement* hostInput();
78 81
79 PickerIndicatorOwner* m_pickerIndicatorOwner; 82 RawPtrWillBeWeakMember<PickerIndicatorOwner> m_pickerIndicatorOwner;
haraken 2014/05/07 15:00:04 As Mads is commenting in https://codereview.chromi
tkent 2014/05/08 01:20:07 That's right.
keishi 2014/05/08 01:47:44 Done.
80 RefPtr<DateTimeChooser> m_chooser; 83 RefPtr<DateTimeChooser> m_chooser;
81 }; 84 };
82 85
83 DEFINE_TYPE_CASTS(PickerIndicatorElement, Element, element, element->isPickerInd icatorElement(), element.isPickerIndicatorElement()); 86 DEFINE_TYPE_CASTS(PickerIndicatorElement, Element, element, element->isPickerInd icatorElement(), element.isPickerIndicatorElement());
84 87
85 } 88 }
86 #endif 89 #endif
87 #endif 90 #endif
OLDNEW
« no previous file with comments | « no previous file | Source/core/html/shadow/PickerIndicatorElement.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698