2020-04-16 09:18:19 +02:00
|
|
|
/*
|
|
|
|
|
* Copyright (C) 2017-2020 The Project X-Ray Authors.
|
|
|
|
|
*
|
|
|
|
|
* Use of this source code is governed by a ISC-style
|
|
|
|
|
* license that can be found in the LICENSE file or at
|
|
|
|
|
* https://opensource.org/licenses/ISC
|
|
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: ISC
|
|
|
|
|
*/
|
2017-11-21 01:38:34 +01:00
|
|
|
#include <prjxray/database.h>
|
|
|
|
|
|
|
|
|
|
#include <glob.h>
|
|
|
|
|
|
|
|
|
|
#include <memory>
|
|
|
|
|
|
|
|
|
|
#include <absl/strings/str_cat.h>
|
|
|
|
|
|
|
|
|
|
namespace prjxray {
|
|
|
|
|
|
|
|
|
|
static constexpr const char kSegbitsGlobPattern[] = "segbits_*.db";
|
|
|
|
|
|
2018-01-08 22:30:02 +01:00
|
|
|
std::vector<std::unique_ptr<prjxray::SegbitsFileReader>> Database::segbits()
|
|
|
|
|
const {
|
2017-11-21 01:38:34 +01:00
|
|
|
std::vector<std::unique_ptr<prjxray::SegbitsFileReader>> segbits;
|
|
|
|
|
|
|
|
|
|
glob_t segbits_glob_results;
|
|
|
|
|
int ret = glob(absl::StrCat(db_path_, "/", kSegbitsGlobPattern).c_str(),
|
2018-01-08 22:30:02 +01:00
|
|
|
GLOB_NOSORT | GLOB_TILDE, NULL, &segbits_glob_results);
|
2017-11-21 01:38:34 +01:00
|
|
|
if (ret < 0) {
|
|
|
|
|
return {};
|
|
|
|
|
}
|
|
|
|
|
|
2018-01-08 22:30:02 +01:00
|
|
|
for (size_t idx = 0; idx < segbits_glob_results.gl_pathc; idx++) {
|
2017-11-21 01:38:34 +01:00
|
|
|
auto this_segbit = SegbitsFileReader::InitWithFile(
|
2018-01-08 22:30:02 +01:00
|
|
|
segbits_glob_results.gl_pathv[idx]);
|
2017-11-21 01:38:34 +01:00
|
|
|
if (this_segbit) {
|
|
|
|
|
segbits.emplace_back(std::move(this_segbit));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
globfree(&segbits_glob_results);
|
|
|
|
|
|
|
|
|
|
return segbits;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} // namespace prjxray
|