/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* 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 org.apache.jmeter.protocol.http.util.accesslog;
import java.io.IOException;
import org.apache.jmeter.services.FileServer;
import org.apache.jmeter.testelement.TestCloneable;
import org.apache.jmeter.testelement.TestElement;
public class SharedTCLogParser extends TCLogParser implements TestCloneable {
public SharedTCLogParser() {
super();
}
public SharedTCLogParser(String source) {
super(source);
}
/* (non-Javadoc)
* @see java.lang.Object#clone()
*/
public Object clone() {
SharedTCLogParser parser = new SharedTCLogParser();
parser.FILENAME = FILENAME;
parser.FILTER = FILTER;
return parser;
}
/* (non-Javadoc)
* @see org.apache.jmeter.protocol.http.util.accesslog.TCLogParser#parse(org.apache.jmeter.testelement.TestElement, int)
*/
public int parse(TestElement el, int parseCount) {
FileServer fileServer = FileServer.getFileServer();
fileServer.reserveFile(FILENAME);
try {
return parse(fileServer, el, parseCount);
} catch (Exception exception) {
log.error("Problem creating samples", exception);
}
return -1;// indicate that an error occured
}
/**
* The method is responsible for reading each line, and breaking out of the
* while loop if a set number of lines is given.
*
* @param breader
*/
protected int parse(FileServer breader, TestElement el, int parseCount) {
int actualCount = 0;
String line = null;
try {
// read one line at a time using
// BufferedReader
line = breader.readLine(FILENAME);
while (line != null) {
if (line.length() > 0) {
actualCount += this.parseLine(line, el);
}
// we check the count to see if we have exceeded
// the number of lines to parse. There's no way
// to know where to stop in the file. Therefore
// we use break to escape the while loop when
// we've reached the count.
if (parseCount != -1 && actualCount >= parseCount) {
break;
}
line = breader.readLine(FILENAME);
}
if (line == null) {
breader.closeFile(FILENAME);
// this.READER = new BufferedReader(new
// FileReader(this.SOURCE));
// parse(this.READER,el);
}
} catch (IOException ioe) {
log.error("Error reading log file", ioe);
}
return actualCount;
}
public void close() {
try {
FileServer.getFileServer().closeFile(FILENAME);
} catch (IOException e) {
// do nothing
}
}
}