951b91fa330cdd7b37d7ea41a0e3613d468ad2ba
1 /**********************************************************************
2 * Copyright (c) 2012, 2014 Ericsson
4 * All rights reserved. This program and the accompanying materials are
5 * made available under the terms of the Eclipse Public License v1.0 which
6 * accompanies this distribution, and is available at
7 * http://www.eclipse.org/legal/epl-v10.html
10 * Bernd Hufmann - Initial API and implementation
11 * Simon Delisle - Updated for support of LTTng Tools 2.2
12 **********************************************************************/
14 package org
.eclipse
.linuxtools
.internal
.lttng2
.control
.core
.model
.impl
;
16 import java
.util
.ArrayList
;
17 import java
.util
.Iterator
;
18 import java
.util
.List
;
20 import org
.eclipse
.linuxtools
.internal
.lttng2
.control
.core
.model
.IChannelInfo
;
21 import org
.eclipse
.linuxtools
.internal
.lttng2
.control
.core
.model
.IEventInfo
;
22 import org
.eclipse
.linuxtools
.internal
.lttng2
.control
.core
.model
.TraceEnablement
;
25 * Implementation of the trace channel interface (IChannelInfo) to store channel
28 * @author Bernd Hufmann
30 public class ChannelInfo
extends TraceInfo
implements IChannelInfo
{
32 // ------------------------------------------------------------------------
34 // ------------------------------------------------------------------------
36 * The overwrite mode of the channel.
38 private boolean fOverwriteMode
;
40 * The sub-buffer size of the channel.
42 private long fSubBufferSize
;
44 * The number of sub-buffers of the channel.
46 private int fNumberOfSubBuffers
;
48 * The switch timer interval of the channel.
50 private long fSwitchTimer
;
52 * The read timer interval of the channel.
54 private long fReadTimer
;
56 * The Output type of the channel.
58 private String fOutputType
= ""; //$NON-NLS-1$
60 * The channel enable state.
62 private TraceEnablement fState
= TraceEnablement
.DISABLED
;
64 * The events information of the channel.
66 private final List
<IEventInfo
> fEvents
= new ArrayList
<>();
68 * The maximum size of trace files
70 private int fMaxSizeTraceFiles
;
72 * The maximum number of trace files
74 private int fMaxNumberTraceFiles
;
76 * The value of buffer type
78 private BufferType fBufferType
= BufferType
.BUFFER_TYPE_UNKNOWN
;
80 // ------------------------------------------------------------------------
82 // ------------------------------------------------------------------------
89 public ChannelInfo(String name
) {
97 * - the instance to copy
99 public ChannelInfo(ChannelInfo other
) {
101 fOverwriteMode
= other
.fOverwriteMode
;
102 fSubBufferSize
= other
.fSubBufferSize
;
103 fNumberOfSubBuffers
= other
.fNumberOfSubBuffers
;
104 fSwitchTimer
= other
.fSwitchTimer
;
105 fReadTimer
= other
.fReadTimer
;
106 fMaxSizeTraceFiles
= other
.fMaxSizeTraceFiles
;
107 fMaxNumberTraceFiles
= other
.fMaxNumberTraceFiles
;
108 fBufferType
= other
.fBufferType
;
109 fOutputType
= (other
.fOutputType
== null ?
null : String
.valueOf(other
.fOutputType
));
110 fState
= other
.fState
;
111 for (Iterator
<IEventInfo
> iterator
= other
.fEvents
.iterator(); iterator
.hasNext();) {
112 IEventInfo event
= iterator
.next();
113 if (event
instanceof EventInfo
) {
114 fEvents
.add(new EventInfo((EventInfo
) event
));
121 // ------------------------------------------------------------------------
123 // ------------------------------------------------------------------------
126 public boolean isOverwriteMode() {
127 return fOverwriteMode
;
131 public void setOverwriteMode(boolean mode
) {
132 fOverwriteMode
= mode
;
136 public long getSubBufferSize() {
137 return fSubBufferSize
;
141 public void setSubBufferSize(long bufferSize
) {
142 fSubBufferSize
= bufferSize
;
146 public int getNumberOfSubBuffers() {
147 return fNumberOfSubBuffers
;
151 public void setNumberOfSubBuffers(int numberOfSubBuffers
) {
152 fNumberOfSubBuffers
= numberOfSubBuffers
;
156 public long getSwitchTimer() {
161 public void setSwitchTimer(long timer
) {
162 fSwitchTimer
= timer
;
166 public long getReadTimer() {
171 public void setReadTimer(long timer
) {
176 public String
getOutputType() {
181 public void setOutputType(String type
) {
186 public TraceEnablement
getState() {
191 public void setState(TraceEnablement state
) {
196 public void setState(String stateName
) {
197 fState
= TraceEnablement
.valueOfString(stateName
);
201 public IEventInfo
[] getEvents() {
202 return fEvents
.toArray(new IEventInfo
[fEvents
.size()]);
206 public void setEvents(List
<IEventInfo
> events
) {
208 for (Iterator
<IEventInfo
> iterator
= events
.iterator(); iterator
.hasNext();) {
209 IEventInfo eventInfo
= iterator
.next();
210 fEvents
.add(eventInfo
);
215 public void addEvent(IEventInfo channel
) {
216 fEvents
.add(channel
);
220 public int hashCode() {
221 final int prime
= 31;
222 int result
= super.hashCode();
223 result
= prime
* result
+ fEvents
.hashCode();
224 result
= prime
* result
+ fNumberOfSubBuffers
;
225 result
= prime
* result
+ ((fOutputType
== null) ?
0 : fOutputType
.hashCode());
226 result
= prime
* result
+ (fOverwriteMode ?
1231 : 1237);
227 result
= prime
* result
+ (int) (fReadTimer ^
(fReadTimer
>>> 32));
228 result
= prime
* result
+ ((fState
== null) ?
0 : (fState
.ordinal() + 1));
229 result
= prime
* result
+ (int) (fSubBufferSize ^
(fSubBufferSize
>>> 32));
230 result
= prime
* result
+ (int) (fSwitchTimer ^
(fSwitchTimer
>>> 32));
231 result
= prime
* result
+ ((fBufferType
== null) ?
0 : (fBufferType
.ordinal() + 1));
236 public boolean equals(Object obj
) {
240 if (!super.equals(obj
)) {
243 if (getClass() != obj
.getClass()) {
246 ChannelInfo other
= (ChannelInfo
) obj
;
247 if (!fEvents
.equals(other
.fEvents
)) {
250 if (fNumberOfSubBuffers
!= other
.fNumberOfSubBuffers
) {
253 if (fOutputType
== null) {
254 if (other
.fOutputType
!= null) {
257 } else if (!fOutputType
.equals(other
.fOutputType
)) {
260 if (fOverwriteMode
!= other
.fOverwriteMode
) {
263 if (fReadTimer
!= other
.fReadTimer
) {
266 if (fState
!= other
.fState
) {
269 if (fSubBufferSize
!= other
.fSubBufferSize
) {
272 if (fSwitchTimer
!= other
.fSwitchTimer
) {
275 if (fBufferType
!= other
.fBufferType
) {
281 @SuppressWarnings("nls")
283 public String
toString() {
284 StringBuffer output
= new StringBuffer();
285 output
.append("[ChannelInfo(");
286 output
.append(super.toString());
287 output
.append(",State=");
288 output
.append(fState
);
289 output
.append(",OverwriteMode=");
290 output
.append(fOverwriteMode
);
291 output
.append(",SubBuffersSize=");
292 output
.append(fSubBufferSize
);
293 output
.append(",NumberOfSubBuffers=");
294 output
.append(fNumberOfSubBuffers
);
295 output
.append(",SwitchTimer=");
296 output
.append(fSwitchTimer
);
297 output
.append(",ReadTimer=");
298 output
.append(fReadTimer
);
299 output
.append(",output=");
300 output
.append(fOutputType
);
301 if ((fBufferType
!= null) && !fBufferType
.equals(BufferType
.BUFFER_TYPE_UNKNOWN
) && !fBufferType
.equals(BufferType
.BUFFER_SHARED
)) {
302 output
.append(",BufferType=");
303 output
.append(fBufferType
);
305 output
.append(",Events=");
306 if (fEvents
.isEmpty()) {
307 output
.append("None");
309 for (Iterator
<IEventInfo
> iterator
= fEvents
.iterator(); iterator
.hasNext();) {
310 IEventInfo event
= iterator
.next();
311 output
.append(event
.toString());
315 return output
.toString();
319 public void setMaxSizeTraceFiles(int maxSizeTraceFiles
) {
320 fMaxSizeTraceFiles
= maxSizeTraceFiles
;
324 public void setMaxNumberTraceFiles(int maxNumberTraceFiles
) {
325 fMaxNumberTraceFiles
= maxNumberTraceFiles
;
329 public int getMaxSizeTraceFiles() {
330 return fMaxSizeTraceFiles
;
334 public int getMaxNumberTraceFiles() {
335 return fMaxNumberTraceFiles
;
339 public void setBufferType(BufferType bufferType
) {
340 fBufferType
= bufferType
;
344 public BufferType
getBufferType() {
This page took 0.040532 seconds and 5 git commands to generate.