| /* |
| * Copyright (C) 2019 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_TABLES_MACROS_H_ |
| #define SRC_TRACE_PROCESSOR_TABLES_MACROS_H_ |
| |
| #include "src/trace_processor/tables/macros_internal.h" |
| |
| namespace perfetto { |
| namespace trace_processor { |
| |
| // Usage of the below macros |
| // These macros have two different invocation patterns depending on whether you |
| // are defining a root table or a derived table (see below for definitions and |
| // examples). If you're not sure which one you need, you probably want a derived |
| // table. |
| // |
| // Root tables |
| // Root tables act as the ultimate parent of a heirarcy of tables. All rows of |
| // child tables will be some subset of rows in the parent. Real world examples |
| // of root tables include EventTable and TrackTable. |
| // |
| // All root tables implicitly contain an 'id' column which contains the row |
| // index for each row in the table. |
| // |
| // Suppose we want to define EventTable with columns 'ts' and 'arg_set_id'. |
| // |
| // Then we would invoke the macro as follows: |
| // #define PERFETTO_TP_EVENT_TABLE_DEF(NAME, PARENT, C) |
| // NAME(EventTable, "event") |
| // PERFETTO_TP_ROOT_TABLE(PARENT, C) |
| // C(int64_t, ts, Column::kSorted) |
| // C(uint32_t, arg_set_id) |
| // PERFETTO_TP_TABLE(PERFETTO_TP_EVENT_TABLE_DEF); |
| // |
| // Note the call to PERFETTO_TP_ROOT_TABLE; this macro (defined below) should |
| // be called by root tables passing the PARENT and C and allows for correct type |
| // checking of root tables. |
| // |
| // Derived tables |
| // Suppose we want to derive a table called SliceTable which inherits all |
| // columns from EventTable (with EventTable's definition macro being |
| // PERFETTO_TP_EVENT_TABLE_DEF) and columns 'dur' and 'depth'. |
| // |
| // Then, we would invoke the macro as follows: |
| // #define PERFETTO_TP_SLICE_TABLE_DEF(NAME, PARENT, C) |
| // NAME(SliceTable, "slice") |
| // PARENT(PERFETTO_TP_EVENT_TABLE_DEF, C) |
| // C(int64_t, dur) |
| // C(uint8_t, depth) |
| // PERFETTO_TP_TABLE(PERFETTO_TP_SLICE_TABLE_DEF); |
| |
| // Macro definition using when defining a new root table. |
| // |
| // This macro should be called by passing PARENT and C in root tables; this |
| // allows for correct type-checking of columns. |
| // |
| // See the top of the file for how this should be used. |
| #define PERFETTO_TP_ROOT_TABLE(PARENT, C) \ |
| PARENT(PERFETTO_TP_ROOT_TABLE_PARENT_DEF, C) |
| |
| // The macro used to define storage backed tables. |
| // See the top of the file for how this should be used. |
| // |
| // This macro takes one argument: the full definition of the table; the |
| // definition is a function macro taking three arguments: |
| // 1. NAME, a function macro taking two argument: the name of the new class |
| // being defined and the name of the table when exposed to SQLite. |
| // 2. PARENT, a function macro taking two arguments: a) the definition of |
| // the parent table if this table |
| // is a root table b) C, the third parameter of the macro definition (see |
| // below). For root tables, PARENT and C are passsed to |
| // PERFETTO_TP_ROOT_TABLE instead of PARENT called directly. |
| // 3. C, a function macro taking two or three parameters: |
| // a) the type of a column |
| // b) the name of a column |
| // c) (optional) the flags of the column (see Column::Flag |
| // for details). |
| // This macro should be invoked as many times as there are columns in the |
| // table with the information about them. |
| #define PERFETTO_TP_TABLE(DEF) \ |
| PERFETTO_TP_TABLE_INTERNAL( \ |
| PERFETTO_TP_TABLE_NAME(DEF), PERFETTO_TP_TABLE_CLASS(DEF), \ |
| PERFETTO_TP_TABLE_CLASS(PERFETTO_TP_PARENT_DEF(DEF)), DEF) |
| |
| } // namespace trace_processor |
| } // namespace perfetto |
| |
| #endif // SRC_TRACE_PROCESSOR_TABLES_MACROS_H_ |