From 9a421428e238a6dbb9ea9c2f7fd2dde97385252b Mon Sep 17 00:00:00 2001 From: "jhawkins@chromium.org" Date: Thu, 8 Apr 2010 02:04:12 +0000 Subject: AutoFill: Respect the maxlength attribute when filling input elements. BUG=40274 TEST=FormManager.FillFormMaxLength Review URL: http://codereview.chromium.org/1630005 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@43915 0039d316-1c4b-4281-b951-d872f2087c98 --- chrome/renderer/form_manager.cc | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'chrome/renderer/form_manager.cc') diff --git a/chrome/renderer/form_manager.cc b/chrome/renderer/form_manager.cc index 87cfcea..5f19c48 100644 --- a/chrome/renderer/form_manager.cc +++ b/chrome/renderer/form_manager.cc @@ -367,7 +367,10 @@ bool FormManager::FillForm(const FormData& form) { element->formControlType() != WebString::fromUTF8("submit")) { if (element->formControlType() == WebString::fromUTF8("text")) { WebInputElement input_element = element->toElement(); - input_element.setValue(form.fields[i].value()); + // If the maxlength attribute contains a negative value, maxLength() + // returns the default maxlength value. + input_element.setValue( + form.fields[i].value().substr(0, input_element.maxLength())); input_element.setAutofilled(true); } else if (element->formControlType() == WebString::fromUTF8("select-one")) { -- cgit v1.1