*/
package org.opendaylight.controller.md.sal.trace.closetracker.impl;
-import java.time.Instant;
import javax.annotation.Nullable;
/**
closeTracker.removeFromTrackedRegistry();
}
- @Override
- public final Instant getObjectCreated() {
- return closeTracker.getObjectCreated();
- }
-
@Override
public @Nullable StackTraceElement[] getAllocationContextStackTrace() {
return closeTracker.getAllocationContextStackTrace();
*/
package org.opendaylight.controller.md.sal.trace.closetracker.impl;
-import java.time.Instant;
import javax.annotation.Nullable;
/**
*/
public interface CloseTracked<T extends CloseTracked<T>> {
- Instant getObjectCreated();
-
@Nullable StackTraceElement[] getAllocationContextStackTrace();
}
*/
package org.opendaylight.controller.md.sal.trace.closetracker.impl;
-import java.time.Instant;
import java.util.Objects;
import javax.annotation.Nullable;
*/
public class CloseTrackedTrait<T extends CloseTracked<T>> implements CloseTracked<T> {
- private final Instant created;
private final @Nullable Throwable allocationContext;
private final CloseTrackedRegistry<T> closeTrackedRegistry;
public CloseTrackedTrait(CloseTrackedRegistry<T> transactionChainRegistry) {
- this.created = Instant.now();
if (transactionChainRegistry.isDebugContextEnabled()) {
this.allocationContext = new Throwable("allocated at");
} else {
this.closeTrackedRegistry.add(this);
}
- @Override
- public Instant getObjectCreated() {
- return created;
- }
-
@Override
public StackTraceElement[] getAllocationContextStackTrace() {
return allocationContext != null ? allocationContext.getStackTrace() : null;
import com.google.common.base.Optional;
import com.google.common.util.concurrent.CheckedFuture;
import com.google.common.util.concurrent.ListenableFuture;
-import java.time.Instant;
import java.util.Objects;
import org.opendaylight.controller.md.sal.common.api.TransactionStatus;
import org.opendaylight.controller.md.sal.common.api.data.LogicalDatastoreType;
return super.cancel();
}
- @Override
- public Instant getObjectCreated() {
- return closeTracker.getObjectCreated();
- }
-
@Override
public StackTraceElement[] getAllocationContextStackTrace() {
return closeTracker.getAllocationContextStackTrace();
import com.google.common.util.concurrent.CheckedFuture;
import com.google.common.util.concurrent.ListenableFuture;
-import java.time.Instant;
import org.opendaylight.controller.md.sal.common.api.TransactionStatus;
import org.opendaylight.controller.md.sal.common.api.data.TransactionCommitFailedException;
import org.opendaylight.controller.md.sal.dom.api.DOMDataWriteTransaction;
return super.cancel();
}
- @Override
- public Instant getObjectCreated() {
- return closeTracker.getObjectCreated();
- }
-
@Override
public StackTraceElement[] getAllocationContextStackTrace() {
return closeTracker.getAllocationContextStackTrace();