Build tool
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

DepNode.cc 2.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. #include "DepNode.h"
  2. #include <mutex>
  3. #include <unordered_set>
  4. #include "parallel.h"
  5. #include "logger.h"
  6. static void maybeAddStrings(
  7. std::unordered_set<std::string> &set,
  8. const std::vector<std::string> &vec,
  9. std::vector<std::string> &out) {
  10. for (auto &str: vec) {
  11. auto pair = set.emplace(str);
  12. bool inserted = pair.second;
  13. if (inserted) {
  14. out.push_back(str);
  15. }
  16. }
  17. }
  18. void DepNode::addChild(std::shared_ptr<DepNode> node) {
  19. deps_.push_back(std::move(node));
  20. }
  21. bool DepNode::hasChanged(const std::string &outDir) {
  22. if (has_changed_ == TriState::TRUE) {
  23. return true;
  24. } else if (has_changed_ == TriState::FALSE) {
  25. return false;
  26. } else {
  27. for (auto &dep: deps_) {
  28. if (dep->hasChanged(outDir)) {
  29. has_changed_ = TriState::TRUE;
  30. return true;
  31. }
  32. }
  33. if (checkHasChanged(outDir)) {
  34. has_changed_ = TriState::TRUE;
  35. return true;
  36. }
  37. has_changed_ = TriState::FALSE;
  38. return false;
  39. }
  40. }
  41. void DepNode::startBuild(const std::string &outDir) {
  42. std::unique_lock<std::mutex> lock(mut_);
  43. if (build_complete_|| build_started_) {
  44. return;
  45. }
  46. if (!hasChanged(outDir)) {
  47. return;
  48. }
  49. build_started_ = true;
  50. lock.unlock();
  51. for (auto &dep: deps_) {
  52. dep->startBuild(outDir);
  53. }
  54. for (auto &dep: deps_) {
  55. dep->joinBuild();
  56. }
  57. parallel::run([&] {
  58. doBuild(outDir);
  59. std::unique_lock<std::mutex> lock(mut_);
  60. build_complete_ = true;
  61. build_cond_.notify_all();
  62. });
  63. }
  64. void DepNode::joinBuild() {
  65. std::unique_lock<std::mutex> lock(mut_);
  66. if (build_complete_ || !build_started_) {
  67. return;
  68. }
  69. build_cond_.wait(lock, [this] { return build_complete_; });
  70. }
  71. void DepNode::writeCompDB(const std::string &outDir, compdb::Writer &w) {
  72. std::unique_lock<std::mutex> lock(mut_);
  73. doWriteCompDB(outDir, w);
  74. lock.unlock();
  75. for (auto &dep: deps_) {
  76. dep->writeCompDB(outDir, w);
  77. }
  78. }
  79. std::vector<std::string> DepNode::publicLDFlags(const std::string &outDir) {
  80. std::unordered_set<std::string> set;
  81. std::vector<std::string> flags;
  82. maybeAddStrings(set, getPublicLDFlags(outDir), flags);
  83. for (auto &dep: deps_) {
  84. maybeAddStrings(set, dep->publicLDFlags(outDir), flags);
  85. }
  86. return flags;
  87. }
  88. std::vector<std::string> DepNode::publicLDLibs(const std::string &outDir) {
  89. std::unordered_set<std::string> set;
  90. std::vector<std::string> libs;
  91. maybeAddStrings(set, getPublicLDLibs(outDir), libs);
  92. for (auto &dep: deps_) {
  93. maybeAddStrings(set, dep->publicLDLibs(outDir), libs);
  94. }
  95. return libs;
  96. }
  97. std::vector<std::string> DepNode::publicObjects(const std::string &outDir) {
  98. std::vector<std::string> objs = getPublicObjects(outDir);;
  99. for (auto &dep: deps_) {
  100. for (auto &obj: dep->publicObjects(outDir)) {
  101. objs.push_back(obj);
  102. }
  103. }
  104. return objs;
  105. }