// file : libbuild2/functions-process-path.cxx -*- C++ -*- // license : MIT; see accompanying LICENSE file #include <libbuild2/function.hxx> #include <libbuild2/variable.hxx> using namespace std; namespace build2 { void process_path_functions (function_map& m) { function_family f (m, "process_path"); // $recall(<process-path>) // // Return the recall path of an executable, that is, a path that is not // necessarily absolute but which nevertheless can be used to re-run the // executable in the current environment. This path, for example, could be // used in diagnostics when printing the failing command line. // // As discussed in value_traits<process_path>, we always have recall. // f["recall"] += &process_path::recall; // $effect(<process-path>) // // Return the effective path of an executable, that is, the absolute path // to the executable that will also include any omitted extensions, etc. // f["effect"] += [] (process_path p) { return move (p.effect.empty () ? p.recall : p.effect); }; // $name(<process-path-ex>) // // Return the stable process name for diagnostics. // f["name"] += &process_path_ex::name; // $checksum(<process-path-ex>) // // Return the executable checksum for change tracking. // f["checksum"] += &process_path_ex::checksum; // $env_checksum(<process-path-ex>) // // Return the environment checksum for change tracking. // f["env_checksum"] += &process_path_ex::env_checksum; } }