// file      : build/test/module.cxx -*- C++ -*-
// copyright : Copyright (c) 2014-2015 Code Synthesis Ltd
// license   : MIT; see accompanying LICENSE file

#include <build/test/module>

#include <build/scope>
#include <build/target>
#include <build/rule>
#include <build/diagnostics>

#include <build/test/operation>
#include <build/test/rule>

using namespace std;
using namespace butl;

namespace build
{
  namespace test
  {
    static rule rule_;

    extern "C" bool
    test_init (scope& r,
               scope& b,
               const location& l,
               unique_ptr<module>&,
               bool first,
               bool)
    {
      tracer trace ("test::init");

      if (&r != &b)
        fail (l) << "test module must be initialized in bootstrap.build";

      if (!first)
      {
        warn (l) << "multiple test module initializations";
        return true;
      }

      const dir_path& out_root (r.out_path ());
      level5 ([&]{trace << "for " << out_root;});

      // Register the test operation.
      //
      r.operations.insert (test_id, test);

      // Register rules.
      //
      {
        auto& rs (r.rules);

        // Register our test running rule.
        //
        rs.insert<target> (perform_id, test_id, "test", rule_);

        // Register our rule for the dist meta-operation. We need
        // to do this because we have "ad-hoc prerequisites", test
        // input/output files, that need to be entered into the
        // target list.
        //
        rs.insert<target> (dist_id, test_id, "test", rule_);
      }

      // Enter module variables.
      //
      {
        var_pool.find ("test", bool_type);
        var_pool.find ("test.input", name_type);
        var_pool.find ("test.output", name_type);
        var_pool.find ("test.roundtrip", name_type);
        var_pool.find ("test.options", strings_type);
        var_pool.find ("test.arguments", strings_type);
      }

      return true;
    }
  }
}