From 9fb791e9fad6c63fc1dac49f4d05ae63b8a3db9b Mon Sep 17 00:00:00 2001 From: Boris Kolpackov Date: Tue, 5 Jan 2016 11:55:15 +0200 Subject: Rename build directory/namespace to build2 --- build2/target.ixx | 85 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 85 insertions(+) create mode 100644 build2/target.ixx (limited to 'build2/target.ixx') diff --git a/build2/target.ixx b/build2/target.ixx new file mode 100644 index 0000000..25c33ba --- /dev/null +++ b/build2/target.ixx @@ -0,0 +1,85 @@ +// file : build2/target.ixx -*- C++ -*- +// copyright : Copyright (c) 2014-2015 Code Synthesis Ltd +// license : MIT; see accompanying LICENSE file + +namespace build2 +{ + // prerequisite_ref + // + inline bool prerequisite_ref:: + belongs (const target& t) const + { + const auto& p (t.prerequisites); + return !(p.empty () || this < &p.front () || this > &p.back ()); + } + + // prerequisite_member + // + inline prerequisite& prerequisite_member:: + as_prerequisite (tracer& trace) const + { + if (target == nullptr) + return prerequisite; + + // The use of the group's prerequisite scope is debatable. + // + scope& s (prerequisite.get ().scope); + return s.prerequisites.insert (nullptr, key ().tk, s, trace).first; + } + + // prerequisite_members + // + group_view + resolve_group_members (action, target&); // + + template + inline auto prerequisite_members_range::iterator:: + operator++ () -> iterator& + { + if (g_.count != 0) + { + if (++j_ <= g_.count) + return *this; + + // Switch back to prerequisite iteration mode. + // + g_.count = 0; + } + + ++i_; + + // Switch to member iteration mode. + // + if (r_->members_ && i_ != r_->e_ && i_->get ().type.see_through) + { + bool r (switch_members ()); + assert (r); // Group could not be resolved. + } + + return *this; + } + + template + inline bool prerequisite_members_range::iterator:: + switch_members () + { + do + { + g_ = resolve_group_members (r_->a_, search (*i_)); + + // If members are not know, iterate over the group as itself. + // + if (g_.members == nullptr) + { + g_.count = 0; + return false; + } + } + while (g_.count == 0 && // Skip empty groups. + ++i_ != r_->e_ && + i_->get ().type.see_through); + + j_ = 1; // Start from the first group member. + return true; + } +} -- cgit v1.1