// Copyright 2019 Roman Perepelitsa. // // This file is part of GitStatus. // // GitStatus is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // GitStatus is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with GitStatus. If not, see . #ifndef ROMKATV_GITSTATUS_DIR_H_ #define ROMKATV_GITSTATUS_DIR_H_ #include #include #include "arena.h" namespace gitstatus { // On error, leaves entries unchanged and returns false. Does not throw. // // On success, appends names of files from the specified directory to entries and returns true. // Every appended entry is a null-terminated string. At -1 offset is its d_type. All elements // point into the arena. They are sorted either by strcmp or strcasecmp depending on case_sensitive. // // Does not close dir_fd. // // There are two distinct implementations of ListDir -- one for Linux and another for everything // else. The linux-specific implementation is 20% faster. // // The reason sorting is bundled with directory listing is performance on Linux. The API of // getdents64 allows for much faster sorting than what can be done with a plain vector. // For the POSIX implementation there is no need to bundle sorting in this way. In fact, it's // done at the end with a generic StrSort() call. // // For best results, reuse the arena and vector for multiple calls to avoid heap allocations. bool ListDir(int dir_fd, Arena& arena, std::vector& entries, bool precompose_unicode, bool case_sensitive); } // namespace gitstatus #endif // ROMKATV_GITSTATUS_DIR_H_