Mercurial Hosting > luan
changeset 1346:efd1c6380f2c
minor
author | Franklin Schmidt <fschmidt@gmail.com> |
---|---|
date | Mon, 25 Feb 2019 12:29:33 -0700 (2019-02-25) |
parents | 6f8988830098 |
children | 643cf1c37723 |
files | src/luan/modules/lucene/LuceneIndex.java |
diffstat | 1 files changed, 19 insertions(+), 15 deletions(-) [+] |
line wrap: on
line diff
--- a/src/luan/modules/lucene/LuceneIndex.java Mon Feb 25 11:00:10 2019 -0700 +++ b/src/luan/modules/lucene/LuceneIndex.java Mon Feb 25 12:29:33 2019 -0700 @@ -213,8 +213,8 @@ return new Term(key,br); } - public void delete(Luan luan,String queryStr) - throws LuanException, IOException, ParseException + public void delete(String queryStr) + throws IOException, ParseException { Query query = SaneQueryParser.parseQuery(mfp,queryStr); @@ -233,7 +233,7 @@ indexOnly.addAll(fields); } - public void save(Luan luan,LuanTable doc,LuanTable boosts) + public void save(LuanTable doc,LuanTable boosts) throws LuanException, IOException { Object obj = doc.get("id"); @@ -248,7 +248,7 @@ writeLock.lock(); try { if( id == null ) { - id = nextId(luan); + id = nextId(); doc.put("id",id); writer.addDocument(toLucene(doc,boosts)); } else { @@ -308,13 +308,13 @@ } } - public synchronized long nextId(Luan luan) throws LuanException, IOException { + public synchronized long nextId() throws LuanException, IOException { if( ++id > idLim ) { idLim += idBatch; - LuanTable doc = new LuanTable(luan); - doc.rawPut( "type", "next_id" ); - doc.rawPut( FLD_NEXT_ID, idLim ); - writer.updateDocument(new Term("type","next_id"),toLucene(doc,null)); + Map doc = new HashMap(); + doc.put( "type", "next_id" ); + doc.put( FLD_NEXT_ID, idLim ); + writer.updateDocument(new Term("type","next_id"),toLucene(doc.entrySet(),null)); wrote(); } return id; @@ -344,11 +344,11 @@ return snapshotDeletionPolicy; } - public Object snapshot(Luan luan,LuanFunction fn) throws LuanException, IOException { + public Object snapshot(LuanFunction fn) throws LuanException, IOException { IndexCommit ic = snapshotDeletionPolicy.snapshot(); try { String dir = fileDir.toString(); - LuanTable fileNames = new LuanTable(luan,new ArrayList(ic.getFileNames())); + LuanTable fileNames = new LuanTable(fn.luan(),new ArrayList(ic.getFileNames())); return fn.call(dir,fileNames); } finally { snapshotDeletionPolicy.release(ic); @@ -441,7 +441,7 @@ close(openSearcher()); } - public int advanced_search( final Luan luan, String queryStr, LuanFunction fn, Integer n, String sortStr ) + public int advanced_search( String queryStr, LuanFunction fn, Integer n, String sortStr ) throws LuanException, IOException, ParseException { Utils.checkNotNull(queryStr); @@ -454,7 +454,7 @@ if( fn!=null && n==null ) { if( sortStr != null ) throw new LuanException("sort must be nil when n is nil"); - final DocFn docFn = new DocFn(luan,searcher,query); + final DocFn docFn = new DocFn(fn.luan(),searcher,query); MyCollector col = new MyCollector() { @Override public void collect(int doc) { try { @@ -480,7 +480,7 @@ Sort sort = sortStr==null ? null : SaneQueryParser.parseSort(mfp,sortStr); TopDocs td = sort==null ? searcher.search(query,n) : searcher.search(query,n,sort); final ScoreDoc[] scoreDocs = td.scoreDocs; - DocFn docFn = new DocFn(luan,searcher,query); + DocFn docFn = new DocFn(fn.luan(),searcher,query); for( int i=0; i<scoreDocs.length; i++ ) { ScoreDoc scoreDoc = scoreDocs[i]; docFn.docID = scoreDoc.doc; @@ -578,9 +578,13 @@ } private Document toLucene(LuanTable table,LuanTable boosts) throws LuanException { + return toLucene(table,boosts); + } + + private Document toLucene(Iterable<Map.Entry> iterable,LuanTable boosts) throws LuanException { Set<String> indexed = mfp.fields.keySet(); Document doc = new Document(); - for( Map.Entry<Object,Object> entry : table.iterable() ) { + for( Map.Entry<Object,Object> entry : iterable ) { Object key = entry.getKey(); if( !(key instanceof String) ) throw new LuanException("key must be string");