| Index: sync/engine/committer_list.cc
|
| diff --git a/sync/engine/committer_list.cc b/sync/engine/committer_list.cc
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..24ae64f9c0a3bab7d85a3c4d923ece6636215845
|
| --- /dev/null
|
| +++ b/sync/engine/committer_list.cc
|
| @@ -0,0 +1,61 @@
|
| +// Copyright (c) 2013 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/committer_list.h"
|
| +
|
| +#include <map>
|
| +
|
| +#include "sync/engine/sync_directory_commit_contribution.h"
|
| +#include "sync/engine/sync_directory_commit_contributor.h"
|
| +#include "sync/protocol/sync.pb.h"
|
| +
|
| +namespace syncer {
|
| +
|
| +typedef std::map<ModelType, size_t> TypeToIndexMap;
|
| +
|
| +CommitterList::CommitterList()
|
| + : commit_contributor_deleter_(&commit_contributor_map_) {}
|
| +
|
| +CommitterList::~CommitterList() {}
|
| +
|
| +void CommitterList::RegisterType(
|
| + ModelType type,
|
| + SyncDirectoryCommitContributor* contributor) {
|
| + bool inserted =
|
| + commit_contributor_map_.insert(std::make_pair(type, contributor)).second;
|
| + DCHECK(inserted) << "Attempt to override existing type handler in map";
|
| +}
|
| +
|
| +void CommitterList::GatherCommitContributions(
|
| + ModelTypeSet commit_types,
|
| + size_t max_entries,
|
| + ContributionMap* contributions) {
|
| + size_t num_entries = 0;
|
| + for (ModelTypeSet::Iterator it = commit_types.First();
|
| + it.Good(); it.Inc()) {
|
| + CommitContributorMap::iterator cm_it =
|
| + commit_contributor_map_.find(it.Get());
|
| + if (cm_it == commit_contributor_map_.end()) {
|
| + NOTREACHED()
|
| + << "Could not find requested type " << ModelTypeToString(it.Get())
|
| + << " in contributor map.";
|
| + continue;
|
| + }
|
| + size_t spaces_remaining = max_entries - num_entries;
|
| + SyncDirectoryCommitContribution* contribution =
|
| + cm_it->second->GetContribution(spaces_remaining);
|
| + if (contribution) {
|
| + num_entries += contribution->GetNumEntries();
|
| + contributions->insert(std::make_pair(it.Get(), contribution));
|
| + }
|
| + if (num_entries == max_entries) {
|
| + break; // No point in continuting to iterate in this case.
|
| + } else if (num_entries > max_entries) {
|
| + NOTREACHED() << "Number of commit entries exceeds maximum.";
|
| + break; // This should never happen, but let's exit early if it does.
|
| + }
|
| + }
|
| +}
|
| +
|
| +} // namespace syncer
|
|
|