From b5bc5316fe9b9319514c202d0517146306976452 Mon Sep 17 00:00:00 2001 From: Mark Harris <783069+harrism@users.noreply.github.com> Date: Wed, 6 Mar 2024 17:01:39 +1100 Subject: [PATCH] Update `developer_guide.md` with new guidance on quoted internal includes (#15238) Follow up to #15063 to add new guidance for quoting includes of internal headers from `src` paths. Also covers clang-format include grouping. Also fixes a single include that was added with `<>` recently that should be `""`. #15063 updated all includes to match the guidance in this PR (changing a lot of `<>` to `""` for includes from `src/...`. Authors: - Mark Harris (https://github.com/harrism) Approvers: - David Wendt (https://github.com/davidwendt) - Vukasin Milovanovic (https://github.com/vuule) URL: https://github.com/rapidsai/cudf/pull/15238 --- cpp/doxygen/developer_guide/DEVELOPER_GUIDE.md | 17 +++++++++++------ cpp/src/io/parquet/error.hpp | 4 ++-- 2 files changed, 13 insertions(+), 8 deletions(-) diff --git a/cpp/doxygen/developer_guide/DEVELOPER_GUIDE.md b/cpp/doxygen/developer_guide/DEVELOPER_GUIDE.md index 5c137433dc5..935ca20b6fa 100644 --- a/cpp/doxygen/developer_guide/DEVELOPER_GUIDE.md +++ b/cpp/doxygen/developer_guide/DEVELOPER_GUIDE.md @@ -127,7 +127,7 @@ and we try to follow his rules: "No raw loops. No raw pointers. No raw synchroni does use raw synchronization primitives. So we should revisit Parent's third rule and improve here. -Additional style guidelines for libcudf code include: +Additional style guidelines for libcudf code: * Prefer "east const", placing `const` after the type. This is not automatically enforced by `clang-format` because the option @@ -152,15 +152,20 @@ The following guidelines apply to organizing `#include` lines. from other RAPIDS libraries, then includes from related libraries, like ``, then includes from dependencies installed with cuDF, and then standard headers (for example ``, ``). - * Use `<>` instead of `""` unless the header is in the same directory as the source file. + * We use clang-format for grouping and sorting headers automatically. See the + `cudf/cpp/.clang-format` file for specifics. + * Use `<>` for all includes except for internal headers that are not in the `include` + directory. In other words, if it is a cuDF internal header (e.g. in the `src` or `test` + directory), the path will not start with `cudf` (e.g. `#include `) so it + should use quotes. Example: `#include "io/utilities/hostdevice_vector.hpp"`. + * `cudf_test` and `nvtext` are separate libraries within the `libcudf` repo. As such, they have + public headers in `include` that should be included with `<>`. * Tools like `clangd` often auto-insert includes when they can, but they usually get the grouping - and brackets wrong. + and brackets wrong. Correct the usage of quotes or brackets and then run clang-format to correct + the grouping. * Always check that includes are only necessary for the file in which they are included. Try to avoid excessive including especially in header files. Double check this when you remove code. - * Use quotes `"` to include local headers from the same relative source directory. This should only - occur in source files and non-public header files. Otherwise use angle brackets `<>` around - included header filenames. * Avoid relative paths with `..` when possible. Paths with `..` are necessary when including (internal) headers from source paths not in the same directory as the including file, because source paths are not passed with `-I`. diff --git a/cpp/src/io/parquet/error.hpp b/cpp/src/io/parquet/error.hpp index 4e2eb4c66d3..f0fc9fab3ab 100644 --- a/cpp/src/io/parquet/error.hpp +++ b/cpp/src/io/parquet/error.hpp @@ -16,9 +16,9 @@ #pragma once -#include +#include "io/utilities/hostdevice_vector.hpp" -#include +#include #include #include