Merge "IsStarredByPredicate: Don't implement ChangeDataSource"

This commit is contained in:
Edwin Kempin
2016-02-12 11:08:10 +00:00
committed by Gerrit Code Review
2 changed files with 3 additions and 142 deletions

View File

@@ -1,113 +0,0 @@
// Copyright (C) 2010 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.google.gerrit.server.query.change;
import com.google.gerrit.reviewdb.client.Change;
import com.google.gerrit.reviewdb.server.ReviewDb;
import com.google.gwtorm.server.ResultSet;
import com.google.inject.Provider;
import java.util.HashSet;
import java.util.Iterator;
import java.util.NoSuchElementException;
import java.util.Set;
abstract class ChangeDataResultSet<T> extends AbstractResultSet<ChangeData> {
static ResultSet<ChangeData> change(final ChangeData.Factory factory,
final Provider<ReviewDb> db, final ResultSet<Change> rs) {
return new ChangeDataResultSet<Change>(rs, true) {
@Override
ChangeData convert(Change t) {
return factory.create(db.get(), t);
}
};
}
private final ResultSet<T> source;
private final boolean unique;
ChangeDataResultSet(ResultSet<T> source, boolean unique) {
this.source = source;
this.unique = unique;
}
@Override
public Iterator<ChangeData> iterator() {
if (unique) {
return new Iterator<ChangeData>() {
private final Iterator<T> itr = source.iterator();
@Override
public boolean hasNext() {
return itr.hasNext();
}
@Override
public ChangeData next() {
return convert(itr.next());
}
@Override
public void remove() {
throw new UnsupportedOperationException();
}
};
} else {
return new Iterator<ChangeData>() {
private final Iterator<T> itr = source.iterator();
private final Set<Change.Id> seen = new HashSet<>();
private ChangeData next;
@Override
public boolean hasNext() {
if (next != null) {
return true;
}
while (itr.hasNext()) {
ChangeData d = convert(itr.next());
if (seen.add(d.getId())) {
next = d;
return true;
}
}
return false;
}
@Override
public ChangeData next() {
if (hasNext()) {
ChangeData r = next;
next = null;
return r;
}
throw new NoSuchElementException();
}
@Override
public void remove() {
throw new UnsupportedOperationException();
}
};
}
}
@Override
public void close() {
source.close();
}
abstract ChangeData convert(T t);
}

View File

@@ -17,19 +17,15 @@ package com.google.gerrit.server.query.change;
import com.google.common.collect.Lists;
import com.google.gerrit.reviewdb.client.Change;
import com.google.gerrit.server.CurrentUser;
import com.google.gerrit.server.IdentifiedUser;
import com.google.gerrit.server.query.OrPredicate;
import com.google.gerrit.server.query.Predicate;
import com.google.gerrit.server.query.QueryParseException;
import com.google.gerrit.server.query.change.ChangeQueryBuilder.Arguments;
import com.google.gwtorm.server.OrmException;
import com.google.gwtorm.server.ResultSet;
import java.util.List;
import java.util.Set;
class IsStarredByPredicate extends OrPredicate<ChangeData> implements
ChangeDataSource {
class IsStarredByPredicate extends OrPredicate<ChangeData> {
private static String describe(CurrentUser user) {
if (user.isIdentifiedUser()) {
return user.getAccountId().toString();
@@ -45,17 +41,11 @@ class IsStarredByPredicate extends OrPredicate<ChangeData> implements
return r;
}
private final Arguments args;
private final CurrentUser user;
IsStarredByPredicate(Arguments args) throws QueryParseException {
this(args, args.getIdentifiedUser());
}
private IsStarredByPredicate(Arguments args, IdentifiedUser user) {
super(predicates(user.getStarredChanges()));
this.args = args;
this.user = user;
super(predicates(args.getIdentifiedUser().getStarredChanges()));
this.user = args.getIdentifiedUser();
}
@Override
@@ -63,22 +53,6 @@ class IsStarredByPredicate extends OrPredicate<ChangeData> implements
return user.getStarredChanges().contains(object.getId());
}
@Override
public ResultSet<ChangeData> read() throws OrmException {
return ChangeDataResultSet.change(args.changeDataFactory, args.db,
args.db.get().changes().get(user.getStarredChanges()));
}
@Override
public boolean hasChange() {
return true;
}
@Override
public int getCardinality() {
return 10;
}
@Override
public int getCost() {
return 0;