All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.hcl.domino.jna.internal.views.NotesViewLookupResultData 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.internal.views;

import java.util.List;

import com.hcl.domino.commons.views.NotesCollectionStats;
import com.hcl.domino.commons.views.ReadMask;
import com.hcl.domino.data.DominoDateTime;
import com.hcl.domino.jna.data.JNACollectionEntry;
import com.hcl.domino.jna.data.JNADominoCollection;
import com.hcl.domino.misc.NotesConstants;

/**
 * Container class for a lookup result in a collection/view
 * 
 * @author Karsten Lehmann
 */
public class NotesViewLookupResultData {
	private NotesCollectionStats m_stats;
	private List m_entries;
	private int m_numEntriesReturned;
	private int m_numEntriesSkipped;
	private short m_signalFlags;
	private String m_pos;
	private int m_indexModifiedSequenceNo;
	private DominoDateTime m_retDiffTime;
	
	/**
	 * Creates a new instance
	 * 
	 * @param stats collection statistics
	 * @param entries entries read from the buffer
	 * @param numEntriesSkipped number of skipped entries
	 * @param numEntriesReturned number of returned entries
	 * @param signalFlags signal flags indicating view index changes and other stuff
	 * @param pos first matching position
	 * @param indexModifiedSequenceNo index modified sequence number
	 * @param retDiffTime only set in {@link JNADominoCollection#readEntriesExt(com.hcl.domino.jna.data.JNADominoCollectionPosition, com.hcl.domino.data.Navigate, boolean, int, com.hcl.domino.data.Navigate, int, java.util.Set, DominoDateTime, com.hcl.domino.jna.data.JNAIDTable, Integer)}
	 */
	public NotesViewLookupResultData(NotesCollectionStats stats, List entries, int numEntriesSkipped, int numEntriesReturned, short signalFlags, String pos, int indexModifiedSequenceNo, DominoDateTime retDiffTime) {
		m_stats = stats;
		m_entries = entries;
		m_numEntriesSkipped = numEntriesSkipped;
		m_numEntriesReturned = numEntriesReturned;
		m_signalFlags = signalFlags;
		m_pos = pos;
		m_indexModifiedSequenceNo = indexModifiedSequenceNo;
		m_retDiffTime = retDiffTime;
	}

	/**
	 * For differential view reading via {@link JNADominoCollection#readEntriesExt(com.hcl.domino.jna.data.JNADominoCollectionPosition, com.hcl.domino.data.Navigate, boolean, int, com.hcl.domino.data.Navigate, int, java.util.Set, DominoDateTime, com.hcl.domino.jna.data.JNAIDTable, Integer)},
	 * this method returns the returned diff time that can be passed in subsequent read calls to
	 * get incremental view updates
	 * 
	 * @return diff time or null
	 */
	public DominoDateTime getReturnedDiffTime() {
		return m_retDiffTime;
	}
	
	/**
	 * Returns the index modified sequence number, which is increased on every index change.
* * @return number */ public int getIndexModifiedSequenceNo() { return m_indexModifiedSequenceNo; } /** * If multiple index entries match the specified lookup key (especially if
* not enough key items were specified), then the index position of
* the FIRST matching entry is returned ("first" is defined by the
* entry which collates before all others in the collated index).
* * Will only be set when {@link JNADominoCollection#findByKeyExtended2(java.util.Set, java.util.Set, Object...)} * is called. * * @return position or null */ public String getPosition() { return m_pos; } /** * Returns view statistics, if they have been requested via the * read mask {@link ReadMask#COLLECTIONSTATS} * * @return statistics or null */ public NotesCollectionStats getStats() { return m_stats; } /** * Returns the number of view entries skipped * * @return skip count */ public int getSkipCount() { return m_numEntriesSkipped; } /** * Returns the number of view entries read * * @return return count */ public int getReturnCount() { return m_numEntriesReturned; } /** * Returns the view entry data * * @return list of view entry data */ public List getEntries() { return m_entries; } /** * End of collection has not been reached because the return buffer is too full. * The NIFReadEntries call should be repeated to continue reading the desired entries. * * @return true if more to do */ public boolean hasMoreToDo() { return (m_signalFlags & NotesConstants.SIGNAL_MORE_TO_DO) == NotesConstants.SIGNAL_MORE_TO_DO; } /** * Collection is not up to date. * * @return true if database was modified */ public boolean isDatabaseModified() { return (m_signalFlags & NotesConstants.SIGNAL_DATABASE_MODIFIED) == NotesConstants.SIGNAL_DATABASE_MODIFIED; } /** * At least one of the "definition" view items (Selection formula or sorting rules) has been * modified by another user since the last NIFReadEntries. Upon receipt, you may wish to * re-read the view note if up-to-date copies of these items are needed. You also may wish * to re-synchronize your index position and re-read the rebuilt index.
*
* This signal is returned only ONCE per detection. * * @return true if modified */ public boolean isViewDefiningItemModified() { return (m_signalFlags & NotesConstants.SIGNAL_DEFN_ITEM_MODIFIED) == NotesConstants.SIGNAL_DEFN_ITEM_MODIFIED; } /** * At least one of the non-"definition" view items ($TITLE,etc) has been * modified since last ReadEntries. * Upon receipt, you may wish to re-read the view note if up-to-date copies of these * items are needed.
*
* Signal returned only ONCE per detection * * @return true if modified */ public boolean isViewOtherItemModified() { return (m_signalFlags & NotesConstants.SIGNAL_VIEW_ITEM_MODIFIED) == NotesConstants.SIGNAL_VIEW_ITEM_MODIFIED; } /** * The collection index has been modified by another user since the last NIFReadEntries. * Upon receipt, you may wish to re-synchronize your index position and re-read the modified index. * This signal is returned only ONCE per detection. * * @return true if modified */ public boolean isViewIndexModified() { return (m_signalFlags & NotesConstants.SIGNAL_INDEX_MODIFIED) == NotesConstants.SIGNAL_INDEX_MODIFIED; } /** * Use this method to tell whether the collection contains a time-relative formula (e.g., @ Now) and * will EVER be up-to-date since time-relative views, by definition, are NEVER up-to-date. * * @return true if time relative */ public boolean isViewTimeRelative() { return (m_signalFlags & NotesConstants.SIGNAL_VIEW_TIME_RELATIVE) == NotesConstants.SIGNAL_VIEW_TIME_RELATIVE; } /** * Returns whether the view contains documents with reader fields * * @return true if reader fields */ public boolean hasDocsWithReaderFields() { return (m_signalFlags & NotesConstants.SIGNAL_VIEW_HASPRIVS) == NotesConstants.SIGNAL_VIEW_HASPRIVS; } /** * Mask that defines all "sharing conflicts" except for {@link #isDatabaseModified()}. * This can be used in combination with {@link #isViewTimeRelative()} to tell if * the database or collection has truly changed out from under the user or if the * view is a time-relative view which will NEVER be up-to-date. {@link #isDatabaseModified()} * is always returned for a time-relative view to indicate that it is never up-to-date. * * @return true if we have conflicts */ public boolean hasAnyNonDataConflicts() { return (m_signalFlags & NotesConstants.SIGNAL_ANY_NONDATA_CONFLICT) != 0; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy