| Index: components/autofill/content/renderer/autofill_agent.cc
|
| diff --git a/components/autofill/content/renderer/autofill_agent.cc b/components/autofill/content/renderer/autofill_agent.cc
|
| index b994e4d4efbdc306de76a6a47f92a40686c33697..4edfe66527958e43ae08213bcccc9f2053898c2f 100644
|
| --- a/components/autofill/content/renderer/autofill_agent.cc
|
| +++ b/components/autofill/content/renderer/autofill_agent.cc
|
| @@ -20,6 +20,7 @@
|
| #include "components/autofill/core/common/autofill_constants.h"
|
| #include "components/autofill/core/common/autofill_data_validation.h"
|
| #include "components/autofill/core/common/autofill_switches.h"
|
| +#include "components/autofill/core/common/autofill_util.h"
|
| #include "components/autofill/core/common/form_data.h"
|
| #include "components/autofill/core/common/form_data_predictions.h"
|
| #include "components/autofill/core/common/form_field_data.h"
|
| @@ -726,8 +727,15 @@ void AutofillAgent::PreviewFieldWithValue(const base::string16& value,
|
| was_query_node_autofilled_ = element_.isAutofilled();
|
| node->setSuggestedValue(value.substr(0, node->maxLength()));
|
| node->setAutofilled(true);
|
| - node->setSelectionRange(node->value().length(),
|
| - node->suggestedValue().length());
|
| +
|
| + if (IsFeatureSubstringMatchEnabled()) {
|
| + size_t start = autofill::GetTextSelectionStart(value, node->value());
|
| + if (start != base::string16::npos)
|
| + node->setSelectionRange(start, node->suggestedValue().length());
|
| + } else {
|
| + node->setSelectionRange(node->value().length(),
|
| + node->suggestedValue().length());
|
| + }
|
| }
|
|
|
| void AutofillAgent::ProcessForms() {
|
|
|