Mercurial Hosting > luan
changeset 1764:527c53b91a50
lucene error handling
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Mon, 22 May 2023 20:43:52 -0600 (20 months ago) |
parents | 164c6ea53147 |
children | 1ffe1e06ea55 |
files | src/luan/modules/lucene/LuceneIndex.java |
diffstat | 1 files changed, 14 insertions(+), 56 deletions(-) [+] |
line wrap: on
line diff
--- a/src/luan/modules/lucene/LuceneIndex.java Mon May 22 19:21:14 2023 -0600 +++ b/src/luan/modules/lucene/LuceneIndex.java Mon May 22 20:43:52 2023 -0600 @@ -1,56 +1,31 @@ package luan.modules.lucene; -import java.io.Closeable; import java.io.File; -import java.io.FileOutputStream; -import java.io.FileInputStream; import java.io.IOException; import java.lang.ref.Reference; import java.lang.ref.WeakReference; -import java.util.Arrays; -import java.util.Iterator; import java.util.Map; import java.util.HashMap; -import java.util.List; import java.util.ArrayList; -import java.util.Set; -import java.util.HashSet; -import java.util.Collections; import java.util.concurrent.atomic.AtomicInteger; -import java.util.concurrent.locks.Lock; import java.util.concurrent.locks.ReentrantLock; -import java.util.zip.ZipOutputStream; -import java.util.zip.ZipEntry; import org.apache.lucene.analysis.Analyzer; import org.apache.lucene.analysis.TokenStream; import org.apache.lucene.analysis.core.KeywordAnalyzer; import org.apache.lucene.analysis.core.SimpleAnalyzer; import org.apache.lucene.analysis.en.EnglishAnalyzer; import org.apache.lucene.document.Document; -import org.apache.lucene.document.Field; -import org.apache.lucene.document.StoredField; -import org.apache.lucene.document.StringField; -import org.apache.lucene.document.TextField; -import org.apache.lucene.document.IntField; -import org.apache.lucene.document.LongField; -import org.apache.lucene.document.DoubleField; -import org.apache.lucene.index.IndexableField; -import org.apache.lucene.index.IndexWriter; -import org.apache.lucene.index.IndexWriterConfig; import org.apache.lucene.index.DirectoryReader; import org.apache.lucene.index.Term; import org.apache.lucene.index.SnapshotDeletionPolicy; import org.apache.lucene.index.IndexCommit; import org.apache.lucene.index.AtomicReaderContext; import org.apache.lucene.index.CheckIndex; -import org.apache.lucene.store.Directory; import org.apache.lucene.store.FSDirectory; import org.apache.lucene.util.Version; import org.apache.lucene.util.BytesRef; import org.apache.lucene.util.NumericUtils; import org.apache.lucene.search.Query; -import org.apache.lucene.search.PrefixQuery; -import org.apache.lucene.search.TermQuery; import org.apache.lucene.search.MatchAllDocsQuery; import org.apache.lucene.search.TopDocs; import org.apache.lucene.search.Sort; @@ -64,7 +39,6 @@ import org.apache.lucene.search.highlight.Formatter; import org.apache.lucene.search.highlight.Highlighter; import org.apache.lucene.search.highlight.InvalidTokenOffsetsException; -import org.apache.lucene.search.highlight.Fragmenter; import org.apache.lucene.search.highlight.NullFragmenter; import org.apache.lucene.search.highlight.SimpleSpanFragmenter; import org.apache.lucene.search.highlight.QueryScorer; @@ -89,7 +63,6 @@ import luan.LuanFunction; import luan.LuanException; import luan.LuanRuntimeException; -import luan.modules.parsers.LuanToString; import goodjava.logging.Logger; import goodjava.logging.LoggerFactory; @@ -190,17 +163,22 @@ fsDir = FSDirectory.open(indexDir); boolean wasCreated = !fsDir.getDirectory().exists(); writer = new LuceneIndexWriter(fsDir,config); - if( logDir != null ) { - if( BackupIndexWriter.backupDomains == null ) { - writer = new LoggingIndexWriter((LuceneIndexWriter)writer,logDir,logTime); - } else { - writer = BackupIndexWriter.newWithRestore((LuceneIndexWriter)writer,logDir,logTime,domain,name); + try { + if( logDir != null ) { + if( BackupIndexWriter.backupDomains == null ) { + writer = new LoggingIndexWriter((LuceneIndexWriter)writer,logDir,logTime); + } else { + writer = BackupIndexWriter.newWithRestore((LuceneIndexWriter)writer,logDir,logTime,domain,name); + } } + reader = DirectoryReader.open(fsDir); + searcher = new IndexSearcher(reader); + initId(); + return wasCreated; + } catch(IOException e) { + writer.close(); + throw e; } - reader = DirectoryReader.open(fsDir); - searcher = new IndexSearcher(reader); - initId(); - return wasCreated; } private void wrote() { @@ -358,26 +336,6 @@ } } -/* - public void backup(String zipFile) throws LuanException, IOException { - if( !zipFile.endsWith(".zip") ) - throw new LuanException("file "+zipFile+" doesn't end with '.zip'"); - IndexCommit ic = snapshotDeletionPolicy.snapshot(); - try { - ZipOutputStream out = new ZipOutputStream(new FileOutputStream(zipFile)); - for( String fileName : ic.getFileNames() ) { - out.putNextEntry(new ZipEntry(fileName)); - FileInputStream in = new FileInputStream(new File(indexDir,fileName)); - Utils.copyAll(in,out); - in.close(); - out.closeEntry(); - } - out.close(); - } finally { - snapshotDeletionPolicy.release(ic); - } - } -*/ public SnapshotDeletionPolicy snapshotDeletionPolicy() { return (SnapshotDeletionPolicy)writer.getLuceneIndexWriter().getConfig().getIndexDeletionPolicy(); }