// 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/engine/traffic_logger.h" #include #include "base/json/json_writer.h" #include "base/logging.h" #include "base/memory/scoped_ptr.h" #include "base/values.h" #include "sync/protocol/proto_value_conversions.h" #include "sync/protocol/sync.pb.h" namespace syncer { namespace { template void LogData(const T& data, scoped_ptr(*to_dictionary_value)(const T&, bool), const std::string& description) { if (::logging::DEBUG_MODE && VLOG_IS_ON(1)) { scoped_ptr value = (*to_dictionary_value)(data, true /* include_specifics */); std::string message; base::JSONWriter::WriteWithOptions( *value, base::JSONWriter::OPTIONS_PRETTY_PRINT, &message); DVLOG(1) << "\n" << description << "\n" << message << "\n"; } } } // namespace void LogClientToServerMessage(const sync_pb::ClientToServerMessage& msg) { LogData(msg, &ClientToServerMessageToValue, "******Client To Server Message******"); } void LogClientToServerResponse( const sync_pb::ClientToServerResponse& response) { LogData(response, &ClientToServerResponseToValue, "******Server Response******"); } } // namespace syncer