| Index: mojo/services/test_service/test_time_service_impl.cc
|
| diff --git a/mojo/services/test_service/test_time_service_impl.cc b/mojo/services/test_service/test_time_service_impl.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..d11d346ad8558aaaf001d423c5ac29dc9906a30b
|
| --- /dev/null
|
| +++ b/mojo/services/test_service/test_time_service_impl.cc
|
| @@ -0,0 +1,43 @@
|
| +// Copyright 2014 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 "base/time/time.h"
|
| +#include "mojo/public/cpp/application/application_impl.h"
|
| +#include "mojo/services/test_service/test_request_tracker.mojom.h"
|
| +#include "mojo/services/test_service/test_time_service_impl.h"
|
| +#include "mojo/services/test_service/tracked_service.h"
|
| +
|
| +namespace mojo {
|
| +namespace test {
|
| +
|
| +TestTimeServiceImpl::TestTimeServiceImpl(
|
| + ApplicationImpl* app_impl,
|
| + InterfaceRequest<TestTimeService> request)
|
| + : app_impl_(app_impl), binding_(this, request.Pass()) {
|
| +}
|
| +
|
| +TestTimeServiceImpl::~TestTimeServiceImpl() {
|
| +}
|
| +
|
| +void TestTimeServiceImpl::StartTrackingRequests(
|
| + const mojo::Callback<void()>& callback) {
|
| + TestRequestTrackerPtr tracker;
|
| + app_impl_->ConnectToService("mojo:test_request_tracker_app", &tracker);
|
| + tracking_.reset(new TrackedService(tracker.Pass(), Name_, callback));
|
| +}
|
| +
|
| +void TestTimeServiceImpl::GetPartyTime(
|
| + const mojo::Callback<void(int64_t)>& callback) {
|
| + if (tracking_)
|
| + tracking_->RecordNewRequest();
|
| + base::Time frozen_time(base::Time::UnixEpoch()
|
| + + base::TimeDelta::FromDays(10957)
|
| + + base::TimeDelta::FromHours(7)
|
| + + base::TimeDelta::FromMinutes(59));
|
| + int64 time(frozen_time.ToInternalValue());
|
| + callback.Run(time);
|
| +}
|
| +
|
| +} // namespace test
|
| +} // namespace mojo
|
|
|