| Index: components/translate/core/common/translation_logging_helper.cc
|
| diff --git a/components/translate/core/common/translation_logging_helper.cc b/components/translate/core/common/translation_logging_helper.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..ac6c0d2ed9b37fffd83a45036b23fecfcae3edc0
|
| --- /dev/null
|
| +++ b/components/translate/core/common/translation_logging_helper.cc
|
| @@ -0,0 +1,71 @@
|
| +// Copyright 2017 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "components/translate/core/common/translation_logging_helper.h"
|
| +
|
| +#include "base/logging.h"
|
| +#include "base/time/time.h"
|
| +#include "components/metrics/proto/translate_event.pb.h"
|
| +#include "components/sync/protocol/user_event_specifics.pb.h"
|
| +
|
| +namespace translate {
|
| +namespace {
|
| +using metrics::TranslateEventProto;
|
| +} // namespace
|
| +
|
| +bool ConstructTranslateEvent(const int64_t navigation_id,
|
| + const TranslateEventProto& translate_event,
|
| + sync_pb::UserEventSpecifics* const specifics) {
|
| + specifics->set_event_time_usec(base::Time::Now().ToInternalValue());
|
| +
|
| + // TODO(renjieliu): Revisit this field when the best way to identify
|
| + // navigations is determined.
|
| + specifics->set_navigation_id(navigation_id);
|
| + auto* const translation = specifics->mutable_translation();
|
| + translation->set_from_language_code(translate_event.source_language());
|
| + translation->set_to_language_code(translate_event.target_language());
|
| + switch (translate_event.event_type()) {
|
| + case TranslateEventProto::UNKNOWN:
|
| + translation->set_interaction(sync_pb::Translation::UNKNOWN);
|
| + break;
|
| + case TranslateEventProto::USER_ACCEPT:
|
| + if (translate_event.has_modified_source_language() ||
|
| + translate_event.has_modified_target_language()) {
|
| + // Special case, since we don't have event enum telling us it's actually
|
| + // modified by user, we do this by check whether this event has modified
|
| + // source or target language.
|
| + if (translate_event.has_modified_source_language()) {
|
| + translation->set_from_language_code(
|
| + translate_event.modified_source_language());
|
| + }
|
| + if (translate_event.has_modified_target_language()) {
|
| + translation->set_to_language_code(
|
| + translate_event.modified_target_language());
|
| + }
|
| + translation->set_interaction(sync_pb::Translation::MANUAL);
|
| + } else {
|
| + translation->set_interaction(sync_pb::Translation::ACCEPT);
|
| + }
|
| + break;
|
| + case TranslateEventProto::USER_DECLINE:
|
| + translation->set_interaction(sync_pb::Translation::DECLINE);
|
| + break;
|
| + case TranslateEventProto::USER_IGNORE:
|
| + translation->set_interaction(sync_pb::Translation::IGNORED);
|
| + break;
|
| + case TranslateEventProto::USER_DISMISS:
|
| + translation->set_interaction(sync_pb::Translation::DISMISSED);
|
| + break;
|
| + case TranslateEventProto::USER_REVERT:
|
| + translation->set_interaction(sync_pb::Translation::TRANSLATION_REVERTED);
|
| + break;
|
| + case TranslateEventProto::AUTOMATICALLY_TRANSLATED:
|
| + translation->set_interaction(sync_pb::Translation::AUTOMATIC_TRANSLATION);
|
| + break;
|
| + default: // We don't care about other events.
|
| + return false;
|
| + }
|
| + return true;
|
| +}
|
| +} // namespace translate
|
|
|