Skip to content
Permalink

Comparing changes

Choose two branches to see what’s changed or to start a new pull request. If you need to, you can also or learn more about diff comparisons.

Open a pull request

Create a new pull request by comparing changes across two branches. If you need to, you can also . Learn more about diff comparisons here.
base repository: NixOS/nixpkgs
Failed to load repositories. Confirm that selected base ref is valid, then try again.
Loading
base: 0f01a77f8728
Choose a base ref
...
head repository: NixOS/nixpkgs
Failed to load repositories. Confirm that selected head ref is valid, then try again.
Loading
compare: 86bbfc0f4329
Choose a head ref
  • 1 commit
  • 1 file changed
  • 1 contributor

Commits on Jan 8, 2020

  1. lib/types: Fix path type check

    Previously when this function was called without a value coercible to a
    string it would throw an error instead of returning false. Now it does.
    
    As a result this now allows the use of a type like `either path attrs`
    without it erroring out when a definition is an attribute set.
    
    The warning about there not being a isPath primop was removed because
    this is not the case anymore, there is builtins.isPath. But also there
    always was `builtins.typeOf x == "path"` that could've been used
    instead. However the path type now stands for more than just path types,
    but absolute paths in general.
    
    (cherry picked from commit d7a109b)
    
    See #76861 (comment)
    for why this is cherry-picked
    infinisil committed Jan 8, 2020
    Copy the full SHA
    86bbfc0 View commit details
Showing with 1 addition and 2 deletions.
  1. +1 −2 lib/types.nix
3 changes: 1 addition & 2 deletions lib/types.nix
Original file line number Diff line number Diff line change
@@ -242,8 +242,7 @@ rec {

path = mkOptionType {
name = "path";
# Hacky: there is no ‘isPath’ primop.
check = x: builtins.substring 0 1 (toString x) == "/";
check = x: isCoercibleToString x && builtins.substring 0 1 (toString x) == "/";
merge = mergeEqualOption;
};