This commit is contained in:
kimchy 2010-10-06 14:07:34 +02:00
parent 22ed71e2e6
commit 4422a4c48a
1 changed files with 45 additions and 0 deletions

View File

@ -30,6 +30,8 @@ import java.io.IOException;
import java.util.Map; import java.util.Map;
/** /**
* Term facets allow to collect frequency of terms within one (or more) field.
*
* @author kimchy (shay.banon) * @author kimchy (shay.banon)
*/ */
public class TermsFacetBuilder extends AbstractFacetBuilder { public class TermsFacetBuilder extends AbstractFacetBuilder {
@ -44,55 +46,92 @@ public class TermsFacetBuilder extends AbstractFacetBuilder {
private String lang; private String lang;
private Map<String, Object> params; private Map<String, Object> params;
/**
* Construct a new term facet with the provided facet name.
*
* @param name The facet name.
*/
public TermsFacetBuilder(String name) { public TermsFacetBuilder(String name) {
super(name); super(name);
} }
/**
* Should the fact run in global mode (not bounded by the search query) or not. Defaults
* to <tt>false</tt>.
*/
public TermsFacetBuilder global(boolean global) { public TermsFacetBuilder global(boolean global) {
this.global = global; this.global = global;
return this; return this;
} }
/**
* An additional facet filter that will further filter the documents the facet will be
* executed on.
*/
public TermsFacetBuilder facetFilter(XContentFilterBuilder filter) { public TermsFacetBuilder facetFilter(XContentFilterBuilder filter) {
this.facetFilter = filter; this.facetFilter = filter;
return this; return this;
} }
/**
* The field the terms will be collected from.
*/
public TermsFacetBuilder field(String field) { public TermsFacetBuilder field(String field) {
this.fieldName = field; this.fieldName = field;
return this; return this;
} }
/**
* The fields the terms will be collected from.
*/
public TermsFacetBuilder fields(String... fields) { public TermsFacetBuilder fields(String... fields) {
this.fieldsNames = fields; this.fieldsNames = fields;
return this; return this;
} }
/**
* A set of terms that will be excluded.
*/
public TermsFacetBuilder exclude(String... exclude) { public TermsFacetBuilder exclude(String... exclude) {
this.exclude = exclude; this.exclude = exclude;
return this; return this;
} }
/**
* The number of terms (and frequencies) to return. Defaults to 10.
*/
public TermsFacetBuilder size(int size) { public TermsFacetBuilder size(int size) {
this.size = size; this.size = size;
return this; return this;
} }
/**
* A regular expression to use in order to further filter terms.
*/
public TermsFacetBuilder regex(String regex) { public TermsFacetBuilder regex(String regex) {
return regex(regex, 0); return regex(regex, 0);
} }
/**
* A regular expression (with flags) to use in order to further filter terms.
*/
public TermsFacetBuilder regex(String regex, int flags) { public TermsFacetBuilder regex(String regex, int flags) {
this.regex = regex; this.regex = regex;
this.regexFlags = flags; this.regexFlags = flags;
return this; return this;
} }
/**
* The order by which to return the facets by. Defaults to {@link TermsFacet.ComparatorType#COUNT}.
*/
public TermsFacetBuilder order(TermsFacet.ComparatorType comparatorType) { public TermsFacetBuilder order(TermsFacet.ComparatorType comparatorType) {
this.comparatorType = comparatorType; this.comparatorType = comparatorType;
return this; return this;
} }
/**
* A script allowing to either modify or ignore a provided term (can be accessed using <tt>term</tt> var).
*/
public TermsFacetBuilder script(String script) { public TermsFacetBuilder script(String script) {
this.script = script; this.script = script;
return this; return this;
@ -106,6 +145,12 @@ public class TermsFacetBuilder extends AbstractFacetBuilder {
return this; return this;
} }
/**
* A parameter that will be passed to the script.
*
* @param name The name of the script parameter.
* @param value The value of the script parameter.
*/
public TermsFacetBuilder param(String name, Object value) { public TermsFacetBuilder param(String name, Object value) {
if (params == null) { if (params == null) {
params = Maps.newHashMap(); params = Maps.newHashMap();