Remove unused label details from old RPC handlers

Change-Id: Ibe2ea9dc416e0e824cfacc5e5e26855b051734a2
This commit is contained in:
Dave Borowitz 2013-02-14 12:22:26 -08:00 committed by Gerrit Code Review
parent 105af8beea
commit 5e9744faa1
5 changed files with 1 additions and 279 deletions

View File

@ -15,12 +15,9 @@
package com.google.gerrit.common.data; package com.google.gerrit.common.data;
import com.google.gerrit.reviewdb.client.Account; import com.google.gerrit.reviewdb.client.Account;
import com.google.gerrit.reviewdb.client.ApprovalCategory;
import com.google.gerrit.reviewdb.client.PatchSetApproval; import com.google.gerrit.reviewdb.client.PatchSetApproval;
import java.sql.Timestamp;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Comparator;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet; import java.util.HashSet;
import java.util.List; import java.util.List;
@ -28,19 +25,6 @@ import java.util.Map;
import java.util.Set; import java.util.Set;
public class ApprovalDetail { public class ApprovalDetail {
public static final Comparator<ApprovalDetail> SORT =
new Comparator<ApprovalDetail>() {
public int compare(final ApprovalDetail o1, final ApprovalDetail o2) {
int cmp;
cmp = o2.hasNonZero - o1.hasNonZero;
if (cmp != 0) return cmp;
return o1.sortOrder.compareTo(o2.sortOrder);
}
};
static final Timestamp EG_0 = new Timestamp(0);
static final Timestamp EG_D = new Timestamp(Long.MAX_VALUE);
protected Account.Id account; protected Account.Id account;
protected List<PatchSetApproval> approvals; protected List<PatchSetApproval> approvals;
protected boolean canRemove; protected boolean canRemove;
@ -49,8 +33,6 @@ public class ApprovalDetail {
private transient Set<String> approved; private transient Set<String> approved;
private transient Set<String> rejected; private transient Set<String> rejected;
private transient Map<String, Integer> values; private transient Map<String, Integer> values;
private transient int hasNonZero;
private transient Timestamp sortOrder = EG_D;
protected ApprovalDetail() { protected ApprovalDetail() {
} }
@ -72,41 +54,6 @@ public class ApprovalDetail {
canRemove = removeable; canRemove = removeable;
} }
@Deprecated
public List<PatchSetApproval> getPatchSetApprovals() {
return approvals;
}
@Deprecated
public PatchSetApproval getPatchSetApproval(ApprovalCategory.Id category) {
for (PatchSetApproval psa : approvals) {
if (psa.getCategoryId().equals(category)) {
return psa;
}
}
return null;
}
public void sortFirst() {
hasNonZero = 1;
sortOrder = ApprovalDetail.EG_0;
}
@Deprecated
public void add(final PatchSetApproval ca) {
approvals.add(ca);
final Timestamp g = ca.getGranted();
if (g != null && g.compareTo(sortOrder) < 0) {
sortOrder = g;
// Value is not set, but code calling this deprecated method does not
// call getValue.
}
if (ca.getValue() != 0) {
hasNonZero = 1;
}
}
public void approved(String label) { public void approved(String label) {
if (approved == null) { if (approved == null) {
approved = new HashSet<String>(); approved = new HashSet<String>();

View File

@ -19,9 +19,6 @@ import com.google.gerrit.reviewdb.client.ChangeMessage;
import com.google.gerrit.reviewdb.client.PatchSet; import com.google.gerrit.reviewdb.client.PatchSet;
import com.google.gerrit.reviewdb.client.Project; import com.google.gerrit.reviewdb.client.Project;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
/** Detail necessary to display a change. */ /** Detail necessary to display a change. */
@ -40,7 +37,6 @@ public class ChangeDetail {
protected List<ChangeInfo> dependsOn; protected List<ChangeInfo> dependsOn;
protected List<ChangeInfo> neededBy; protected List<ChangeInfo> neededBy;
protected List<PatchSet> patchSets; protected List<PatchSet> patchSets;
protected List<ApprovalDetail> approvals;
protected List<SubmitRecord> submitRecords; protected List<SubmitRecord> submitRecords;
protected Project.SubmitType submitType; protected Project.SubmitType submitType;
protected SubmitTypeRecord submitTypeRecord; protected SubmitTypeRecord submitTypeRecord;
@ -191,15 +187,6 @@ public class ChangeDetail {
patchSets = s; patchSets = s;
} }
public List<ApprovalDetail> getApprovals() {
return approvals;
}
public void setApprovals(Collection<ApprovalDetail> list) {
approvals = new ArrayList<ApprovalDetail>(list);
Collections.sort(approvals, ApprovalDetail.SORT);
}
public void setSubmitRecords(List<SubmitRecord> all) { public void setSubmitRecords(List<SubmitRecord> all) {
submitRecords = all; submitRecords = all;
} }

View File

@ -16,12 +16,8 @@ package com.google.gerrit.common.data;
import com.google.gerrit.reviewdb.client.Change; import com.google.gerrit.reviewdb.client.Change;
import com.google.gerrit.reviewdb.client.PatchLineComment; import com.google.gerrit.reviewdb.client.PatchLineComment;
import com.google.gerrit.reviewdb.client.PatchSetApproval;
import com.google.gerrit.reviewdb.client.PatchSetInfo; import com.google.gerrit.reviewdb.client.PatchSetInfo;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
public class PatchSetPublishDetail { public class PatchSetPublishDetail {
@ -29,38 +25,10 @@ public class PatchSetPublishDetail {
protected PatchSetInfo patchSetInfo; protected PatchSetInfo patchSetInfo;
protected Change change; protected Change change;
protected List<PatchLineComment> drafts; protected List<PatchLineComment> drafts;
protected List<PermissionRange> labels;
protected List<ApprovalDetail> approvals;
protected List<SubmitRecord> submitRecords; protected List<SubmitRecord> submitRecords;
protected SubmitTypeRecord submitTypeRecord; protected SubmitTypeRecord submitTypeRecord;
protected List<PatchSetApproval> given;
protected boolean canSubmit; protected boolean canSubmit;
public List<PermissionRange> getLabels() {
return labels;
}
public void setLabels(List<PermissionRange> labels) {
this.labels = labels;
}
public List<ApprovalDetail> getApprovals() {
return approvals;
}
public void setApprovals(Collection<ApprovalDetail> list) {
approvals = new ArrayList<ApprovalDetail>(list);
Collections.sort(approvals, ApprovalDetail.SORT);
}
public void setSubmitRecords(List<SubmitRecord> all) {
submitRecords = all;
}
public List<SubmitRecord> getSubmitRecords() {
return submitRecords;
}
public void setSubmitTypeRecord(SubmitTypeRecord submitTypeRecord) { public void setSubmitTypeRecord(SubmitTypeRecord submitTypeRecord) {
this.submitTypeRecord = submitTypeRecord; this.submitTypeRecord = submitTypeRecord;
} }
@ -69,14 +37,6 @@ public class PatchSetPublishDetail {
return submitTypeRecord; return submitTypeRecord;
} }
public List<PatchSetApproval> getGiven() {
return given;
}
public void setGiven(List<PatchSetApproval> given) {
this.given = given;
}
public void setAccounts(AccountInfoCache accounts) { public void setAccounts(AccountInfoCache accounts) {
this.accounts = accounts; this.accounts = accounts;
} }
@ -113,24 +73,6 @@ public class PatchSetPublishDetail {
return drafts; return drafts;
} }
public PermissionRange getRange(final String permissionName) {
for (PermissionRange s : labels) {
if (s.getName().equals(permissionName)) {
return s;
}
}
return null;
}
public PatchSetApproval getChangeApproval(String label) {
for (PatchSetApproval a : given) {
if (a.getLabel() != null && a.getLabel().equals(label)) {
return a;
}
}
return null;
}
public boolean canSubmit() { public boolean canSubmit() {
return canSubmit; return canSubmit;
} }

View File

@ -14,12 +14,8 @@
package com.google.gerrit.httpd.rpc.changedetail; package com.google.gerrit.httpd.rpc.changedetail;
import com.google.gerrit.common.data.ApprovalDetail;
import com.google.gerrit.common.data.ApprovalType;
import com.google.gerrit.common.data.ApprovalTypes;
import com.google.gerrit.common.data.ChangeDetail; import com.google.gerrit.common.data.ChangeDetail;
import com.google.gerrit.common.data.ChangeInfo; import com.google.gerrit.common.data.ChangeInfo;
import com.google.gerrit.common.data.PermissionRange;
import com.google.gerrit.common.data.SubmitRecord; import com.google.gerrit.common.data.SubmitRecord;
import com.google.gerrit.common.errors.NoSuchEntityException; import com.google.gerrit.common.errors.NoSuchEntityException;
import com.google.gerrit.httpd.rpc.Handler; import com.google.gerrit.httpd.rpc.Handler;
@ -28,7 +24,6 @@ import com.google.gerrit.reviewdb.client.Change;
import com.google.gerrit.reviewdb.client.ChangeMessage; import com.google.gerrit.reviewdb.client.ChangeMessage;
import com.google.gerrit.reviewdb.client.PatchSet; import com.google.gerrit.reviewdb.client.PatchSet;
import com.google.gerrit.reviewdb.client.PatchSetAncestor; import com.google.gerrit.reviewdb.client.PatchSetAncestor;
import com.google.gerrit.reviewdb.client.PatchSetApproval;
import com.google.gerrit.reviewdb.client.RevId; import com.google.gerrit.reviewdb.client.RevId;
import com.google.gerrit.reviewdb.server.ReviewDb; import com.google.gerrit.reviewdb.server.ReviewDb;
import com.google.gerrit.server.AnonymousUser; import com.google.gerrit.server.AnonymousUser;
@ -45,8 +40,6 @@ import com.google.gerrit.server.patch.PatchSetInfoNotAvailableException;
import com.google.gerrit.server.project.ChangeControl; import com.google.gerrit.server.project.ChangeControl;
import com.google.gerrit.server.project.NoSuchChangeException; import com.google.gerrit.server.project.NoSuchChangeException;
import com.google.gerrit.server.query.change.ChangeData; import com.google.gerrit.server.query.change.ChangeData;
import com.google.gerrit.server.workflow.CategoryFunction;
import com.google.gerrit.server.workflow.FunctionState;
import com.google.gwtorm.server.OrmException; import com.google.gwtorm.server.OrmException;
import com.google.gwtorm.server.ResultSet; import com.google.gwtorm.server.ResultSet;
import com.google.inject.Inject; import com.google.inject.Inject;
@ -71,11 +64,7 @@ public class ChangeDetailFactory extends Handler<ChangeDetail> {
ChangeDetailFactory create(Change.Id id); ChangeDetailFactory create(Change.Id id);
} }
private final ApprovalTypes approvalTypes;
private final ChangeControl.Factory changeControlFactory; private final ChangeControl.Factory changeControlFactory;
private final ChangeControl.GenericFactory changeControlGenericFactory;
private final IdentifiedUser.GenericFactory identifiedUserFactory;
private final FunctionState.Factory functionState;
private final PatchSetDetailFactory.Factory patchSetDetail; private final PatchSetDetailFactory.Factory patchSetDetail;
private final AccountInfoCacheFactory aic; private final AccountInfoCacheFactory aic;
private final AnonymousUser anonymousUser; private final AnonymousUser anonymousUser;
@ -96,26 +85,19 @@ public class ChangeDetailFactory extends Handler<ChangeDetail> {
private List<Change> currentDepChanges; private List<Change> currentDepChanges;
@Inject @Inject
ChangeDetailFactory(final ApprovalTypes approvalTypes, ChangeDetailFactory(
final FunctionState.Factory functionState,
final PatchSetDetailFactory.Factory patchSetDetail, final ReviewDb db, final PatchSetDetailFactory.Factory patchSetDetail, final ReviewDb db,
final GitRepositoryManager repoManager, final GitRepositoryManager repoManager,
final ChangeControl.Factory changeControlFactory, final ChangeControl.Factory changeControlFactory,
final ChangeControl.GenericFactory changeControlGenericFactory,
final IdentifiedUser.GenericFactory identifiedUserFactory,
final AccountInfoCacheFactory.Factory accountInfoCacheFactory, final AccountInfoCacheFactory.Factory accountInfoCacheFactory,
final AnonymousUser anonymousUser, final AnonymousUser anonymousUser,
final MergeOp.Factory opFactory, final MergeOp.Factory opFactory,
@GerritServerConfig final Config cfg, @GerritServerConfig final Config cfg,
@Assisted final Change.Id id) { @Assisted final Change.Id id) {
this.approvalTypes = approvalTypes;
this.functionState = functionState;
this.patchSetDetail = patchSetDetail; this.patchSetDetail = patchSetDetail;
this.db = db; this.db = db;
this.repoManager = repoManager; this.repoManager = repoManager;
this.changeControlFactory = changeControlFactory; this.changeControlFactory = changeControlFactory;
this.changeControlGenericFactory = changeControlGenericFactory;
this.identifiedUserFactory = identifiedUserFactory;
this.anonymousUser = anonymousUser; this.anonymousUser = anonymousUser;
this.aic = accountInfoCacheFactory.create(); this.aic = accountInfoCacheFactory.create();
@ -230,55 +212,6 @@ public class ChangeDetailFactory extends Handler<ChangeDetail> {
testMerge) { testMerge) {
ChangeUtil.testMerge(opFactory, detail.getChange()); ChangeUtil.testMerge(opFactory, detail.getChange());
} }
final PatchSet.Id psId = detail.getChange().currentPatchSetId();
final List<PatchSetApproval> allApprovals =
db.patchSetApprovals().byChange(changeId).toList();
if (detail.getChange().getStatus().isOpen()) {
final FunctionState fs = functionState.create(control, psId, allApprovals);
for (final ApprovalType at : approvalTypes.getApprovalTypes()) {
CategoryFunction.forCategory(at.getCategory()).run(at, fs);
}
}
final boolean canRemoveReviewers = detail.getChange().getStatus().isOpen() //
&& control.getCurrentUser() instanceof IdentifiedUser;
final HashMap<Account.Id, ApprovalDetail> ad =
new HashMap<Account.Id, ApprovalDetail>();
for (PatchSetApproval ca : allApprovals) {
ApprovalDetail d = ad.get(ca.getAccountId());
if (d == null) {
d = new ApprovalDetail(ca.getAccountId());
d.setCanRemove(canRemoveReviewers);
ad.put(d.getAccount(), d);
}
if (d.canRemove()) {
d.setCanRemove(control.canRemoveReviewer(ca));
}
if (ca.getPatchSetId().equals(psId)) {
d.add(ca);
}
final ChangeControl chgCtrl =
changeControlGenericFactory.controlFor(detail.getChange(),
identifiedUserFactory.create(ca.getAccountId()));
for (PermissionRange pr : chgCtrl.getLabelRanges()) {
if (pr.getMin() != 0 || pr.getMax() != 0) {
d.votable(pr.getLabel());
}
}
}
final Account.Id owner = detail.getChange().getOwner();
if (ad.containsKey(owner)) {
// Ensure the owner always sorts to the top of the table
//
ad.get(owner).sortFirst();
}
aic.want(ad.keySet());
detail.setApprovals(ad.values());
} }
private boolean isReviewer(Change change) { private boolean isReviewer(Change change) {

View File

@ -14,18 +14,15 @@
package com.google.gerrit.httpd.rpc.changedetail; package com.google.gerrit.httpd.rpc.changedetail;
import com.google.gerrit.common.data.ApprovalDetail;
import com.google.gerrit.common.data.ApprovalType; import com.google.gerrit.common.data.ApprovalType;
import com.google.gerrit.common.data.ApprovalTypes; import com.google.gerrit.common.data.ApprovalTypes;
import com.google.gerrit.common.data.PatchSetPublishDetail; import com.google.gerrit.common.data.PatchSetPublishDetail;
import com.google.gerrit.common.data.PermissionRange; import com.google.gerrit.common.data.PermissionRange;
import com.google.gerrit.common.data.SubmitRecord; import com.google.gerrit.common.data.SubmitRecord;
import com.google.gerrit.httpd.rpc.Handler; import com.google.gerrit.httpd.rpc.Handler;
import com.google.gerrit.reviewdb.client.Account;
import com.google.gerrit.reviewdb.client.Change; import com.google.gerrit.reviewdb.client.Change;
import com.google.gerrit.reviewdb.client.PatchLineComment; import com.google.gerrit.reviewdb.client.PatchLineComment;
import com.google.gerrit.reviewdb.client.PatchSet; import com.google.gerrit.reviewdb.client.PatchSet;
import com.google.gerrit.reviewdb.client.PatchSetApproval;
import com.google.gerrit.reviewdb.client.PatchSetInfo; import com.google.gerrit.reviewdb.client.PatchSetInfo;
import com.google.gerrit.reviewdb.server.ReviewDb; import com.google.gerrit.reviewdb.server.ReviewDb;
import com.google.gerrit.server.IdentifiedUser; import com.google.gerrit.server.IdentifiedUser;
@ -34,14 +31,10 @@ import com.google.gerrit.server.patch.PatchSetInfoFactory;
import com.google.gerrit.server.patch.PatchSetInfoNotAvailableException; import com.google.gerrit.server.patch.PatchSetInfoNotAvailableException;
import com.google.gerrit.server.project.ChangeControl; import com.google.gerrit.server.project.ChangeControl;
import com.google.gerrit.server.project.NoSuchChangeException; import com.google.gerrit.server.project.NoSuchChangeException;
import com.google.gerrit.server.workflow.CategoryFunction;
import com.google.gerrit.server.workflow.FunctionState;
import com.google.gwtorm.server.OrmException; import com.google.gwtorm.server.OrmException;
import com.google.inject.Inject; import com.google.inject.Inject;
import com.google.inject.assistedinject.Assisted; import com.google.inject.assistedinject.Assisted;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
@ -53,10 +46,7 @@ final class PatchSetPublishDetailFactory extends Handler<PatchSetPublishDetail>
private final PatchSetInfoFactory infoFactory; private final PatchSetInfoFactory infoFactory;
private final ReviewDb db; private final ReviewDb db;
private final FunctionState.Factory functionState;
private final ChangeControl.Factory changeControlFactory; private final ChangeControl.Factory changeControlFactory;
private final ChangeControl.GenericFactory changeControlGenericFactory;
private final IdentifiedUser.GenericFactory identifiedUserFactory;
private final ApprovalTypes approvalTypes; private final ApprovalTypes approvalTypes;
private final AccountInfoCacheFactory aic; private final AccountInfoCacheFactory aic;
private final IdentifiedUser user; private final IdentifiedUser user;
@ -71,18 +61,12 @@ final class PatchSetPublishDetailFactory extends Handler<PatchSetPublishDetail>
PatchSetPublishDetailFactory(final PatchSetInfoFactory infoFactory, PatchSetPublishDetailFactory(final PatchSetInfoFactory infoFactory,
final ReviewDb db, final ReviewDb db,
final AccountInfoCacheFactory.Factory accountInfoCacheFactory, final AccountInfoCacheFactory.Factory accountInfoCacheFactory,
final FunctionState.Factory functionState,
final ChangeControl.Factory changeControlFactory, final ChangeControl.Factory changeControlFactory,
final ChangeControl.GenericFactory changeControlGenericFactory,
final IdentifiedUser.GenericFactory identifiedUserFactory,
final ApprovalTypes approvalTypes, final ApprovalTypes approvalTypes,
final IdentifiedUser user, @Assisted final PatchSet.Id patchSetId) { final IdentifiedUser user, @Assisted final PatchSet.Id patchSetId) {
this.infoFactory = infoFactory; this.infoFactory = infoFactory;
this.db = db; this.db = db;
this.functionState = functionState;
this.changeControlFactory = changeControlFactory; this.changeControlFactory = changeControlFactory;
this.changeControlGenericFactory = changeControlGenericFactory;
this.identifiedUserFactory = identifiedUserFactory;
this.approvalTypes = approvalTypes; this.approvalTypes = approvalTypes;
this.aic = accountInfoCacheFactory.create(); this.aic = accountInfoCacheFactory.create();
this.user = user; this.user = user;
@ -107,9 +91,6 @@ final class PatchSetPublishDetailFactory extends Handler<PatchSetPublishDetail>
detail.setChange(change); detail.setChange(change);
detail.setDrafts(drafts); detail.setDrafts(drafts);
List<PermissionRange> allowed = Collections.emptyList();
List<PatchSetApproval> given = Collections.emptyList();
if (change.getStatus().isOpen() if (change.getStatus().isOpen()
&& patchSetId.equals(change.currentPatchSetId())) { && patchSetId.equals(change.currentPatchSetId())) {
// TODO Push this selection of labels down into the Prolog interpreter. // TODO Push this selection of labels down into the Prolog interpreter.
@ -126,11 +107,6 @@ final class PatchSetPublishDetailFactory extends Handler<PatchSetPublishDetail>
rangeByName.put(r.getLabel(), r); rangeByName.put(r.getLabel(), r);
} }
} }
allowed = new ArrayList<PermissionRange>();
given = db.patchSetApprovals() //
.byPatchSetUser(patchSetId, user.getAccountId()) //
.toList();
boolean couldSubmit = false; boolean couldSubmit = false;
List<SubmitRecord> submitRecords = control.canSubmit(db, patchSet); List<SubmitRecord> submitRecords = control.canSubmit(db, patchSet);
@ -148,10 +124,6 @@ final class PatchSetPublishDetailFactory extends Handler<PatchSetPublishDetail>
boolean canMakeOk = false; boolean canMakeOk = false;
PermissionRange range = rangeByName.get(lbl.label); PermissionRange range = rangeByName.get(lbl.label);
if (range != null) { if (range != null) {
if (!allowed.contains(range)) {
allowed.add(range);
}
ApprovalType at = approvalTypes.byLabel(lbl.label); ApprovalType at = approvalTypes.byLabel(lbl.label);
if (at == null || at.getMax().getValue() == range.getMax()) { if (at == null || at.getMax().getValue() == range.getMax()) {
canMakeOk = true; canMakeOk = true;
@ -186,70 +158,11 @@ final class PatchSetPublishDetailFactory extends Handler<PatchSetPublishDetail>
if (couldSubmit && control.getRefControl().canSubmit()) { if (couldSubmit && control.getRefControl().canSubmit()) {
detail.setCanSubmit(true); detail.setCanSubmit(true);
} }
detail.setSubmitRecords(submitRecords);
} }
detail.setSubmitTypeRecord(control.getSubmitTypeRecord(db, patchSet)); detail.setSubmitTypeRecord(control.getSubmitTypeRecord(db, patchSet));
detail.setLabels(allowed);
detail.setGiven(given);
loadApprovals(detail, control);
detail.setAccounts(aic.create()); detail.setAccounts(aic.create());
return detail; return detail;
} }
private void loadApprovals(final PatchSetPublishDetail detail,
final ChangeControl control) throws OrmException, NoSuchChangeException {
final PatchSet.Id psId = detail.getChange().currentPatchSetId();
final Change.Id changeId = patchSetId.getParentKey();
final List<PatchSetApproval> allApprovals =
db.patchSetApprovals().byChange(changeId).toList();
if (detail.getChange().getStatus().isOpen()) {
final FunctionState fs = functionState.create(control, psId, allApprovals);
for (final ApprovalType at : approvalTypes.getApprovalTypes()) {
CategoryFunction.forCategory(at.getCategory()).run(at, fs);
}
}
final boolean canRemoveReviewers = detail.getChange().getStatus().isOpen() //
&& control.getCurrentUser() instanceof IdentifiedUser;
final HashMap<Account.Id, ApprovalDetail> ad =
new HashMap<Account.Id, ApprovalDetail>();
for (PatchSetApproval ca : allApprovals) {
ApprovalDetail d = ad.get(ca.getAccountId());
if (d == null) {
d = new ApprovalDetail(ca.getAccountId());
d.setCanRemove(canRemoveReviewers);
ad.put(d.getAccount(), d);
}
if (d.canRemove()) {
d.setCanRemove(control.canRemoveReviewer(ca));
}
if (ca.getPatchSetId().equals(psId)) {
d.add(ca);
}
final ChangeControl chgCtrl =
changeControlGenericFactory.controlFor(detail.getChange(),
identifiedUserFactory.create(ca.getAccountId()));
for (PermissionRange pr : chgCtrl.getLabelRanges()) {
if (pr.getMin() != 0 || pr.getMax() != 0) {
d.votable(pr.getLabel());
}
}
}
final Account.Id owner = detail.getChange().getOwner();
if (ad.containsKey(owner)) {
// Ensure the owner always sorts to the top of the table
ad.get(owner).sortFirst();
}
aic.want(ad.keySet());
detail.setApprovals(ad.values());
}
} }