/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
using System;
using IndexReader = Lucene.Net.Index.IndexReader;
namespace Lucene.Net.Search
{
/// A query that wraps a filter and simply returns a constant score equal to the
/// query boost for every document in the filter.
///
///
/// yonik
///
/// $Id: ConstantScoreQuery.java 507374 2007-02-14 03:12:50Z yonik $
///
[Serializable]
public class ConstantScoreQuery : Query
{
protected internal Filter filter;
public ConstantScoreQuery(Filter filter)
{
this.filter = filter;
}
/// Returns the encapsulated filter
public virtual Filter GetFilter()
{
return filter;
}
public override Query Rewrite(IndexReader reader)
{
return this;
}
public override void ExtractTerms(System.Collections.Hashtable terms)
{
// OK to not add any terms when used for MultiSearcher,
// but may not be OK for highlighting
}
[Serializable]
protected internal class ConstantWeight : Weight
{
private void InitBlock(ConstantScoreQuery enclosingInstance)
{
this.enclosingInstance = enclosingInstance;
}
private ConstantScoreQuery enclosingInstance;
public ConstantScoreQuery Enclosing_Instance
{
get
{
return enclosingInstance;
}
}
private Similarity similarity;
private float queryNorm;
private float queryWeight;
public ConstantWeight(ConstantScoreQuery enclosingInstance, Searcher searcher)
{
InitBlock(enclosingInstance);
this.similarity = Enclosing_Instance.GetSimilarity(searcher);
}
public virtual Query GetQuery()
{
return Enclosing_Instance;
}
public virtual float GetValue()
{
return queryWeight;
}
public virtual float SumOfSquaredWeights()
{
queryWeight = Enclosing_Instance.GetBoost();
return queryWeight * queryWeight;
}
public virtual void Normalize(float norm)
{
this.queryNorm = norm;
queryWeight *= this.queryNorm;
}
public virtual Scorer Scorer(IndexReader reader)
{
return new ConstantScorer(enclosingInstance, similarity, reader, this);
}
public virtual Explanation Explain(IndexReader reader, int doc)
{
ConstantScorer cs = (ConstantScorer) Scorer(reader);
bool exists = cs.bits.Get(doc);
ComplexExplanation result = new ComplexExplanation();
if (exists)
{
result.SetDescription("ConstantScoreQuery(" + Enclosing_Instance.filter + "), product of:");
result.SetValue(queryWeight);
System.Boolean tempAux = true;
result.SetMatch(tempAux);
result.AddDetail(new Explanation(Enclosing_Instance.GetBoost(), "boost"));
result.AddDetail(new Explanation(queryNorm, "queryNorm"));
}
else
{
result.SetDescription("ConstantScoreQuery(" + Enclosing_Instance.filter + ") doesn't match id " + doc);
result.SetValue(0);
System.Boolean tempAux2 = false;
result.SetMatch(tempAux2);
}
return result;
}
}
protected internal class ConstantScorer : Scorer
{
private void InitBlock(ConstantScoreQuery enclosingInstance)
{
this.enclosingInstance = enclosingInstance;
}
private ConstantScoreQuery enclosingInstance;
public ConstantScoreQuery Enclosing_Instance
{
get
{
return enclosingInstance;
}
}
internal System.Collections.BitArray bits;
internal float theScore;
internal int doc = - 1;
public ConstantScorer(ConstantScoreQuery enclosingInstance, Similarity similarity, IndexReader reader, Weight w):base(similarity)
{
InitBlock(enclosingInstance);
theScore = w.GetValue();
bits = Enclosing_Instance.filter.Bits(reader);
}
public override bool Next()
{
doc = SupportClass.Number.NextSetBit(bits, doc + 1);
return doc >= 0;
}
public override int Doc()
{
return doc;
}
public override float Score()
{
return theScore;
}
public override bool SkipTo(int target)
{
doc = SupportClass.Number.NextSetBit(bits, target); // requires JDK 1.4
return doc >= 0;
}
public override Explanation Explain(int doc)
{
throw new System.NotSupportedException();
}
}
protected internal override Weight CreateWeight(Searcher searcher)
{
return new ConstantScoreQuery.ConstantWeight(this, searcher);
}
/// Prints a user-readable version of this query.
public override System.String ToString(System.String field)
{
return "ConstantScore(" + filter.ToString() + (GetBoost() == 1.0 ? ")" : "^" + GetBoost());
}
/// Returns true if o
is equal to this.
public override bool Equals(System.Object o)
{
if (this == o)
return true;
if (!(o is ConstantScoreQuery))
return false;
ConstantScoreQuery other = (ConstantScoreQuery) o;
return this.GetBoost() == other.GetBoost() && filter.Equals(other.filter);
}
/// Returns a hash code value for this object.
public override int GetHashCode()
{
// Simple add is OK since no existing filter hashcode has a float component.
return filter.GetHashCode() + BitConverter.ToInt32(BitConverter.GetBytes(GetBoost()), 0);
}
override public System.Object Clone()
{
// {{Aroush-1.9}} is this all that we need to clone?!
ConstantScoreQuery clone = (ConstantScoreQuery) base.Clone();
clone.filter = (Filter) this.filter;
return clone;
}
}
}