public class FileSnapshot extends Object
This object tracks the last modified time of a file. Later during an
invocation of isModified(File)
the object will return true if the
file may have been modified and should be re-read from disk.
A snapshot does not "live update" when the underlying filesystem changes.
Callers must poll for updates by periodically invoking
isModified(File)
.
To work around the "racy git" problem (where a file may be modified multiple times within the granularity of the filesystem modification clock) this class may return true from isModified(File) if the last modification time of the file is less than 3 seconds ago.
Modifier and Type | Field and Description |
---|---|
static FileSnapshot |
DIRTY
A FileSnapshot that is considered to always be modified.
|
static FileSnapshot |
MISSING_FILE
A FileSnapshot that is clean if the file does not exist.
|
static long |
UNKNOWN_SIZE
An unknown file size.
|
Modifier | Constructor and Description |
---|---|
protected |
FileSnapshot(File file)
Record a snapshot for a specific file path.
|
protected |
FileSnapshot(File file,
boolean useConfig)
Record a snapshot for a specific file path.
|
Modifier and Type | Method and Description |
---|---|
boolean |
equals(FileSnapshot other)
Compare two snapshots to see if they cache the same information.
|
boolean |
equals(Object obj) |
int |
hashCode() |
boolean |
isModified(File path)
Check if the path may have been modified since the snapshot was saved.
|
long |
lastDelta() |
long |
lastModified()
Deprecated.
use
lastModifiedInstant() instead |
Instant |
lastModifiedInstant()
Get time of last snapshot update
|
long |
lastRacyThreshold() |
static FileSnapshot |
save(File path)
Record a snapshot for a specific file path.
|
static FileSnapshot |
save(Instant modified)
Record a snapshot for a file for which the last modification time is
already known.
|
static FileSnapshot |
save(long modified)
Deprecated.
use
save(Instant) instead. |
static FileSnapshot |
saveNoConfig(File path)
Record a snapshot for a specific file path without using config file to
get filesystem timestamp resolution.
|
void |
setClean(FileSnapshot other)
Update this snapshot when the content hasn't changed.
|
long |
size() |
String |
toString() |
void |
waitUntilNotRacy()
Wait until this snapshot's file can't be racy anymore
|
public static final long UNKNOWN_SIZE
public static final FileSnapshot DIRTY
This instance is useful for application code that wants to lazily read a
file, but only after isModified(File)
gets invoked. The returned
snapshot contains only invalid status information.
public static final FileSnapshot MISSING_FILE
This instance is useful if the application wants to consider a missing
file to be clean. isModified(File)
will return false if the file
path does not exist.
protected FileSnapshot(File file)
This method should be invoked before the file is accessed.
file
- the path to remember meta data for. The path's current status
information is saved.protected FileSnapshot(File file, boolean useConfig)
This method should be invoked before the file is accessed.
file
- the path to remember meta data for. The path's current status
information is saved.useConfig
- if true
read filesystem time resolution from
configuration file otherwise use fallback resolutionpublic static FileSnapshot save(File path)
This method should be invoked before the file is accessed.
path
- the path to later remember. The path's current status
information is saved.public static FileSnapshot saveNoConfig(File path)
This method should be invoked before the file is accessed. It is used by FileBasedConfig to avoid endless recursion.
path
- the path to later remember. The path's current status
information is saved.@Deprecated public static FileSnapshot save(long modified)
save(Instant)
instead.This method should be invoked before the file is accessed.
Note that this method cannot rely on measuring file timestamp resolution to avoid racy git issues caused by finite file timestamp resolution since it's unknown in which filesystem the file is located. Hence the worst case fallback for timestamp resolution is used.
modified
- the last modification time of the filepublic static FileSnapshot save(Instant modified)
This method should be invoked before the file is accessed.
Note that this method cannot rely on measuring file timestamp resolution to avoid racy git issues caused by finite file timestamp resolution since it's unknown in which filesystem the file is located. Hence the worst case fallback for timestamp resolution is used.
modified
- the last modification time of the file@Deprecated public long lastModified()
lastModifiedInstant()
insteadpublic Instant lastModifiedInstant()
public long size()
public boolean isModified(File path)
path
- the path the snapshot describes.public void setClean(FileSnapshot other)
If the caller gets true from isModified(File)
, re-reads the
content, discovers the content is identical, and
equals(FileSnapshot)
is true, it can use
setClean(FileSnapshot)
to make a future
isModified(File)
return false. The logic goes something like
this:
if (snapshot.isModified(path)) { FileSnapshot other = FileSnapshot.save(path); Content newContent = ...; if (oldContent.equals(newContent) && snapshot.equals(other)) snapshot.setClean(other); }
other
- the other snapshot.public void waitUntilNotRacy() throws InterruptedException
InterruptedException
- if sleep was interruptedpublic boolean equals(FileSnapshot other)
other
- the other snapshot.public long lastDelta()
public long lastRacyThreshold()
Copyright © 2020 Eclipse JGit Project. All rights reserved.