/******************************************************************************* * Copyright (c) 2014 Bruno Medeiros and other Contributors. * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * Bruno Medeiros - initial API and implementation *******************************************************************************/ package melnorme.lang.utils; import java.io.IOException; import java.nio.file.attribute.FileTime; import melnorme.utilbox.misc.Location; /** * An entry caching some value, derived from a file as input. * Keeps tracks of file and value timestamps, to see if current value is stale or not with regards to the file input. */ public abstract class FileCachingEntry<VALUE> extends FileModificationDetectionHelper { private VALUE value; public FileCachingEntry(Location location) { super(location); } public Location getFileLocation() { return fileLocation; } public synchronized VALUE getValue() { return value; } /** @return file modified time when entry was last marked as read. Non-null. */ public synchronized FileTime getValueTimeStamp() { return fileSyncAttributes == null ? FileTime.fromMillis(0) : fileSyncAttributes.lastModifiedTime(); } @Override public synchronized void markStale() { super.markStale(); } public synchronized boolean isStale() { return super.isModifiedSinceLastRead(); } public synchronized void updateValue(VALUE value) { try { markRead(); } catch (IOException e) { markStale(); } this.value = value; } @Override protected abstract void handleWarning_ModifiedTimeInTheFuture(FileTime lastModifiedTime); }