1 /*******************************************************************************
2  * Copyright (c) 2009, 2019 Mountainminds GmbH & Co. KG and Contributors
3  * All rights reserved. This program and the accompanying materials
4  * are made available under the terms of the Eclipse Public License v1.0
5  * which accompanies this distribution, and is available at
6  * http://www.eclipse.org/legal/epl-v10.html
7  *
8  * Contributors:
9  *    Marc R. Hoffmann - initial API and implementation
10  *
11  *******************************************************************************/
12 package org.jacoco.core.data;
13 
14 /**
15  * Data object describing a session which was the source of execution data.
16  * {@link SessionInfo} instances can be sorted by dump date through the
17  * {@link Comparable} interface.
18  */
19 public class SessionInfo implements Comparable<SessionInfo> {
20 
21 	private final String id;
22 
23 	private final long start;
24 
25 	private final long dump;
26 
27 	/**
28 	 * Create a immutable session info with the given data.
29 	 *
30 	 * @param id
31 	 *            arbitrary session identifier, must not be <code>null</code>
32 	 * @param start
33 	 *            the epoc based time stamp when execution data recording has
34 	 *            been started
35 	 * @param dump
36 	 *            the epoc based time stamp when execution data was collected
37 	 */
SessionInfo(final String id, final long start, final long dump)38 	public SessionInfo(final String id, final long start, final long dump) {
39 		if (id == null) {
40 			throw new IllegalArgumentException();
41 		}
42 		this.id = id;
43 		this.start = start;
44 		this.dump = dump;
45 	}
46 
47 	/**
48 	 * @return identifier for this session
49 	 */
getId()50 	public String getId() {
51 		return id;
52 	}
53 
54 	/**
55 	 * @return the epoc based time stamp when execution data recording has been
56 	 *         started
57 	 */
getStartTimeStamp()58 	public long getStartTimeStamp() {
59 		return start;
60 	}
61 
62 	/**
63 	 * @return the epoc based time stamp when execution data was collected
64 	 */
getDumpTimeStamp()65 	public long getDumpTimeStamp() {
66 		return dump;
67 	}
68 
compareTo(final SessionInfo other)69 	public int compareTo(final SessionInfo other) {
70 		if (this.dump < other.dump) {
71 			return -1;
72 		}
73 		if (this.dump > other.dump) {
74 			return +1;
75 		}
76 		return 0;
77 	}
78 
79 	@Override
toString()80 	public String toString() {
81 		return "SessionInfo[" + id + "]";
82 	}
83 }
84