mirror of https://github.com/apache/lucene.git
- Added methods:
public static boolean indexExists(String directory); public static boolean indexExists(File directory); public static boolean indexExists(Directory directory); public static boolean isLocked(Directory directory); public static void unlock(Directory directory); git-svn-id: https://svn.apache.org/repos/asf/lucene/java/trunk@149632 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
1eea3cc8b4
commit
d17defd73b
|
@ -123,13 +123,47 @@ abstract public class IndexReader {
|
||||||
return directory.fileModified("segments");
|
return directory.fileModified("segments");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns <code>true</code> if an index exists at the specified directory.
|
||||||
|
* If the directory does not exist or if there is no index in it.
|
||||||
|
* <code>false</code> is returned.
|
||||||
|
* @param directory the directory to check for an index
|
||||||
|
* @return <code>true</code> if an index exists; <code>false</code> otherwise
|
||||||
|
*/
|
||||||
|
public static boolean indexExists(String directory) {
|
||||||
|
return (new File(directory, "segments")).exists();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns <code>true</code> if an index exists at the specified directory.
|
||||||
|
* If the directory does not exist or if there is no index in it.
|
||||||
|
* @param directory the directory to check for an index
|
||||||
|
* @return <code>true</code> if an index exists; <code>false</code> otherwise
|
||||||
|
*/
|
||||||
|
public static boolean indexExists(File directory) {
|
||||||
|
return (new File(directory, "segments")).exists();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns <code>true</code> if an index exists at the specified directory.
|
||||||
|
* If the directory does not exist or if there is no index in it.
|
||||||
|
* @param directory the directory to check for an index
|
||||||
|
* @return <code>true</code> if an index exists; <code>false</code> otherwise
|
||||||
|
* @throws IOException if there is a problem with accessing the index
|
||||||
|
*/
|
||||||
|
public static boolean indexExists(Directory directory) throws IOException {
|
||||||
|
return directory.fileExists("segments");
|
||||||
|
}
|
||||||
|
|
||||||
/** Returns the number of documents in this index. */
|
/** Returns the number of documents in this index. */
|
||||||
abstract public int numDocs();
|
abstract public int numDocs();
|
||||||
|
|
||||||
/** Returns one greater than the largest possible document number.
|
/** Returns one greater than the largest possible document number.
|
||||||
This may be used to, e.g., determine how big to allocate an array which
|
This may be used to, e.g., determine how big to allocate an array which
|
||||||
will have an element for every document number in an index.
|
will have an element for every document number in an index.
|
||||||
*/
|
*/
|
||||||
abstract public int maxDoc();
|
abstract public int maxDoc();
|
||||||
|
|
||||||
/** Returns the stored fields of the <code>n</code><sup>th</sup>
|
/** Returns the stored fields of the <code>n</code><sup>th</sup>
|
||||||
<code>Document</code> in this index. */
|
<code>Document</code> in this index. */
|
||||||
abstract public Document document(int n) throws IOException;
|
abstract public Document document(int n) throws IOException;
|
||||||
|
@ -145,12 +179,13 @@ abstract public class IndexReader {
|
||||||
|
|
||||||
/** Returns an enumeration of all the terms in the index.
|
/** Returns an enumeration of all the terms in the index.
|
||||||
The enumeration is ordered by Term.compareTo(). Each term
|
The enumeration is ordered by Term.compareTo(). Each term
|
||||||
is greater than all that precede it in the enumeration.
|
is greater than all that precede it in the enumeration.
|
||||||
*/
|
*/
|
||||||
abstract public TermEnum terms() throws IOException;
|
abstract public TermEnum terms() throws IOException;
|
||||||
|
|
||||||
/** Returns an enumeration of all terms after a given term.
|
/** Returns an enumeration of all terms after a given term.
|
||||||
The enumeration is ordered by Term.compareTo(). Each term
|
The enumeration is ordered by Term.compareTo(). Each term
|
||||||
is greater than all that precede it in the enumeration.
|
is greater than all that precede it in the enumeration.
|
||||||
*/
|
*/
|
||||||
abstract public TermEnum terms(Term t) throws IOException;
|
abstract public TermEnum terms(Term t) throws IOException;
|
||||||
|
|
||||||
|
@ -213,8 +248,31 @@ abstract public class IndexReader {
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Closes files associated with this index.
|
/**
|
||||||
Also saves any new deletions to disk.
|
* Closes files associated with this index.
|
||||||
No other methods should be called after this has been called. */
|
* Also saves any new deletions to disk.
|
||||||
abstract public void close() throws IOException;
|
* No other methods should be called after this has been called.
|
||||||
|
*/
|
||||||
|
abstract public void close() throws IOException;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns <code>true</code> iff the index in the named directory is
|
||||||
|
* currently locked.
|
||||||
|
* @param directory the directory to check for a lock
|
||||||
|
* @throws IOException if there is a problem with accessing the index
|
||||||
|
*/
|
||||||
|
public static boolean isLocked(Directory directory) throws IOException {
|
||||||
|
return directory.fileExists("write.lock");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Forcibly unlocks the index in the named directory.
|
||||||
|
* <P>
|
||||||
|
* Caution: this should only be used by failure recovery code,
|
||||||
|
* when it is known that no other process nor thread is in fact
|
||||||
|
* currently accessing this index.
|
||||||
|
*/
|
||||||
|
public static void unlock(Directory directory) throws IOException {
|
||||||
|
directory.deleteFile("write.lock");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue