Bug 154906

Summary: Align HTMLInputElement.maxLength with the specification
Product: WebKit Reporter: Chris Dumez <cdumez>
Component: DOMAssignee: Chris Dumez <cdumez>
Status: RESOLVED FIXED    
Severity: Normal CC: commit-queue, darin, rniwa, sam
Priority: P2 Keywords: WebExposed
Version: WebKit Nightly Build   
Hardware: Unspecified   
OS: Unspecified   
See Also: https://bugs.webkit.org/show_bug.cgi?id=44883
Attachments:
Description Flags
Patch
none
Patch none

Chris Dumez
Reported 2016-03-01 21:44:26 PST
Attachments
Patch (35.24 KB, patch)
2016-03-01 22:11 PST, Chris Dumez
no flags
Patch (36.08 KB, patch)
2016-03-02 11:51 PST, Chris Dumez
no flags
Chris Dumez
Comment 1 2016-03-01 22:11:34 PST
Ryosuke Niwa
Comment 2 2016-03-01 22:47:06 PST
Comment on attachment 272632 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=272632&action=review > Source/WebCore/ChangeLog:24 > + You should probably mention that textarea's maxLength already returned -1 before this change. Or did you change that recently also? If so, it would be nice to refer to the revision in the change log. > Source/WebCore/html/HTMLInputElement.cpp:1260 > + return std::min(static_cast<unsigned>(m_maxLength), maximumLength); Should we just check m_maxLength > maximumLength in the above if instead of using std::max here? That might read better overall.
Darin Adler
Comment 3 2016-03-02 08:59:13 PST
Comment on attachment 272632 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=272632&action=review Even if the public API uses negative numbers as magic values, it seems to me would could do some cleaner stuff inside WebKit itself. Some suggestions below: > Source/WebCore/html/HTMLInputElement.cpp:-99 > - , m_maxLength(maximumLength) I think it’s really confusing to have m_maxLength and maximumLength. Those are the same names, but they are two different concepts. I think maximumLength should be renamed maxEffectiveLength, maximumEffectiveLength, maxEffectiveMaxLength, or maximumEffectiveMaxLength. > Source/WebCore/html/HTMLInputElement.cpp:1258 > + if (m_maxLength < 0) > + return maximumLength; A cleaner, albeit less efficient, way to do all of this would be to use Optional<int> for m_maxLength and friends, and implement the -1 magic value meaning "no length" only in the maxLengthForBindings function. If we want to do the trickier way, then I will note -1 will automatically do the right thing when converted to unsigned, so I suggest removing this code and instead writing a comment. Or you could write a static_assert and a comment, perhaps something like this: // The number -1 represents no maximum at all; conveniently it becomes a super-large value when converted to unsigned. std::static_assert(std::min<unsigned>(-1, maximumLength) == maximumLength, "-1 means no maximum"); >> Source/WebCore/html/HTMLInputElement.cpp:1260 >> + return std::min(static_cast<unsigned>(m_maxLength), maximumLength); > > Should we just check m_maxLength > maximumLength in the above if instead of using std::max here? > That might read better overall. I personally find the use of std::min a little clearer readable than an if statement. However, I think this is better than static_cast: return std::min<unsigned>(m_maxLength, maximumLength); > Source/WebCore/html/HTMLInputElement.cpp:1743 > - int maxLength = std::min(parseHTMLNonNegativeInteger(value).valueOr(maximumLength), maximumLength); > int oldMaxLength = m_maxLength; > - m_maxLength = maxLength; > - if (oldMaxLength != maxLength) > + m_maxLength = parsedMaxLength(); > + if (oldMaxLength != m_maxLength) > updateValueIfNeeded(); > setNeedsStyleRecalc(); > updateValidity(); I think it would be more correct to do work only if effectiveMaxLength() changed. In fact, I am not sure why setNeedsStyleRecalc and updateValidity need to be called if effectiveMaxLength didn’t change, but it seems especially clear that updateValueIfNeeded should be called only if effectiveMaxLength changed, rather than if m_maxLength changed. > Source/WebCore/html/HTMLTextAreaElement.h:49 > + int effectiveMaxLength() const { return m_maxLength; } Seems peculiar to continue using -1 here to indicate there is no maximum. Is that really OK? Might be worth returning to clean that up. > Source/WebCore/html/HTMLTextFormControlElement.cpp:776 > + auto optionalMaxLength = parseHTMLNonNegativeInteger(fastGetAttribute(maxlengthAttr)); > + if (!optionalMaxLength) > + return -1; > + return optionalMaxLength.value(); This should be a one-liner that uses valueOr(-1) if we are going to keep this.
Chris Dumez
Comment 4 2016-03-02 09:04:41 PST
Comment on attachment 272632 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=272632&action=review >> Source/WebCore/html/HTMLTextFormControlElement.cpp:776 >> + return optionalMaxLength.value(); > > This should be a one-liner that uses valueOr(-1) if we are going to keep this. Yes, I did it this way for now because the other patch that allows parseHTMLNonNegativeInteger().valueOr(-1) has not landed yet.
Chris Dumez
Comment 5 2016-03-02 09:25:18 PST
Comment on attachment 272632 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=272632&action=review >> Source/WebCore/html/HTMLTextAreaElement.h:49 >> + int effectiveMaxLength() const { return m_maxLength; } > > Seems peculiar to continue using -1 here to indicate there is no maximum. Is that really OK? Might be worth returning to clean that up. Yes, this is OK. unlike HTMLInputElement, HTMLTextAreaElement does not clamp the maxLength to a large value. Instead, the call sites of HTMLTextAreaElement::effectiveMaxLength() (that is HTMLTextAreaElement::tooLong() and HTMLTextAreaElement::handleBeforeTextInsertedEvent()) correctly handle -1 as a value indicating no limit.
Chris Dumez
Comment 6 2016-03-02 09:59:08 PST
Comment on attachment 272632 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=272632&action=review >> Source/WebCore/html/HTMLInputElement.cpp:1258 >> + return maximumLength; > > A cleaner, albeit less efficient, way to do all of this would be to use Optional<int> for m_maxLength and friends, and implement the -1 magic value meaning "no length" only in the maxLengthForBindings function. > > If we want to do the trickier way, then I will note -1 will automatically do the right thing when converted to unsigned, so I suggest removing this code and instead writing a comment. Or you could write a static_assert and a comment, perhaps something like this: > > // The number -1 represents no maximum at all; conveniently it becomes a super-large value when converted to unsigned. > std::static_assert(std::min<unsigned>(-1, maximumLength) == maximumLength, "-1 means no maximum"); It looks like std::min() is only constexpr in C++14, I cannot seem to get this to build.
Chris Dumez
Comment 7 2016-03-02 11:51:44 PST
WebKit Commit Bot
Comment 8 2016-03-02 12:38:16 PST
Comment on attachment 272669 [details] Patch Clearing flags on attachment: 272669 Committed r197458: <http://trac.webkit.org/changeset/197458>
WebKit Commit Bot
Comment 9 2016-03-02 12:38:19 PST
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.