SOLR-1120 followup -- Introduced a DocWrapper which takes care of maintaining document level session variables

git-svn-id: https://svn.apache.org/repos/asf/lucene/solr/trunk@769058 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Shalin Shekhar Mangar 2009-04-27 16:55:46 +00:00
parent 6ea022f90b
commit d7f7ca176f
4 changed files with 50 additions and 43 deletions

View File

@ -267,6 +267,7 @@ Other
EntityProcessor#destroy has been modified to be called once per parent-row at the end of row. A new EntityProcessor#destroy has been modified to be called once per parent-row at the end of row. A new
method EntityProcessor#close is added which is called at the end of import. A new method method EntityProcessor#close is added which is called at the end of import. A new method
Context#getResolvedEntityAttribute is added which returns the resolved value of an entity's attribute. Context#getResolvedEntityAttribute is added which returns the resolved value of an entity's attribute.
Introduced a DocWrapper which takes care of maintaining document level session variables.
(Noble Paul, shalin) (Noble Paul, shalin)
================== Release 1.3.0 20080915 ================== ================== Release 1.3.0 20080915 ==================

View File

@ -48,18 +48,21 @@ public class ContextImpl extends Context {
private DataImporter dataImporter; private DataImporter dataImporter;
private Map<String, Object> entitySession, globalSession, docSession; private Map<String, Object> entitySession, globalSession;
DocBuilder.DocWrapper doc;
DocBuilder docBuilder; DocBuilder docBuilder;
public ContextImpl(DataConfig.Entity entity, VariableResolverImpl resolver, public ContextImpl(DataConfig.Entity entity, VariableResolverImpl resolver,
DataSource ds, String currProcess, DataSource ds, String currProcess,
Map<String, Object> global, ContextImpl parentContext, DocBuilder docBuilder) { Map<String, Object> global, ContextImpl parentContext, DocBuilder docBuilder) {
this.entity = entity; this.entity = entity;
this.docBuilder = docBuilder;
this.resolver = resolver; this.resolver = resolver;
this.ds = ds; this.ds = ds;
this.currProcess = currProcess; this.currProcess = currProcess;
this.docBuilder = docBuilder;
if (docBuilder != null) { if (docBuilder != null) {
this.requestParams = docBuilder.requestParameters.requestParams; this.requestParams = docBuilder.requestParameters.requestParams;
dataImporter = docBuilder.dataImporter; dataImporter = docBuilder.dataImporter;
@ -90,9 +93,8 @@ public class ContextImpl extends Context {
entity.dataSrc = dataImporter.getDataSourceInstance(entity, entity.dataSource, this); entity.dataSrc = dataImporter.getDataSourceInstance(entity, entity.dataSource, this);
} }
if (entity.dataSrc != null && docBuilder != null && docBuilder.verboseDebug && if (entity.dataSrc != null && docBuilder != null && docBuilder.verboseDebug &&
currProcess == Context.FULL_DUMP) { Context.FULL_DUMP.equals(currentProcess())) {
//debug is not yet implemented properly for deltas //debug is not yet implemented properly for deltas
entity.dataSrc = docBuilder.writer.getDebugLogger().wrapDs(entity.dataSrc); entity.dataSrc = docBuilder.writer.getDebugLogger().wrapDs(entity.dataSrc);
} }
return entity.dataSrc; return entity.dataSrc;
@ -128,9 +130,9 @@ public class ContextImpl extends Context {
globalSession.put(name, val); globalSession.put(name, val);
} }
} else if (Context.SCOPE_DOC.equals(scope)) { } else if (Context.SCOPE_DOC.equals(scope)) {
Map<String, Object> docsession = getDocSession(); DocBuilder.DocWrapper doc = getDocument();
if (docsession != null) if (doc != null)
docsession.put(name, val); doc.setSessionAttribute(name, val);
} else if (SCOPE_SOLR_CORE.equals(scope)){ } else if (SCOPE_SOLR_CORE.equals(scope)){
if(dataImporter != null) dataImporter.getCoreScopeSession().put(name, val); if(dataImporter != null) dataImporter.getCoreScopeSession().put(name, val);
} }
@ -146,9 +148,8 @@ public class ContextImpl extends Context {
return globalSession.get(name); return globalSession.get(name);
} }
} else if (Context.SCOPE_DOC.equals(scope)) { } else if (Context.SCOPE_DOC.equals(scope)) {
Map<String, Object> docsession = getDocSession(); DocBuilder.DocWrapper doc = getDocument();
if (docsession != null) return doc == null ? null: doc.getSessionAttribute(name);
return docsession.get(name);
} else if (SCOPE_SOLR_CORE.equals(scope)){ } else if (SCOPE_SOLR_CORE.equals(scope)){
return dataImporter == null ? null : dataImporter.getCoreScopeSession().get(name); return dataImporter == null ? null : dataImporter.getCoreScopeSession().get(name);
} }
@ -159,11 +160,11 @@ public class ContextImpl extends Context {
return parent; return parent;
} }
public Map<String, Object> getDocSession() { private DocBuilder.DocWrapper getDocument() {
ContextImpl c = this; ContextImpl c = this;
while (true) { while (true) {
if (c.docSession != null) if (c.doc != null)
return c.docSession; return c.doc;
if (c.parent != null) if (c.parent != null)
c = c.parent; c = c.parent;
else else
@ -171,8 +172,8 @@ public class ContextImpl extends Context {
} }
} }
public void setDocSession(Map<String, Object> docSession) { public void setDoc(DocBuilder.DocWrapper docWrapper) {
this.docSession = docSession; this.doc = docWrapper;
} }

View File

@ -97,7 +97,7 @@ public class DataConfig {
public Entity parentEntity; public Entity parentEntity;
public EntityProcessor processor; public EntityProcessorWrapper processor;
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public DataSource dataSrc; public DataSource dataSrc;

View File

@ -38,7 +38,6 @@ import java.util.concurrent.atomic.AtomicLong;
* @since solr 1.3 * @since solr 1.3
*/ */
public class DocBuilder { public class DocBuilder {
public static final String DOC_BOOST = "$docBoost";
private static final Logger LOG = LoggerFactory.getLogger(DocBuilder.class); private static final Logger LOG = LoggerFactory.getLogger(DocBuilder.class);
@ -257,7 +256,7 @@ public class DocBuilder {
Iterator<Map<String, Object>> pkIter = allPks.iterator(); Iterator<Map<String, Object>> pkIter = allPks.iterator();
while (pkIter.hasNext()) { while (pkIter.hasNext()) {
Map<String, Object> map = pkIter.next(); Map<String, Object> map = pkIter.next();
vri.addNamespace(DataConfig.IMPORTER_NS + ".delta", map); vri.addNamespace(DataConfig.IMPORTER_NS_SHORT + ".delta", map);
buildDocument(vri, null, map, root, true, null); buildDocument(vri, null, map, root, true, null);
pkIter.remove(); pkIter.remove();
// check for abort // check for abort
@ -286,11 +285,11 @@ public class DocBuilder {
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
private void buildDocument(VariableResolverImpl vr, SolrInputDocument doc, private void buildDocument(VariableResolverImpl vr, DocWrapper doc,
Map<String, Object> pk, DataConfig.Entity entity, boolean isRoot, Map<String, Object> pk, DataConfig.Entity entity, boolean isRoot,
ContextImpl parentCtx) { ContextImpl parentCtx) {
EntityProcessor entityProcessor = getEntityProcessor(entity); EntityProcessorWrapper entityProcessor = getEntityProcessor(entity);
ContextImpl ctx = new ContextImpl(entity, vr, null, ContextImpl ctx = new ContextImpl(entity, vr, null,
pk == null ? Context.FULL_DUMP : Context.DELTA_DUMP, pk == null ? Context.FULL_DUMP : Context.DELTA_DUMP,
@ -323,11 +322,8 @@ public class DocBuilder {
writer.log(SolrWriter.START_DOC, entity.name, null); writer.log(SolrWriter.START_DOC, entity.name, null);
} }
if (doc == null && entity.isDocRoot) { if (doc == null && entity.isDocRoot) {
if (ctx.getDocSession() != null) doc = new DocWrapper();
ctx.getDocSession().clear(); ctx.setDoc(doc);
else
ctx.setDocSession(new HashMap<String, Object>());
doc = new SolrInputDocument();
DataConfig.Entity e = entity; DataConfig.Entity e = entity;
while (e.parentEntity != null) { while (e.parentEntity != null) {
addFields(e.parentEntity, doc, (Map<String, Object>) vr addFields(e.parentEntity, doc, (Map<String, Object>) vr
@ -342,10 +338,6 @@ public class DocBuilder {
break; break;
} }
if (arow.containsKey(DOC_BOOST)) {
setDocumentBoost(doc, arow);
}
// Support for start parameter in debug mode // Support for start parameter in debug mode
if (entity.isDocRoot) { if (entity.isDocRoot) {
if (seenDocCount <= requestParameters.start) if (seenDocCount <= requestParameters.start)
@ -361,7 +353,7 @@ public class DocBuilder {
} }
importStatistics.rowsCount.incrementAndGet(); importStatistics.rowsCount.incrementAndGet();
if (doc != null) { if (doc != null) {
handleSpecialCommands(arow); handleSpecialCommands(arow, doc);
addFields(entity, doc, arow); addFields(entity, doc, arow);
} }
if (isRoot) if (isRoot)
@ -423,18 +415,21 @@ public class DocBuilder {
} }
} }
private void setDocumentBoost(SolrInputDocument doc, Map<String, Object> arow) { static class DocWrapper extends SolrInputDocument {
Object v = arow.get(DOC_BOOST); //final SolrInputDocument solrDocument = new SolrInputDocument();
float value = 1.0f; Map<String ,Object> session;
if (v instanceof Number) {
value = ((Number) v).floatValue(); public void setSessionAttribute(String key, Object val){
} else { if(session == null) session = new HashMap<String, Object>();
value = Float.parseFloat(v.toString()); session.put(key, val);
}
public Object getSessionAttribute(String key) {
return session == null ? null : session.get(key);
} }
doc.setDocumentBoost(value);
} }
private void handleSpecialCommands(Map<String, Object> arow) { private void handleSpecialCommands(Map<String, Object> arow, DocWrapper doc) {
Object value = arow.get("$deleteDocById"); Object value = arow.get("$deleteDocById");
if (value != null) { if (value != null) {
if (value instanceof Collection) { if (value instanceof Collection) {
@ -453,11 +448,21 @@ public class DocBuilder {
for (Object o : collection) { for (Object o : collection) {
writer.deleteByQuery(o.toString()); writer.deleteByQuery(o.toString());
} }
} else { } else {
writer.deleteByQuery(value.toString()); writer.deleteByQuery(value.toString());
} }
} }
value = arow.get("$docBoost");
if (value != null) {
float value1 = 1.0f;
if (value instanceof Number) {
value1 = ((Number) value).floatValue();
} else {
value1 = Float.parseFloat(value.toString());
}
doc.setDocumentBoost(value1);
}
value = arow.get("$skipDoc"); value = arow.get("$skipDoc");
if (value != null) { if (value != null) {
if (Boolean.parseBoolean(value.toString())) { if (Boolean.parseBoolean(value.toString())) {
@ -475,7 +480,7 @@ public class DocBuilder {
} }
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
private void addFields(DataConfig.Entity entity, SolrInputDocument doc, Map<String, Object> arow) { private void addFields(DataConfig.Entity entity, DocWrapper doc, Map<String, Object> arow) {
for (Map.Entry<String, Object> entry : arow.entrySet()) { for (Map.Entry<String, Object> entry : arow.entrySet()) {
String key = entry.getKey(); String key = entry.getKey();
Object value = entry.getValue(); Object value = entry.getValue();
@ -502,7 +507,7 @@ public class DocBuilder {
} }
} }
private void addFieldToDoc(Object value, String name, float boost, boolean multiValued, SolrInputDocument doc) { private void addFieldToDoc(Object value, String name, float boost, boolean multiValued, DocWrapper doc) {
if (value instanceof Collection) { if (value instanceof Collection) {
Collection collection = (Collection) value; Collection collection = (Collection) value;
if (multiValued) { if (multiValued) {
@ -529,7 +534,7 @@ public class DocBuilder {
} }
} }
private EntityProcessor getEntityProcessor(DataConfig.Entity entity) { private EntityProcessorWrapper getEntityProcessor(DataConfig.Entity entity) {
if (entity.processor != null) if (entity.processor != null)
return entity.processor; return entity.processor;
EntityProcessor entityProcessor; EntityProcessor entityProcessor;