/*
* Copyright 2016 The Android Open Source Project
*
* Licensed 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.
*/
#ifndef __VTS_SYSFUZZER_LIBMEASUREMENT_GCDA_PARSER_H__
#define __VTS_SYSFUZZER_LIBMEASUREMENT_GCDA_PARSER_H__
#include <iostream>
#include <string>
#include <vector>
#include "GcdaFile.h"
using namespace std;
namespace android {
namespace vts {
// Parses a GCDA file and extracts raw coverage info.
class GcdaRawCoverageParser {
public:
explicit GcdaRawCoverageParser(const char* filename)
: filename_(filename), gcda_file_(new GcdaFile(filename_)) {}
virtual ~GcdaRawCoverageParser() {}
// Parses a given file and returns a vector which contains IDs of raw
// coverage measurement units (e.g., basic blocks).
vector<unsigned> Parse();
protected:
// Parses the GCOV magic number.
bool ParseMagic();
// Parses the GCOV file body.
void ParseBody();
// Processes tag for functions.
void TagFunction(unsigned /*tag*/, unsigned length) {
/* unsigned long pos = */ gcda_file_->Position();
if (length) {
gcda_file_->ReadUnsigned(); // ident %u
unsigned lineno_checksum = gcda_file_->ReadUnsigned();
result.push_back(lineno_checksum);
gcda_file_->ReadUnsigned(); // cfg_checksum 0x%08x
}
}
// Processes tag for blocks.
void TagBlocks(unsigned /*tag*/, unsigned length) {
unsigned n_blocks = GCOV_TAG_BLOCKS_NUM(length);
cout << __func__ << ": " << n_blocks << " blocks" << endl;
}
// Processes tag for arcs.
void TagArcs(unsigned /*tag*/, unsigned length) {
unsigned n_arcs = GCOV_TAG_ARCS_NUM(length);
cout << __func__ << ": " << n_arcs << " arcs" << endl;
}
// Processes tag for lines.
void TagLines(unsigned /*tag*/, unsigned /*length*/) {
cout << __func__ << endl;
}
private:
// the name of a target file.
const string filename_;
// global GcovFile data structure.
GcdaFile* gcda_file_;
// vector containing the parsed, raw coverage data.
vector<unsigned> result;
};
} // namespace vts
} // namespace android
#endif