com.hcl.domino.jna.data.JNAFormulaQueryResult Maven / Gradle / Ivy
/*
* ==========================================================================
* Copyright (C) 2019-2022 HCL America, Inc. ( http://www.hcl.com/ )
* All rights reserved.
* ==========================================================================
* 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 .
*
* 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 com.hcl.domino.jna.data;
import java.util.Collection;
import java.util.List;
import java.util.Map;
import java.util.Optional;
import java.util.Set;
import java.util.function.BiConsumer;
import java.util.stream.Stream;
import com.hcl.domino.data.CollectionEntry;
import com.hcl.domino.data.CollectionSearchQuery.CollectionEntryProcessor;
import com.hcl.domino.data.Database;
import com.hcl.domino.data.Database.SearchMatch;
import com.hcl.domino.data.Document;
import com.hcl.domino.data.DominoCollection;
import com.hcl.domino.data.DominoDateTime;
import com.hcl.domino.data.FormulaQueryResult;
import com.hcl.domino.data.IDTable;
import com.hcl.domino.misc.Loop;
public class JNAFormulaQueryResult implements FormulaQueryResult {
private JNADatabase m_parentDb;
private DbQueryResultUtil m_queryUtil;
private JNAIDTable m_idTable;
private List m_matches;
private List m_nonMatches;
private List m_deletions;
public JNAFormulaQueryResult(JNADatabase parentDb, JNAIDTable idTable,
List matches, List nonMatches, List deletions) {
m_parentDb = parentDb;
m_idTable = idTable;
m_matches = matches;
m_nonMatches = nonMatches;
m_deletions = deletions;
this.m_queryUtil = new DbQueryResultUtil() {
@Override
public Database getParentDatabase() {
return JNAFormulaQueryResult.this.getParentDatabase();
}
@Override
public Optional getNoteIds() {
return JNAFormulaQueryResult.this.getNoteIds();
}
};
}
@Override
public Database getParentDatabase() {
return m_parentDb;
}
@Override
public Stream getDocuments() {
return m_queryUtil.getDocuments();
}
@Override
public T build(int skip, int count, CollectionEntryProcessor processor) {
return this.m_queryUtil.build(skip, count, processor);
}
@Override
public Set collectIds(int skip, int count) {
return this.m_queryUtil.collectIds(skip, count);
}
@Override
public void collectIds(int skip, int count, Collection idTable) {
this.m_queryUtil.collectIds(skip, count, idTable);
}
@Override
public FormulaQueryResult computeValues(String... itemsAndFormulas) {
m_queryUtil.computeValues(itemsAndFormulas);
return this;
}
@Override
public FormulaQueryResult computeValues(Map itemsAndFormulas) {
m_queryUtil.computeValues(itemsAndFormulas);
return this;
}
@Override
public FormulaQueryResult sort(DominoCollection collection) {
m_queryUtil.sort(collection);
return this;
}
@Override
public List collectEntries(int skip, int count) {
return this.m_queryUtil.collectEntries(skip, count);
}
@Override
public void collectEntries(int skip, int count, Collection collection) {
this.m_queryUtil.collectEntries(skip, count, collection);
}
@Override
public void forEachDocument(int skip, int count, BiConsumer consumer) {
m_queryUtil.forEachDocument(skip, count, consumer);
}
@Override
public int size() {
return m_idTable.size();
}
@Override
public Optional getNoteIds() {
return Optional.ofNullable(m_idTable);
}
@Override
public List getMatches() {
return m_matches;
}
@Override
public List getNonMatches() {
return m_nonMatches;
}
@Override
public List getDeletions() {
return m_deletions;
}
@Override
public DominoDateTime getUntil() {
return m_idTable.getDateTime().orElseThrow(() -> new IllegalStateException("Underlying search did not return an until value"));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy