1 /*******************************************************************************
2 * Copyright (c) 2009, 2010 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 * Francois Chouinard - Initial API and implementation
11 *******************************************************************************/
13 package org
.eclipse
.linuxtools
.tmf
.tests
.stubs
.trace
;
15 import java
.io
.FileNotFoundException
;
16 import java
.io
.IOException
;
17 import java
.io
.RandomAccessFile
;
18 import java
.util
.concurrent
.locks
.ReentrantLock
;
20 import org
.eclipse
.linuxtools
.tmf
.core
.event
.ITmfEvent
;
21 import org
.eclipse
.linuxtools
.tmf
.core
.event
.ITmfTimestamp
;
22 import org
.eclipse
.linuxtools
.tmf
.core
.event
.TmfEvent
;
23 import org
.eclipse
.linuxtools
.tmf
.core
.event
.TmfTimeRange
;
24 import org
.eclipse
.linuxtools
.tmf
.core
.parser
.ITmfEventParser
;
25 import org
.eclipse
.linuxtools
.tmf
.core
.trace
.ITmfContext
;
26 import org
.eclipse
.linuxtools
.tmf
.core
.trace
.ITmfLocation
;
27 import org
.eclipse
.linuxtools
.tmf
.core
.trace
.TmfContext
;
28 import org
.eclipse
.linuxtools
.tmf
.core
.trace
.TmfLocation
;
29 import org
.eclipse
.linuxtools
.tmf
.core
.trace
.TmfTrace
;
32 * <b><u>TmfTraceStub</u></b>
34 * Dummy test trace. Use in conjunction with TmfEventParserStub.
36 @SuppressWarnings("nls")
37 public class TmfTraceStub
extends TmfTrace
<TmfEvent
> {
39 // ------------------------------------------------------------------------
41 // ------------------------------------------------------------------------
44 private RandomAccessFile fTrace
;
46 // The associated event parser
47 private ITmfEventParser
<TmfEvent
> fParser
;
49 // The synchronization lock
50 private ReentrantLock fLock
= new ReentrantLock();
52 // ------------------------------------------------------------------------
54 // ------------------------------------------------------------------------
58 * @throws FileNotFoundException
60 public TmfTraceStub(String path
) throws FileNotFoundException
{
61 this(path
, DEFAULT_INDEX_PAGE_SIZE
, false);
67 * @throws FileNotFoundException
69 public TmfTraceStub(String path
, int cacheSize
) throws FileNotFoundException
{
70 this(path
, cacheSize
, false);
75 * @param waitForCompletion
76 * @throws FileNotFoundException
78 public TmfTraceStub(String path
, boolean waitForCompletion
) throws FileNotFoundException
{
79 this(path
, DEFAULT_INDEX_PAGE_SIZE
, waitForCompletion
);
85 * @param waitForCompletion
86 * @throws FileNotFoundException
88 public TmfTraceStub(String path
, int cacheSize
, boolean waitForCompletion
) throws FileNotFoundException
{
89 super(null, TmfEvent
.class, path
, cacheSize
, false);
90 fTrace
= new RandomAccessFile(path
, "r");
91 fParser
= new TmfEventParserStub();
98 * @param waitForCompletion
100 * @throws FileNotFoundException
102 public TmfTraceStub(String path
, int cacheSize
, boolean waitForCompletion
, ITmfEventParser
<TmfEvent
> parser
) throws FileNotFoundException
{
103 super(path
, TmfEvent
.class, path
, cacheSize
, false);
104 fTrace
= new RandomAccessFile(path
, "r");
111 public TmfTraceStub
clone() {
112 TmfTraceStub clone
= null;
114 clone
= (TmfTraceStub
) super.clone();
115 clone
.fTrace
= new RandomAccessFile(getPath(), "r");
116 clone
.fParser
= new TmfEventParserStub();
117 } catch (FileNotFoundException e
) {
122 // ------------------------------------------------------------------------
124 // ------------------------------------------------------------------------
126 public RandomAccessFile
getStream() {
130 // ------------------------------------------------------------------------
132 // ------------------------------------------------------------------------
135 @SuppressWarnings("unchecked")
136 public TmfContext
seekLocation(ITmfLocation
<?
> location
) {
139 if (fTrace
!= null) {
140 // Position the trace at the requested location and
141 // returns the corresponding context
144 if (location
!= null) {
145 loc
= ((TmfLocation
<Long
>) location
).getLocation();
146 rank
= ITmfContext
.UNKNOWN_RANK
;
148 if (loc
!= fTrace
.getFilePointer()) {
151 TmfContext context
= new TmfContext(getCurrentLocation(), rank
);
154 } catch (IOException e
) {
165 public TmfContext
seekLocation(double ratio
) {
168 if (fTrace
!= null) {
169 ITmfLocation
<?
> location
= new TmfLocation
<Long
>(Long
.valueOf((long) (ratio
* fTrace
.length())));
170 TmfContext context
= seekLocation(location
);
171 context
.setRank(ITmfContext
.UNKNOWN_RANK
);
174 } catch (IOException e
) {
184 @SuppressWarnings("rawtypes")
185 public double getLocationRatio(ITmfLocation location
) {
188 if (fTrace
!= null) {
189 if (location
.getLocation() instanceof Long
) {
190 return (double) ((Long
) location
.getLocation()) / fTrace
.length();
193 } catch (IOException e
) {
202 public TmfLocation
<Long
> getCurrentLocation() {
205 if (fTrace
!= null) {
206 return new TmfLocation
<Long
>(fTrace
.getFilePointer());
208 } catch (IOException e
) {
217 public ITmfEvent
parseEvent(ITmfContext context
) {
220 // parseNextEvent will update the context
221 if (fTrace
!= null) {
222 ITmfEvent event
= fParser
.parseNextEvent(this, context
.clone());
226 catch (IOException e
) {
235 public void setTimeRange(TmfTimeRange range
) {
236 super.setTimeRange(range
);
240 public void setStartTime(ITmfTimestamp startTime
) {
241 super.setStartTime(startTime
);
245 public void setEndTime(ITmfTimestamp endTime
) {
246 super.setEndTime(endTime
);
250 public void dispose() {
253 if (fTrace
!= null) {
257 } catch (IOException e
) {
This page took 0.035857 seconds and 5 git commands to generate.