/** * Copyright 2014 National University of Ireland, Galway. * * This file is part of the SIREn project. Project and contact information: * * https://github.com/rdelbru/SIREn * * Licensed 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.sindice.siren.qparser.keyword.builders; import java.util.ArrayList; import java.util.List; import org.apache.lucene.search.Query; import org.sindice.siren.qparser.keyword.nodes.ArrayQueryNode; /** * An {@link ArrayQuery} is a {@link Query} object that is used to store * a list of queries. * * @see ArrayQueryNode */ final class ArrayQuery extends Query { private final ArrayList<Query> elements = new ArrayList<Query>(); /** * Add a {@link Query} to the array */ public void addElement(final Query q) { elements.add(q); } /** * Returns the list of queries. */ public List<Query> getElements() { return elements; } @Override public String toString(final String field) { final StringBuilder sb = new StringBuilder("[ "); for (int i = 0; i < elements.size(); i++) { sb.append(elements.get(i).toString(field)); if (i + 1 != elements.size()) { sb.append(", "); } } sb.append(" ]"); return sb.toString(); } }