Viewing file: Trace.h (2.64 KB) -rw-r--r-- Select action/file-type: (+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
//===- Trace.h - XRay Trace Abstraction -----------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // Defines the XRay Trace class representing records in an XRay trace file. // //===----------------------------------------------------------------------===// #ifndef LLVM_XRAY_TRACE_H #define LLVM_XRAY_TRACE_H
#include <cstdint> #include <vector>
#include "llvm/ADT/StringRef.h" #include "llvm/Support/DataExtractor.h" #include "llvm/Support/Error.h" #include "llvm/XRay/XRayRecord.h"
namespace llvm { namespace xray {
/// A Trace object represents the records that have been loaded from XRay /// log files generated by instrumented binaries. We encapsulate the logic of /// reading the traces in factory functions that populate the Trace object /// appropriately. /// /// Trace objects provide an accessor to an XRayFileHeader which says more about /// details of the file from which the XRay trace was loaded from. /// /// Usage: /// /// if (auto TraceOrErr = loadTraceFile("xray-log.something.xray")) { /// auto& T = *TraceOrErr; /// // T.getFileHeader() will provide information from the trace header. /// for (const XRayRecord &R : T) { /// // ... do something with R here. /// } /// } else { /// // Handle the error here. /// } /// class Trace { XRayFileHeader FileHeader; using RecordVector = std::vector<XRayRecord>; RecordVector Records;
typedef std::vector<XRayRecord>::const_iterator citerator;
friend Expected<Trace> loadTrace(const DataExtractor &, bool);
public: using size_type = RecordVector::size_type; using value_type = RecordVector::value_type; using const_iterator = RecordVector::const_iterator;
/// Provides access to the loaded XRay trace file header. const XRayFileHeader &getFileHeader() const { return FileHeader; }
const_iterator begin() const { return Records.begin(); } const_iterator end() const { return Records.end(); } bool empty() const { return Records.empty(); } size_type size() const { return Records.size(); } };
/// This function will attempt to load XRay trace records from the provided /// |Filename|. Expected<Trace> loadTraceFile(StringRef Filename, bool Sort = false);
/// This function will attempt to load XRay trace records from the provided /// DataExtractor. Expected<Trace> loadTrace(const DataExtractor &Extractor, bool Sort = false);
} // namespace xray } // namespace llvm
#endif // LLVM_XRAY_TRACE_H
|