SOLR-359: LukeResponse.FieldInfo should expose the selected flags info and the indexInfo

git-svn-id: https://svn.apache.org/repos/asf/lucene/solr/trunk@580089 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Erik Hatcher 2007-09-27 16:43:42 +00:00
parent aa1e9e1064
commit ebf602df89
4 changed files with 274 additions and 144 deletions

View File

@ -131,6 +131,11 @@ New Features
sqrt, abs, scale, map. Constants may now be used as a value source. sqrt, abs, scale, map. Constants may now be used as a value source.
(yonik) (yonik)
25. SOLR-359: Add field type className to Luke response, and enabled access
to the detailed field information from the solrj client API.
(Grant Ingersoll via ehatcher)
Changes in runtime behavior Changes in runtime behavior
Optimizations Optimizations

View File

@ -17,147 +17,233 @@
package org.apache.solr.client.solrj.response; package org.apache.solr.client.solrj.response;
import java.util.HashMap; import org.apache.solr.common.luke.FieldFlag;
import java.util.Map;
import org.apache.solr.common.util.NamedList; import org.apache.solr.common.util.NamedList;
import java.util.*;
/** /**
* This is an incomplete representation of the data returned from Luke * This is an incomplete representation of the data returned from Luke
* + *
* *
* @version $Id$ * @version $Id$
* @since solr 1.3 * @since solr 1.3
*/ */
public class LukeResponse extends SolrResponseBase public class LukeResponse extends SolrResponseBase {
{
public static class FieldInfo { public static class FieldTypeInfo {
String name; String name;
String type; String className;
String schema; boolean tokenized;
int docs; String analyzer;
int distinct; List<String> fields;
boolean cacheableFaceting;
NamedList<Integer> topTerms;
public FieldInfo( String n )
{ public FieldTypeInfo(String name) {
name = n; this.name = name;
fields = Collections.emptyList();
} }
@SuppressWarnings("unchecked")
public void read( NamedList<Object> nl ) public String getAnalyzer() {
{ return analyzer;
for( Map.Entry<String, Object> entry : nl ) {
if( "type".equals( entry.getKey() ) ) {
type = (String)entry.getValue();
}
else if( "schema".equals( entry.getKey() ) ) {
schema = (String)entry.getValue();
}
else if( "docs".equals( entry.getKey() ) ) {
docs = (Integer)entry.getValue();
}
else if( "distinct".equals( entry.getKey() ) ) {
distinct = (Integer)entry.getValue();
}
else if( "cacheableFaceting".equals( entry.getKey() ) ) {
cacheableFaceting = (Boolean)entry.getValue();
}
else if( "topTerms".equals( entry.getKey() ) ) {
topTerms = (NamedList<Integer>)entry.getValue();
}
}
} }
public boolean isCacheableFaceting() { public String getClassName() {
return cacheableFaceting; return className;
} }
public int getDistinct() { public List<String> getFields() {
return distinct; return fields;
}
public int getDocs() {
return docs;
} }
public String getName() { public String getName() {
return name; return name;
} }
public String getSchema() { public boolean isTokenized() {
return schema; return tokenized;
}/*
Sample:
types={ignored={fields=null,tokenized=false,analyzer=org.apache.solr.schema.FieldType$DefaultAnalyzer@f94934},
integer={fields=null,tokenized=false,analyzer=org.apache.solr.schema.FieldType$DefaultAnalyzer@3525a2},
sfloat={fields=[price, weight],tokenized=false,analyzer=org.apache.solr.schema.FieldType$DefaultAnalyzer@39cf9c},
text_ws={fields=[cat],tokenized=true,analyzer=TokenizerChain(org.apache.solr.analysis.WhitespaceTokenizerFactory@6d3ca2)},
alphaOnlySort={fields=[alphaNameSort],tokenized=true,analyzer=TokenizerChain(org.apache.solr.analysis.KeywordTokenizerFactory@a7bd3b,
org.apache.solr.analysis.LowerCaseFilterFactory@78aae2, org.apache.solr.analysis.TrimFilterFactory@1b16a7,
org.apache.solr.analysis.PatternReplaceFilterFactory@6c6b08)},date={fields=[timestamp],tokenized=false,
analyzer=org.apache.solr.schema.FieldType$DefaultAnalyzer@e6e42e},sint={fields=[popularity],
tokenized=false,analyzer=org.apache.solr.schema.FieldType$DefaultAnalyzer@8ea21d},
boolean={fields=[inStock],tokenized=false,analyzer=org.apache.solr.schema.BoolField$1@354949},
textTight={fields=[sku],tokenized=true,analyzer=TokenizerChain(org.apache.solr.analysis.WhitespaceTokenizerFactory@5e88f7,
org.apache.solr.analysis.SynonymFilterFactory@723646, org.apache.solr.analysis.StopFilterFactory@492ff1,
org.apache.solr.analysis.WordDelimiterFilterFactory@eaabad, org.apache.solr.analysis.LowerCaseFilterFactory@ad1355,
org.apache.solr.analysis.EnglishPorterFilterFactory@d03a00, org.apache.solr.analysis.RemoveDuplicatesTokenFilterFactory@900079)},
long={fields=null,tokenized=false,analyzer=org.apache.solr.schema.FieldType$DefaultAnalyzer@f3b83},
double={fields=null,tokenized=false,analyzer=org.apache.solr.schema.FieldType$DefaultAnalyzer@c2b07},
*/
@SuppressWarnings("unchecked")
public void read(NamedList<Object> nl) {
for (Map.Entry<String, Object> entry : nl) {
String key = entry.getKey();
if ("fields".equals(key) && entry.getValue() != null) {
List<String> theFields = (List<String>) entry.getValue();
fields = new ArrayList<String>(theFields);
} else if ("tokenized".equals(key) == true) {
tokenized = Boolean.parseBoolean(entry.getValue().toString());
} else if ("analyzer".equals(key) == true) {
analyzer = entry.getValue().toString();
} else if ("className".equals(key) == true) {
className = entry.getValue().toString();
}
}
}
} }
public NamedList<Integer> getTopTerms() { public static class FieldInfo {
return topTerms; String name;
String type;
String schema;
int docs;
int distinct;
EnumSet<FieldFlag> flags;
boolean cacheableFaceting;
NamedList<Integer> topTerms;
public FieldInfo(String n) {
name = n;
}
@SuppressWarnings("unchecked")
public void read(NamedList<Object> nl) {
for (Map.Entry<String, Object> entry : nl) {
if ("type".equals(entry.getKey())) {
type = (String) entry.getValue();
}
if ("flags".equals(entry.getKey())) {
flags = parseFlags((String) entry.getValue());
} else if ("schema".equals(entry.getKey())) {
schema = (String) entry.getValue();
} else if ("docs".equals(entry.getKey())) {
docs = (Integer) entry.getValue();
} else if ("distinct".equals(entry.getKey())) {
distinct = (Integer) entry.getValue();
} else if ("cacheableFaceting".equals(entry.getKey())) {
cacheableFaceting = (Boolean) entry.getValue();
} else if ("topTerms".equals(entry.getKey())) {
topTerms = (NamedList<Integer>) entry.getValue();
}
}
}
public static EnumSet<FieldFlag> parseFlags(String flagStr) {
EnumSet<FieldFlag> result = EnumSet.noneOf(FieldFlag.class);
char[] chars = flagStr.toCharArray();
for (int i = 0; i < chars.length; i++) {
if (chars[i] != '-') {
FieldFlag flag = FieldFlag.getFlag(chars[i]);
result.add(flag);
}
}
return result;
}
public EnumSet<FieldFlag> getFlags() {
return flags;
}
public boolean isCacheableFaceting() {
return cacheableFaceting;
} }
public String getType() { public String getType() {
return type; return type;
} }
}; }
private NamedList<Object> indexInfo; private NamedList<Object> indexInfo;
private Map<String,FieldInfo> fieldInfo; private Map<String, FieldInfo> fieldInfo;
private Map<String, FieldTypeInfo> fieldTypeInfo;
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public LukeResponse(NamedList<Object> res) { public LukeResponse(NamedList<Object> res) {
super(res); super(res);
// Parse indexinfo // Parse indexinfo
indexInfo = (NamedList<Object>)res.get( "index" ); indexInfo = (NamedList<Object>) res.get("index");
NamedList<Object> flds = (NamedList<Object>)res.get( "fields" ); NamedList<Object> flds = (NamedList<Object>) res.get("fields");
if (flds==null) { if (flds == null) {
flds = (NamedList<Object>) ((NamedList<Object>)res.get( "schema" )).get("fields"); flds = (NamedList<Object>) ((NamedList<Object>) res.get("schema")).get("fields");
} }
if( flds != null ) { if (flds != null) {
fieldInfo = new HashMap<String,FieldInfo>( ); fieldInfo = new HashMap<String, FieldInfo>();
for( Map.Entry<String, Object> field : flds ) { for (Map.Entry<String, Object> field : flds) {
FieldInfo f = new FieldInfo( field.getKey() ); FieldInfo f = new FieldInfo(field.getKey());
f.read( (NamedList<Object>)field.getValue() ); f.read((NamedList<Object>) field.getValue());
fieldInfo.put( field.getKey(), f ); fieldInfo.put(field.getKey(), f);
} }
} }
NamedList<Object> fldTypes = (NamedList<Object>) ((NamedList<Object>) res.get("schema")).get("types");
if (fldTypes != null) {
fieldTypeInfo = new HashMap<String, FieldTypeInfo>();
for (Map.Entry<String, Object> fieldType : fldTypes) {
FieldTypeInfo ft = new FieldTypeInfo(fieldType.getKey());
ft.read((NamedList<Object>) fieldType.getValue());
fieldTypeInfo.put(fieldType.getKey(), ft);
}
}
} }
//---------------------------------------------------------------- //----------------------------------------------------------------
//---------------------------------------------------------------- //----------------------------------------------------------------
public String getIndexDirectory() public String getIndexDirectory() {
{ if (indexInfo == null) return null;
if( indexInfo == null ) return null; return (String) indexInfo.get("directory");
return (String)indexInfo.get( "directory" );
} }
public Integer getNumDocs() public Integer getNumDocs() {
{ if (indexInfo == null) return null;
if( indexInfo == null ) return null; return (Integer) indexInfo.get("numDocs");
return (Integer)indexInfo.get( "numDocs" );
} }
public Integer getMaxDoc() public Integer getMaxDoc() {
{ if (indexInfo == null) return null;
if( indexInfo == null ) return null; return (Integer) indexInfo.get("maxDoc");
return (Integer)indexInfo.get( "maxDoc" );
} }
public Integer getNumTerms() public Integer getNumTerms() {
{ if (indexInfo == null) return null;
if( indexInfo == null ) return null; return (Integer) indexInfo.get("numTerms");
return (Integer)indexInfo.get( "numTerms" );
} }
public Map<String,FieldInfo> getFieldInfo() { public Map<String, FieldTypeInfo> getFieldTypeInfo() {
return fieldTypeInfo;
}
public FieldTypeInfo getFieldTypeInfo(String name) {
return fieldTypeInfo.get(name);
}
public NamedList<Object> getIndexInfo() {
return indexInfo;
}
public Map<String, FieldInfo> getFieldInfo() {
return fieldInfo; return fieldInfo;
} }
public FieldInfo getFieldInfo( String f ) { public FieldInfo getFieldInfo(String f) {
return fieldInfo.get( f ); return fieldInfo.get(f);
} }
//---------------------------------------------------------------- //----------------------------------------------------------------
//----------------------------------------------------------------
} }

View File

@ -0,0 +1,43 @@
package org.apache.solr.common.luke;
/**
* The FieldFlag class is used to store
*
**/
public enum FieldFlag {
INDEXED('I', "Indexed"), TOKENIZED('T', "Tokenized"), STORED('S', "Stored"), MULTI_VALUED('M', "Multivalued"),
TERM_VECTOR_STORED('V', "TermVector Stored"), TERM_VECTOR_OFFSET('o', "Store Offset With TermVector"),
TERM_VECTOR_POSITION('p', "Store Position With TermVector"),
OMIT_NORMS('O', "Omit Norms"), LAZY('L', "Lazy"), BINARY('B', "Binary"), COMPRESSED('C', "Compressed"),
SORT_MISSING_FIRST('f', "Sort Missing First"), SORT_MISSING_LAST('l', "Sort Missing Last");
private char abbreviation;
private String display;
FieldFlag(char abbreviation, String display) {
this.abbreviation = abbreviation;
this.display = display;
this.display.intern();//QUESTION: Need we bother here?
}
public static FieldFlag getFlag(char abbrev){
FieldFlag result = null;
FieldFlag [] vals = FieldFlag.values();
for (int i = 0; i < vals.length; i++) {
if (vals[i].getAbbreviation() == abbrev){
result = vals[i];
break;
}
}
return result;
}
public char getAbbreviation() {
return abbreviation;
}
public String getDisplay() {
return display;
}
}

View File

@ -17,21 +17,6 @@
package org.apache.solr.handler.admin; package org.apache.solr.handler.admin;
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Date;
import java.util.HashMap;
import java.util.HashSet;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.logging.Level;
import java.util.logging.Logger;
import org.apache.lucene.document.Document; import org.apache.lucene.document.Document;
import org.apache.lucene.document.Fieldable; import org.apache.lucene.document.Fieldable;
import org.apache.lucene.index.IndexReader; import org.apache.lucene.index.IndexReader;
@ -44,6 +29,7 @@ import org.apache.lucene.search.Sort;
import org.apache.lucene.store.Directory; import org.apache.lucene.store.Directory;
import org.apache.lucene.util.PriorityQueue; import org.apache.lucene.util.PriorityQueue;
import org.apache.solr.common.SolrException; import org.apache.solr.common.SolrException;
import org.apache.solr.common.luke.FieldFlag;
import org.apache.solr.common.params.CommonParams; import org.apache.solr.common.params.CommonParams;
import org.apache.solr.common.params.SolrParams; import org.apache.solr.common.params.SolrParams;
import org.apache.solr.common.util.NamedList; import org.apache.solr.common.util.NamedList;
@ -59,6 +45,13 @@ import org.apache.solr.search.DocList;
import org.apache.solr.search.SolrIndexSearcher; import org.apache.solr.search.SolrIndexSearcher;
import org.apache.solr.search.SolrQueryParser; import org.apache.solr.search.SolrQueryParser;
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.*;
import java.util.logging.Level;
import java.util.logging.Logger;
/** /**
* This handler exposes the internal lucene index. It is inspired by and * This handler exposes the internal lucene index. It is inspired by and
* modeled on Luke, the Lucene Index Browser by Andrzej Bialecki. * modeled on Luke, the Lucene Index Browser by Andrzej Bialecki.
@ -151,25 +144,27 @@ public class LukeRequestHandler extends RequestHandlerBase
rsp.add( "info", info ); rsp.add( "info", info );
} }
/** /**
* @return a string representing a Fieldable's flags. * @return a string representing a Fieldable's flags.
*/ */
private static String getFieldFlags( Fieldable f ) private static String getFieldFlags( Fieldable f )
{ {
StringBuilder flags = new StringBuilder(); StringBuilder flags = new StringBuilder();
flags.append( (f != null && f.isIndexed()) ? 'I' : '-' ); flags.append( (f != null && f.isIndexed()) ? FieldFlag.INDEXED.getAbbreviation() : '-' );
flags.append( (f != null && f.isTokenized()) ? 'T' : '-' ); flags.append( (f != null && f.isTokenized()) ? FieldFlag.TOKENIZED.getAbbreviation() : '-' );
flags.append( (f != null && f.isStored()) ? 'S' : '-' ); flags.append( (f != null && f.isStored()) ? FieldFlag.STORED.getAbbreviation() : '-' );
flags.append( (false) ? 'M' : '-' ); // SchemaField Specific flags.append( (false) ? FieldFlag.MULTI_VALUED.getAbbreviation() : '-' ); // SchemaField Specific
flags.append( (f != null && f.isTermVectorStored()) ? 'V' : '-' ); flags.append( (f != null && f.isTermVectorStored()) ? FieldFlag.TERM_VECTOR_STORED.getAbbreviation() : '-' );
flags.append( (f != null && f.isStoreOffsetWithTermVector()) ? 'o' : '-' ); flags.append( (f != null && f.isStoreOffsetWithTermVector()) ? FieldFlag.TERM_VECTOR_OFFSET.getAbbreviation() : '-' );
flags.append( (f != null && f.isStorePositionWithTermVector()) ? 'p' : '-' ); flags.append( (f != null && f.isStorePositionWithTermVector()) ? FieldFlag.TERM_VECTOR_POSITION.getAbbreviation() : '-' );
flags.append( (f != null && f.getOmitNorms()) ? 'O' : '-' ); flags.append( (f != null && f.getOmitNorms()) ? FieldFlag.OMIT_NORMS.getAbbreviation() : '-' );
flags.append( (f != null && f.isLazy()) ? 'L' : '-' ); flags.append( (f != null && f.isLazy()) ? FieldFlag.LAZY.getAbbreviation() : '-' );
flags.append( (f != null && f.isBinary()) ? 'B' : '-' ); flags.append( (f != null && f.isBinary()) ? FieldFlag.BINARY.getAbbreviation() : '-' );
flags.append( (f != null && f.isCompressed()) ? 'C' : '-' ); flags.append( (f != null && f.isCompressed()) ? FieldFlag.COMPRESSED.getAbbreviation() : '-' );
flags.append( (false) ? 'f' : '-' ); // SchemaField Specific flags.append( (false) ? FieldFlag.SORT_MISSING_FIRST.getAbbreviation() : '-' ); // SchemaField Specific
flags.append( (false) ? 'l' : '-' ); // SchemaField Specific flags.append( (false) ? FieldFlag.SORT_MISSING_LAST.getAbbreviation() : '-' ); // SchemaField Specific
return flags.toString(); return flags.toString();
} }
@ -185,41 +180,41 @@ public class LukeRequestHandler extends RequestHandlerBase
boolean binary = false; // Currently not possible boolean binary = false; // Currently not possible
StringBuilder flags = new StringBuilder(); StringBuilder flags = new StringBuilder();
flags.append( (f != null && f.indexed()) ? 'I' : '-' ); flags.append( (f != null && f.indexed()) ? FieldFlag.INDEXED.getAbbreviation() : '-' );
flags.append( (t != null && t.isTokenized()) ? 'T' : '-' ); flags.append( (t != null && t.isTokenized()) ? FieldFlag.TOKENIZED.getAbbreviation() : '-' );
flags.append( (f != null && f.stored()) ? 'S' : '-' ); flags.append( (f != null && f.stored()) ? FieldFlag.STORED.getAbbreviation() : '-' );
flags.append( (f != null && f.multiValued()) ? 'M' : '-' ); flags.append( (f != null && f.multiValued()) ? FieldFlag.MULTI_VALUED.getAbbreviation() : '-' );
flags.append( (f != null && f.storeTermVector() ) ? 'V' : '-' ); flags.append( (f != null && f.storeTermVector() ) ? FieldFlag.TERM_VECTOR_STORED.getAbbreviation() : '-' );
flags.append( (f != null && f.storeTermOffsets() ) ? 'o' : '-' ); flags.append( (f != null && f.storeTermOffsets() ) ? FieldFlag.TERM_VECTOR_OFFSET.getAbbreviation() : '-' );
flags.append( (f != null && f.storeTermPositions() ) ? 'p' : '-' ); flags.append( (f != null && f.storeTermPositions() ) ? FieldFlag.TERM_VECTOR_POSITION.getAbbreviation() : '-' );
flags.append( (f != null && f.omitNorms()) ? 'O' : '-' ); flags.append( (f != null && f.omitNorms()) ? FieldFlag.OMIT_NORMS.getAbbreviation() : '-' );
flags.append( (lazy) ? 'L' : '-' ); flags.append( (lazy) ? FieldFlag.LAZY.getAbbreviation() : '-' );
flags.append( (binary) ? 'B' : '-' ); flags.append( (binary) ? FieldFlag.BINARY.getAbbreviation() : '-' );
flags.append( (f != null && f.isCompressed()) ? 'C' : '-' ); flags.append( (f != null && f.isCompressed()) ? FieldFlag.COMPRESSED.getAbbreviation() : '-' );
flags.append( (f != null && f.sortMissingFirst() ) ? 'f' : '-' ); flags.append( (f != null && f.sortMissingFirst() ) ? FieldFlag.SORT_MISSING_FIRST.getAbbreviation() : '-' );
flags.append( (f != null && f.sortMissingLast() ) ? 'l' : '-' ); flags.append( (f != null && f.sortMissingLast() ) ? FieldFlag.SORT_MISSING_LAST.getAbbreviation() : '-' );
return flags.toString(); return flags.toString();
} }
/** /**
* @return a key to what each character means * @return a key to what each character means
*/ */
private static SimpleOrderedMap<String> getFieldFlagsKey() public static SimpleOrderedMap<String> getFieldFlagsKey()
{ {
SimpleOrderedMap<String> key = new SimpleOrderedMap<String>(); SimpleOrderedMap<String> key = new SimpleOrderedMap<String>();
key.add( "I", "Indexed" ); key.add(String.valueOf(FieldFlag.INDEXED.getAbbreviation()), FieldFlag.INDEXED.getDisplay() );
key.add( "T", "Tokenized" ); key.add(String.valueOf(FieldFlag.TOKENIZED.getAbbreviation()), FieldFlag.TOKENIZED.getDisplay() );
key.add( "S", "Stored" ); key.add( String.valueOf(FieldFlag.STORED.getAbbreviation()), FieldFlag.STORED.getDisplay() );
key.add( "M", "Multivalued" ); key.add( String.valueOf(FieldFlag.MULTI_VALUED.getAbbreviation()), FieldFlag.MULTI_VALUED.getDisplay() );
key.add( "V", "TermVector Stored" ); key.add( String.valueOf(FieldFlag.TERM_VECTOR_STORED.getAbbreviation()), FieldFlag.TERM_VECTOR_STORED.getDisplay() );
key.add( "o", "Store Offset With TermVector" ); key.add( String.valueOf(FieldFlag.TERM_VECTOR_OFFSET.getAbbreviation()), FieldFlag.TERM_VECTOR_OFFSET.getDisplay() );
key.add( "p", "Store Position With TermVector" ); key.add( String.valueOf(FieldFlag.TERM_VECTOR_POSITION.getAbbreviation()), FieldFlag.TERM_VECTOR_POSITION.getDisplay() );
key.add( "O", "Omit Norms" ); key.add( String.valueOf(FieldFlag.OMIT_NORMS.getAbbreviation()), FieldFlag.OMIT_NORMS.getDisplay() );
key.add( "L", "Lazy" ); key.add( String.valueOf(FieldFlag.LAZY.getAbbreviation()), FieldFlag.LAZY.getDisplay() );
key.add( "B", "Binary" ); key.add( String.valueOf(FieldFlag.BINARY.getAbbreviation()), FieldFlag.BINARY.getDisplay() );
key.add( "C", "Compressed" ); key.add( String.valueOf(FieldFlag.COMPRESSED.getAbbreviation()), FieldFlag.COMPRESSED.getDisplay() );
key.add( "f", "Sort Missing First" ); key.add( String.valueOf(FieldFlag.SORT_MISSING_FIRST.getAbbreviation()), FieldFlag.SORT_MISSING_FIRST.getDisplay() );
key.add( "l", "Sort Missing Last" ); key.add( String.valueOf(FieldFlag.SORT_MISSING_LAST.getAbbreviation()), FieldFlag.SORT_MISSING_LAST.getDisplay() );
return key; return key;
} }
@ -372,7 +367,8 @@ public class LukeRequestHandler extends RequestHandlerBase
SimpleOrderedMap<Object> field = new SimpleOrderedMap<Object>(); SimpleOrderedMap<Object> field = new SimpleOrderedMap<Object>();
field.add( "fields", typeusemap.get( ft.getTypeName() ) ); field.add( "fields", typeusemap.get( ft.getTypeName() ) );
field.add( "tokenized", ft.isTokenized() ); field.add( "tokenized", ft.isTokenized() );
field.add( "analyzer", ft.getAnalyzer()+"" ); field.add("className", ft.getClass().getName());
field.add( "analyzer", ft.getAnalyzer().getClass().getName());
types.add( ft.getTypeName(), field ); types.add( ft.getTypeName(), field );
} }