2017-05-21 17:39:23 +00:00
|
|
|
let inherit (import ../attrsets.nix) mapAttrs; in
|
|
|
|
|
2017-02-09 02:27:22 +00:00
|
|
|
rec {
|
|
|
|
doubles = import ./doubles.nix;
|
|
|
|
parse = import ./parse.nix;
|
2017-05-21 17:39:23 +00:00
|
|
|
inspect = import ./inspect.nix;
|
2017-02-09 02:27:22 +00:00
|
|
|
platforms = import ./platforms.nix;
|
2017-05-23 22:04:15 +00:00
|
|
|
examples = import ./examples.nix;
|
2017-03-24 00:49:28 +00:00
|
|
|
|
|
|
|
# Elaborate a `localSystem` or `crossSystem` so that it contains everything
|
|
|
|
# necessary.
|
|
|
|
#
|
|
|
|
# `parsed` is inferred from args, both because there are two options with one
|
|
|
|
# clearly prefered, and to prevent cycles. A simpler fixed point where the RHS
|
|
|
|
# always just used `final.*` would fail on both counts.
|
|
|
|
elaborate = args: let
|
|
|
|
final = {
|
|
|
|
# Prefer to parse `config` as it is strictly more informative.
|
|
|
|
parsed = parse.mkSystemFromString (if args ? config then args.config else args.system);
|
|
|
|
# Either of these can be losslessly-extracted from `parsed` iff parsing succeeds.
|
|
|
|
system = parse.doubleFromSystem final.parsed;
|
|
|
|
config = parse.tripleFromSystem final.parsed;
|
|
|
|
# Just a guess, based on `system`
|
|
|
|
platform = platforms.selectBySystem final.system;
|
2017-05-21 18:02:19 +00:00
|
|
|
libc =
|
|
|
|
/**/ if final.isDarwin then "libSystem"
|
|
|
|
else if final.isMinGW then "msvcrt"
|
|
|
|
else if final.isLinux then "glibc"
|
|
|
|
# TODO(@Ericson2314) think more about other operating systems
|
|
|
|
else "native/impure";
|
2017-05-21 17:39:23 +00:00
|
|
|
} // mapAttrs (n: v: v final.parsed) inspect.predicates
|
|
|
|
// args;
|
2017-03-24 00:49:28 +00:00
|
|
|
in final;
|
2017-02-09 02:27:22 +00:00
|
|
|
}
|