// file      : libbuild2/functions-target-triplet.cxx -*- C++ -*-
// license   : MIT; see accompanying LICENSE file

#include <libbuild2/function.hxx>
#include <libbuild2/variable.hxx>

using namespace std;

namespace build2
{
  void
  target_triplet_functions (function_map& m)
  {
    function_family f (m, "target_triplet");

    // $string(<target-triplet>)
    //
    // Return the canonical (that is, without the `unknown` vendor component)
    // target triplet string.
    //

    // Note that we must handle NULL values (relied upon by the parser
    // to provide conversion semantics consistent with untyped values).
    //
    f["string"] += [](target_triplet* t)
    {
      return t != nullptr ? t->string () : string ();
    };

    // $representation(<target-triplet>)
    //
    // Return the complete target triplet string that always contains the
    // vendor component.
    //
    f["representation"] += [](target_triplet t)
    {
      return t.representation ();
    };

    // Target triplet-specific overloads from builtins.
    //
    function_family b (m, "builtin");

    // Note that while we should normally handle NULL values (relied upon by
    // the parser to provide concatenation semantics consistent with untyped
    // values), the result will unlikely be what the user expected. So for now
    // we keep it a bit tighter.
    //
    b[".concat"] += [](target_triplet l, string sr) {return l.string () + sr;};
    b[".concat"] += [](string sl, target_triplet r) {return sl + r.string ();};

    b[".concat"] += [](target_triplet l, names ur)
    {
      return l.string () + convert<string> (move (ur));
    };

    b[".concat"] += [](names ul, target_triplet r)
    {
      return convert<string> (move (ul)) + r.string ();
    };
  }
}