aboutsummaryrefslogtreecommitdiff
path: root/build2/target-key
blob: 1c8037c8a4df47b615b50dbc4980a7ebd8635cae (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
// file      : build2/target-key -*- C++ -*-
// copyright : Copyright (c) 2014-2016 Code Synthesis Ltd
// license   : MIT; see accompanying LICENSE file

#ifndef BUILD2_TARGET_KEY
#define BUILD2_TARGET_KEY

#include <map>
#include <string>
#include <ostream>
#include <functional>  // reference_wrapper

#include <butl/utility> // compare_c_string

#include <build2/types>
#include <build2/utility>

#include <build2/target-type>

namespace build2
{
  // Light-weight (by being shallow-pointing) target key.
  //
  class target_key
  {
  public:
    const target_type* const  type;
    const dir_path* const     dir;
    const std::string* const  name;
    const std::string* const& ext;

    friend bool
    operator< (const target_key& x, const target_key& y)
    {
      const target_type* xt (x.type);
      const target_type* yt (y.type);

      //@@ TODO: use compare() to compare once.

      // Unspecified and specified extension are assumed equal. The
      // extension strings are from the pool, so we can just compare
      // pointers.
      //
      return
        (xt < yt) ||
        (xt == yt && *x.name < *y.name) ||
        (xt == yt && *x.name == *y.name && *x.dir < *y.dir) ||
        (xt == yt && *x.name == *y.name && *x.dir == *y.dir &&
         x.ext != nullptr && y.ext != nullptr && *x.ext < *y.ext);
    }
  };

  // If the target type has a custom print function, call that. Otherwise,
  // call to_stream() with the current stream verbosity as a third argument.
  // Both are defined in target.cxx.
  //
  ostream&
  operator<< (ostream&, const target_key&);

  ostream&
  to_stream (ostream&, const target_key&, uint16_t ext_verb);
}

#endif // BUILD2_TARGET_KEY