blob: 74247f6024aa896d4e1ffbbc17b90a08ec98ebfe [file] [log] [blame]
/*
* 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_STORAGE_TABLE_H_
#define SRC_TRACE_PROCESSOR_STORAGE_TABLE_H_
#include <set>
#include "src/trace_processor/row_iterators.h"
#include "src/trace_processor/sqlite/sqlite_table.h"
#include "src/trace_processor/storage_columns.h"
#include "src/trace_processor/storage_schema.h"
namespace perfetto {
namespace trace_processor {
// Base class for all table implementations which are backed by some data
// storage.
class StorageTable : public SqliteTable {
public:
// A cursor which abstracts common patterns found in storage backed tables. It
// takes a strategy to iterate through rows and a column reporter for each
// column to implement the Cursor interface.
class Cursor final : public SqliteTable::Cursor {
public:
Cursor(StorageTable* table);
// Implementation of SqliteTable::Cursor.
int Filter(const QueryConstraints& qc, sqlite3_value** argv) override;
int Next() override;
int Eof() override;
int Column(sqlite3_context*, int N) override;
private:
std::unique_ptr<RowIterator> iterator_;
std::vector<std::unique_ptr<StorageColumn>>* columns_ = nullptr;
StorageTable* table_ = nullptr;
};
StorageTable();
virtual ~StorageTable() override;
// Table implementation.
util::Status Init(int,
const char* const*,
SqliteTable::Schema*) override final;
std::unique_ptr<SqliteTable::Cursor> CreateCursor() override;
// Required methods for subclasses to implement.
virtual StorageSchema CreateStorageSchema() = 0;
virtual uint32_t RowCount() = 0;
protected:
const StorageSchema& schema() const { return schema_; }
bool HasEqConstraint(const QueryConstraints&, const std::string& col_name);
private:
// Creates a row iterator which is optimized for a generic storage schema
// (i.e. it does not make assumptions about values of columns).
std::unique_ptr<RowIterator> CreateBestRowIterator(const QueryConstraints& qc,
sqlite3_value** argv);
FilteredRowIndex CreateRangeIterator(
const std::vector<QueryConstraints::Constraint>& cs,
sqlite3_value** argv);
std::pair<bool, bool> IsOrdered(
const std::vector<QueryConstraints::OrderBy>& obs);
std::vector<QueryConstraints::OrderBy> RemoveRedundantOrderBy(
const std::vector<QueryConstraints::Constraint>& cs,
const std::vector<QueryConstraints::OrderBy>& obs);
std::vector<uint32_t> CreateSortedIndexVector(
FilteredRowIndex index,
const std::vector<QueryConstraints::OrderBy>& obs);
StorageSchema schema_;
};
} // namespace trace_processor
} // namespace perfetto
#endif // SRC_TRACE_PROCESSOR_STORAGE_TABLE_H_