/** * 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. */ package org.apache.nutch.searcher; import java.io.DataInput; import java.io.DataOutput; import java.io.IOException; import org.apache.hadoop.io.Writable; import org.apache.hadoop.io.WritableComparable; import org.apache.hadoop.io.Text; /** A set of hits matching a query. */ public final class Hits implements Writable { private long total; private boolean totalIsExact = true; private Hit[] top; public Hits() {} public Hits(long total, Hit[] top) { this.total = total; this.top = top; } /** Returns the total number of hits for this query. This may be an estimate * when (@link #totalIsExact()} is false. */ public long getTotal() { return total; } /** True if {@link #getTotal()} gives the exact number of hits, or false if * it is only an estimate of the total number of hits. */ public boolean totalIsExact() { return totalIsExact; } /** Set {@link #totalIsExact()}. */ public void setTotalIsExact(boolean isExact) { totalIsExact = isExact; } /** Returns the number of hits included in this current listing. */ public int getLength() { return top.length; } /** Returns the <code>i</code><sup>th</sup> hit in this list. */ public Hit getHit(int i) { return top[i]; } /** Returns a subset of the hit objects. */ public Hit[] getHits(int start, int length) { Hit[] results = new Hit[length]; for (int i = 0; i < length; i++) { results[i] = top[start+i]; } return results; } public void write(DataOutput out) throws IOException { out.writeLong(total); // write total hits out.writeInt(top.length); // write hits returned if (top.length > 0) // write sort value class Text.writeString(out, top[0].getSortValue().getClass().getName()); for (int i = 0; i < top.length; i++) { Hit h = top[i]; Text.writeString(out, h.getUniqueKey()); // write uniqueKey h.getSortValue().write(out); // write sortValue Text.writeString(out, h.getDedupValue()); // write dedupValue } } @SuppressWarnings("unchecked") public void readFields(DataInput in) throws IOException { total = in.readLong(); // read total hits top = new Hit[in.readInt()]; // read hits returned Class sortClass = null; if (top.length > 0) { // read sort value class try { sortClass = Class.forName(Text.readString(in)); } catch (ClassNotFoundException e) { throw new IOException(e.toString()); } } for (int i = 0; i < top.length; i++) { String uniqueKey = Text.readString(in); // read uniqueKey WritableComparable sortValue = null; try { sortValue = (WritableComparable)sortClass.newInstance(); } catch (Exception e) { throw new IOException(e.toString()); } sortValue.readFields(in); // read sortValue String dedupValue = Text.readString(in); // read dedupValue top[i] = new Hit(uniqueKey, sortValue, dedupValue); } } }