blob: c0ec406582d3e635729b3cdd491d3e40d8a06d59 [file] [log] [blame]
/*
* Copyright (C) 2018 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 SRC_TRACE_PROCESSOR_TRACE_PROCESSOR_H_
#define SRC_TRACE_PROCESSOR_TRACE_PROCESSOR_H_
#include <functional>
#include <memory>
#include "perfetto/base/weak_ptr.h"
#include "src/trace_processor/scoped_db.h"
#include "src/trace_processor/trace_processor_context.h"
namespace perfetto {
namespace base {
class TaskRunner;
}
namespace protos {
class RawQueryArgs;
class RawQueryResult;
} // namespace protos
namespace trace_processor {
class BlobReader;
// Coordinates the loading of traces from an arbitary source and allows
// execution of SQL queries on the events in these traces.
class TraceProcessor {
public:
explicit TraceProcessor(base::TaskRunner*);
~TraceProcessor();
// Loads a trace by reading from the given blob reader. Invokes |callback|
// when the trace has been fully read and parsed.
void LoadTrace(BlobReader*, std::function<void()> callback);
// Executes a SQLite query on the loaded portion of the trace. |result| will
// be invoked once after the result of the query is available.
void ExecuteQuery(const protos::RawQueryArgs&,
std::function<void(const protos::RawQueryResult&)>);
private:
void LoadTraceChunk(std::function<void()> callback);
ScopedDb db_; // Keep first.
TraceProcessorContext context_;
base::TaskRunner* const task_runner_;
base::WeakPtrFactory<TraceProcessor> weak_factory_; // Keep last.
};
} // namespace trace_processor
} // namespace perfetto
#endif // SRC_TRACE_PROCESSOR_TRACE_PROCESSOR_H_