SessionInfoStore.java
- /*******************************************************************************
- * Copyright (c) 2009, 2025 Mountainminds GmbH & Co. KG and Contributors
- * This program and the accompanying materials are made available under
- * the terms of the Eclipse Public License 2.0 which is available at
- * http://www.eclipse.org/legal/epl-2.0
- *
- * SPDX-License-Identifier: EPL-2.0
- *
- * Contributors:
- * Marc R. Hoffmann - initial API and implementation
- *
- *******************************************************************************/
- package org.jacoco.core.data;
- import static java.lang.Math.max;
- import static java.lang.Math.min;
- import java.util.ArrayList;
- import java.util.Collections;
- import java.util.List;
- /**
- * Container to collect and merge session {@link SessionInfo} objects. An
- * instance of this class is not thread safe.
- */
- public class SessionInfoStore implements ISessionInfoVisitor {
- private final List<SessionInfo> infos = new ArrayList<SessionInfo>();
- /**
- * Tests whether the store is empty.
- *
- * @return <code>true</code> if the store is empty
- */
- public boolean isEmpty() {
- return infos.isEmpty();
- }
- /**
- * Returns all {@link SessionInfo} objects currently contained in the store.
- * The info objects are ordered by its natural ordering (i.e. by the dump
- * time stamp).
- *
- * @return list of stored {@link SessionInfo} objects
- */
- public List<SessionInfo> getInfos() {
- final List<SessionInfo> copy = new ArrayList<SessionInfo>(infos);
- Collections.sort(copy);
- return copy;
- }
- /**
- * Returns a new session info with the given id that contains a merged
- * version from all contained version. The start timestamp is the minimum of
- * all contained sessions, the dump timestamp the maximum of all contained
- * sessions. If no session is currently contained both timestamps are set to
- * <code>0</code>.
- *
- * @param id
- * identifier for the merged session info
- * @return new {@link SessionInfo} object
- *
- */
- public SessionInfo getMerged(final String id) {
- if (infos.isEmpty()) {
- return new SessionInfo(id, 0, 0);
- }
- long start = Long.MAX_VALUE;
- long dump = Long.MIN_VALUE;
- for (final SessionInfo i : infos) {
- start = min(start, i.getStartTimeStamp());
- dump = max(dump, i.getDumpTimeStamp());
- }
- return new SessionInfo(id, start, dump);
- }
- /**
- * Writes all contained {@link SessionInfo} objects into the given visitor.
- * The info objects are emitted in chronological order by dump timestamp.
- *
- * @param visitor
- * visitor to emit {@link SessionInfo} objects to
- */
- public void accept(final ISessionInfoVisitor visitor) {
- for (final SessionInfo i : getInfos()) {
- visitor.visitSessionInfo(i);
- }
- }
- // === ISessionInfoVisitor ===
- public void visitSessionInfo(final SessionInfo info) {
- infos.add(info);
- }
- }