// Copyright (c) 2012 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 "sync/api/sync_error.h" #include <ostream> #include "base/location.h" #include "base/logging.h" #include "sync/internal_api/public/base/model_type.h" namespace syncer { SyncError::SyncError() { Clear(); } SyncError::SyncError(const tracked_objects::Location& location, ErrorType error_type, const std::string& message, ModelType model_type) { DCHECK(error_type != UNSET); Init(location, message, model_type, error_type); PrintLogError(); } SyncError::SyncError(const SyncError& other) { Copy(other); } SyncError::~SyncError() { } SyncError& SyncError::operator=(const SyncError& other) { if (this == &other) { return *this; } Copy(other); return *this; } void SyncError::Copy(const SyncError& other) { if (other.IsSet()) { Init(other.location(), other.message(), other.model_type(), other.error_type()); } else { Clear(); } } void SyncError::Clear() { location_.reset(); message_ = std::string(); model_type_ = UNSPECIFIED; error_type_ = UNSET; } void SyncError::Reset(const tracked_objects::Location& location, const std::string& message, ModelType model_type) { Init(location, message, model_type, DATATYPE_ERROR); PrintLogError(); } void SyncError::Init(const tracked_objects::Location& location, const std::string& message, ModelType model_type, ErrorType error_type) { location_.reset(new tracked_objects::Location(location)); message_ = message; model_type_ = model_type; error_type_ = error_type; } bool SyncError::IsSet() const { return error_type_ != UNSET; } const tracked_objects::Location& SyncError::location() const { CHECK(IsSet()); return *location_; } const std::string& SyncError::message() const { CHECK(IsSet()); return message_; } ModelType SyncError::model_type() const { CHECK(IsSet()); return model_type_; } SyncError::ErrorType SyncError::error_type() const { CHECK(IsSet()); return error_type_; } SyncError::Severity SyncError::GetSeverity() const { switch (error_type_) { case UNREADY_ERROR: case DATATYPE_POLICY_ERROR: return SYNC_ERROR_SEVERITY_INFO; default: return SYNC_ERROR_SEVERITY_ERROR; } } std::string SyncError::GetMessagePrefix() const { std::string type_message; switch (error_type_) { case UNRECOVERABLE_ERROR: type_message = "unrecoverable error was encountered: "; break; case DATATYPE_ERROR: type_message = "datatype error was encountered: "; break; case PERSISTENCE_ERROR: type_message = "persistence error was encountered: "; break; case CRYPTO_ERROR: type_message = "cryptographer error was encountered: "; break; case UNREADY_ERROR: type_message = "unready error was encountered: "; break; case DATATYPE_POLICY_ERROR: type_message = "disabled due to configuration constraints: "; break; case UNSET: NOTREACHED() << "Invalid error type"; break; } return type_message; } std::string SyncError::ToString() const { if (!IsSet()) { return std::string(); } return location_->ToString() + ", " + ModelTypeToString(model_type_) + " " + GetMessagePrefix() + message_; } void SyncError::PrintLogError() const { logging::LogSeverity logSeverity = (GetSeverity() == SYNC_ERROR_SEVERITY_INFO) ? logging::LOG_VERBOSE : logging::LOG_ERROR; LAZY_STREAM(logging::LogMessage(location_->file_name(), location_->line_number(), logSeverity).stream(), logSeverity >= ::logging::GetMinLogLevel()) << ModelTypeToString(model_type_) << " " << GetMessagePrefix() << message_; } void PrintTo(const SyncError& sync_error, std::ostream* os) { *os << sync_error.ToString(); } } // namespace syncer