Merge "IsStarredByPredicate: Don't implement ChangeDataSource"
This commit is contained in:
@@ -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);
|
||||
}
|
||||
@@ -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;
|
||||
|
||||
Reference in New Issue
Block a user