| package com.googlesource.gerrit.plugins.gerritcachedrefdb; |
| |
| import com.google.inject.Inject; |
| import com.google.inject.assistedinject.Assisted; |
| import java.io.IOException; |
| import java.util.EnumSet; |
| import org.eclipse.jgit.lib.AnyObjectId; |
| import org.eclipse.jgit.lib.ObjectId; |
| import org.eclipse.jgit.lib.PersonIdent; |
| import org.eclipse.jgit.lib.Ref; |
| import org.eclipse.jgit.lib.RefDatabase; |
| import org.eclipse.jgit.lib.RefUpdate; |
| import org.eclipse.jgit.lib.Repository; |
| import org.eclipse.jgit.revwalk.RevWalk; |
| import org.eclipse.jgit.transport.PushCertificate; |
| |
| class RefUpdateWithCacheUpdate extends RefUpdate { |
| interface Factory { |
| RefUpdateWithCacheUpdate create(RefDatabase refDb, Repository repo, RefUpdate delegate); |
| } |
| |
| private static final String NOT_SUPPORTED_MSG = "Should never be called"; |
| private static final EnumSet<Result> SUCCESSFUL_UPDATES = |
| EnumSet.of(Result.NEW, Result.FORCED, Result.FAST_FORWARD, Result.RENAMED); |
| |
| private final RefByNameCacheWrapper refsCache; |
| private final RefDatabase refDb; |
| private final Repository repo; |
| private final RefUpdate delegate; |
| |
| @Inject |
| RefUpdateWithCacheUpdate( |
| RefByNameCacheWrapper refsCache, |
| @Assisted RefDatabase refDb, |
| @Assisted Repository repo, |
| @Assisted RefUpdate delegate) { |
| super(delegate.getRef()); |
| this.refsCache = refsCache; |
| this.refDb = refDb; |
| this.repo = repo; |
| this.delegate = delegate; |
| } |
| |
| @Override |
| public String getName() { |
| return delegate.getName(); |
| } |
| |
| @Override |
| public Ref getRef() { |
| return delegate.getRef(); |
| } |
| |
| @Override |
| public ObjectId getNewObjectId() { |
| return delegate.getNewObjectId(); |
| } |
| |
| @Override |
| public void setDetachingSymbolicRef() { |
| delegate.setDetachingSymbolicRef(); |
| } |
| |
| @Override |
| public boolean isDetachingSymbolicRef() { |
| return delegate.isDetachingSymbolicRef(); |
| } |
| |
| @Override |
| public void setNewObjectId(AnyObjectId id) { |
| delegate.setNewObjectId(id); |
| } |
| |
| @Override |
| public ObjectId getExpectedOldObjectId() { |
| return delegate.getExpectedOldObjectId(); |
| } |
| |
| @Override |
| public void setExpectedOldObjectId(AnyObjectId id) { |
| delegate.setExpectedOldObjectId(id); |
| } |
| |
| @Override |
| public boolean isForceUpdate() { |
| return delegate.isForceUpdate(); |
| } |
| |
| @Override |
| public void setForceUpdate(boolean b) { |
| delegate.setForceUpdate(b); |
| } |
| |
| @Override |
| public PersonIdent getRefLogIdent() { |
| return delegate.getRefLogIdent(); |
| } |
| |
| @Override |
| public void setRefLogIdent(PersonIdent pi) { |
| delegate.setRefLogIdent(pi); |
| } |
| |
| @Override |
| public String getRefLogMessage() { |
| return delegate.getRefLogMessage(); |
| } |
| |
| @Override |
| public void setRefLogMessage(String msg, boolean appendStatus) { |
| delegate.setRefLogMessage(msg, appendStatus); |
| } |
| |
| @Override |
| public void disableRefLog() { |
| delegate.disableRefLog(); |
| } |
| |
| @Override |
| public void setForceRefLog(boolean force) { |
| delegate.setForceRefLog(force); |
| } |
| |
| @Override |
| public ObjectId getOldObjectId() { |
| return delegate.getOldObjectId(); |
| } |
| |
| @Override |
| public void setPushCertificate(PushCertificate cert) { |
| delegate.setPushCertificate(cert); |
| } |
| |
| @Override |
| public Result getResult() { |
| return delegate.getResult(); |
| } |
| |
| @Override |
| public Result forceUpdate() throws IOException { |
| return evictCache(delegate.forceUpdate()); |
| } |
| |
| @Override |
| public Result update() throws IOException { |
| return evictCache(delegate.update()); |
| } |
| |
| @Override |
| public Result update(RevWalk walk) throws IOException { |
| return evictCache(delegate.update(walk)); |
| } |
| |
| @Override |
| public Result delete() throws IOException { |
| return evictCache(delegate.delete()); |
| } |
| |
| @Override |
| public Result delete(RevWalk walk) throws IOException { |
| return evictCache(delegate.delete(walk)); |
| } |
| |
| @Override |
| public Result link(String target) throws IOException { |
| return evictCache(delegate.link(target)); |
| } |
| |
| @Override |
| public void setCheckConflicting(boolean check) { |
| delegate.setCheckConflicting(check); |
| } |
| |
| @Override |
| protected RefDatabase getRefDatabase() { |
| return refDb; |
| } |
| |
| @Override |
| protected Repository getRepository() { |
| return repo; |
| } |
| |
| @Override |
| protected boolean tryLock(boolean deref) throws IOException { |
| throw new UnsupportedOperationException(NOT_SUPPORTED_MSG); |
| } |
| |
| @Override |
| protected void unlock() { |
| throw new UnsupportedOperationException(NOT_SUPPORTED_MSG); |
| } |
| |
| @Override |
| protected Result doUpdate(Result desiredResult) throws IOException { |
| throw new UnsupportedOperationException(NOT_SUPPORTED_MSG); |
| } |
| |
| @Override |
| protected Result doDelete(Result desiredResult) throws IOException { |
| throw new UnsupportedOperationException(NOT_SUPPORTED_MSG); |
| } |
| |
| @Override |
| protected Result doLink(String target) throws IOException { |
| throw new UnsupportedOperationException(NOT_SUPPORTED_MSG); |
| } |
| |
| private Result evictCache(Result r) { |
| if (SUCCESSFUL_UPDATES.contains(r)) { |
| refsCache.evict(repo.getIdentifier(), getName()); |
| } |
| return r; |
| } |
| } |