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

Unified Diff: Source/core/html/HTMLTextFormControlElement.cpp

Issue 995363002: Implement autocapitalize in Blink to be used by the embedder. (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: update webexposed tests Created 5 years, 9 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « Source/core/html/HTMLTextFormControlElement.h ('k') | Source/core/html/forms/BaseTextInputType.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: Source/core/html/HTMLTextFormControlElement.cpp
diff --git a/Source/core/html/HTMLTextFormControlElement.cpp b/Source/core/html/HTMLTextFormControlElement.cpp
index 03a8854b8cd7236ac39ebfb69cce901d3445bfda..1520edd6dc347a7c8b1fdb00f3b657c568e368b5 100644
--- a/Source/core/html/HTMLTextFormControlElement.cpp
+++ b/Source/core/html/HTMLTextFormControlElement.cpp
@@ -548,6 +548,33 @@ PassRefPtrWillBeRawPtr<Range> HTMLTextFormControlElement::selection() const
return Range::create(document(), startNode, start, endNode, end);
}
+const AtomicString& HTMLTextFormControlElement::autocapitalize() const
+{
+ DEFINE_STATIC_LOCAL(const AtomicString, off, ("off", AtomicString::ConstructFromLiteral));
+ DEFINE_STATIC_LOCAL(const AtomicString, none, ("none", AtomicString::ConstructFromLiteral));
+ DEFINE_STATIC_LOCAL(const AtomicString, characters, ("characters", AtomicString::ConstructFromLiteral));
+ DEFINE_STATIC_LOCAL(const AtomicString, words, ("words", AtomicString::ConstructFromLiteral));
+ DEFINE_STATIC_LOCAL(const AtomicString, sentences, ("sentences", AtomicString::ConstructFromLiteral));
+
+ const AtomicString& value = fastGetAttribute(autocapitalizeAttr);
+ if (equalIgnoringCase(value, none) || equalIgnoringCase(value, off))
+ return none;
+ if (equalIgnoringCase(value, characters))
+ return characters;
+ if (equalIgnoringCase(value, words))
+ return words;
+ if (equalIgnoringCase(value, sentences))
+ return sentences;
+
+ // Invalid or missing value.
+ return defaultAutocapitalize();
+}
+
+void HTMLTextFormControlElement::setAutocapitalize(const AtomicString& autocapitalize)
+{
+ setAttribute(autocapitalizeAttr, autocapitalize);
+}
+
void HTMLTextFormControlElement::restoreCachedSelection()
{
setSelectionRange(m_cachedSelectionStart, m_cachedSelectionEnd, m_cachedSelectionDirection, NotDispatchSelectEvent);
« no previous file with comments | « Source/core/html/HTMLTextFormControlElement.h ('k') | Source/core/html/forms/BaseTextInputType.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698