Skip to content

Latest commit

 

History

History
1362 lines (1259 loc) · 72.2 KB

CHANGELOG.md

File metadata and controls

1362 lines (1259 loc) · 72.2 KB

1.26.1

1.26.0

1.25.0

  • Supports version 9.0.0 of the standard
  • BREAKING CHANGE: Remove support for old-style List-like Optional literals
    • List-like Optional Literals (i.e. [ 1 ] : Optional Natural) are no longer valid
    • See: dhall-lang#1002
  • BREAKING CHANGE: Add support for semi-semantic caching
    • This change significantly improves the performance of imports
    • This change also automatically caches imports without an integrity check
    • This changes several types in Dhall.Import to support this new feature
    • See: dhall-lang#1113
  • BREAKING CHANGE: Implement new Unicode braced escape sequence
    • Escape sequences encoding surrogate pairs are no longer valid
    • Instead, characters previously encoded as surrogate pairs can instead be encoded as a braced sequence
    • For example: "\uD834\uDD1E" must now be written as "\u{1D11E}"
    • See: dhall-lang#987
    • See: dhall-lang#1104
  • BREAKING CHANGE: Make the type of extract richer:
    • Dhall.extract can now return a detailed error instead of just a Maybe
    • This is a breaking chnage because the type of extract changed
    • See: dhall-lang#1011
  • BREAKING CHANGE: Add support for importing expressions as Location
    • This is a breaking change because a new Location constructor was added to ImportMode
    • See: dhall-lang#1019
  • BREAKING CHANGE: Switch Var to use an Int
    • This is a performance improvement, but also a breaking change since the Integer in the Var constructor was changed to an Int
    • See: dhall-lang#1044
  • BREAKING CHANGE: Add new toMap keyword
    • This is a breaking change to the API because a new ToMap constructor was added to the Expr type
    • This is also a technically breaking change to the language because toMap is now a reserved keyword, although most code should be unaffected in practice
    • See: dhall-lang#1041
  • BREAKING CHANGE: Sort the fields of a record projection during normalization
    • This is a technically breaking change to the language because any expressions with an uninterpreted record projection will have a different semantic integrity check. However, most could should be unaffected in practice
    • See: dhall-lang#1111
  • BUG FIX: Fix substitution into record projection by type
    • An expression like this one was being incorrectly rejected: let e = { a = 10, b = "Text" } let s = { a : Natural } in e.(s), which this change fixes
    • See: dhall-lang#1012
  • BUG FIX: Reject record projection when there is a field type mismatch
    • Record projection by type was previously not checking the expected field types, which this change fixes
    • See: dhall-lang#1027
  • BUG FIX: Fix linting of unused let bindings
    • Certain let bindings were not correctly detected as unused, which this change fixes
    • See: dhall-lang#1001
  • BUG FIX: Fix --file option
    • The --file option from the previous release did not work, due to not computing relative paths correctly, which this change fixes
    • See: dhall-lang#1004
  • BUG FIX: Minor fix to dhall diff
    • dhall diff was incorrectly displaying spurious differences for identical lists that were function arguments, which this change fixes
    • See: dhall-lang#1006
  • BUG FIX: Allow Sort as type annotation
    • This should have been implemented in the previous release as part of supporting version 8.0.0 of the standard, but was missed
    • See: dhall-lang#1024
  • BUG FIX: Dhall.Map: Reflect original key ordering in Ord instance
    • Dhall.Map now considers key order when comparing Maps, which it should have done before, but didn't
    • See: dhall-lang#1050
  • BUG FIX: Consistently format multi-line strings
    • The formatter now formats naked multi-line strings the same as nested multi-line strings
    • Specifically, naked multi-line strings can now be formatted on a single (just like nested multi-line strings)
    • See: dhall-lang#1056
  • BUG FIX: Make isNormalized consistent with normalize
  • BUG FIX: Make normalizeWithM consistent with normalize
  • BUG FIX: Fix import alternatives to recover from type errors
  • Feature: Semi-semantic caching
    • The Haskell implementation now implicitly caches all local imports, not just imports frozen by integrity checks, so that you don't have to freeze them when doing local development
    • These cached imports are still correctly invalidated if they or any of their dependencies change
    • This new implicit cache is stored underneath ~/.cache/dhall-haskell by default
    • See: dhall-lang#1154
  • Feature: New dhall text subcommand
    • This new subcommand supersedes the old dhall-to-text executable
  • Feature: Add instance Lift (Expr s a)
  • Fixes and improvements to error messages:
  • Fixes and improvements to tests:
  • Performance improvements

1.24.0

  • Supports version 8.0.0 of the standard
  • BREAKING CHANGE: Allow tabs and blank lines in multi-line strings
    • Blank lines are now ignored for the purpose of dedenting multiline strings
    • Lines with leading tabs (or mixed tabs and spaces) are now dedented, too, so long as they all share the same prefix
    • This is technically a breaking change, but unlikely to affect programs in practice, especially if they were formatted with dhall format. This change mainly affects programs that were not indented correctly.
    • See the changelog for standard version 8.0.0 for more details
  • BREAKING CHANGE: Simplify bare interpolations
    • Expressions like λ(x : Text) → "${x}" now simplify to λ(x : Text) → x
    • This is a technically breaking change because it changes how these sorts of expressions are serialized. This does not affect semantic integrity checks and the new simplified expressions are extensionally equivalent to their older counterpart expressions.
    • See the changelog for standard version 8.0.0 for more details
  • BREAKING CHANGE: Encode integrity check as multihash
    • Semantic integrity checks are now encoded using the multihash spec
    • This is a technically breaking change that does not perturb the hash for user-facing semantic integrity checks. This only affects how expressions with unresolved imports are serialized, but semantic integrity checks are only computed for fully-resolved imports.
    • See the changelog for standard version 8.0.0 for more details
  • BUG FIX: Fix type-checker to reject invalid record type annotations
    • e.g. { x = 1 } : { x : Text } was not properly rejected by the type checker
    • See: dhall-lang#965
  • BUG FIX: Custom header forwarding fixed
    • Forwarding custom headers could previously fail in various ways, such as:
      • Cyclic imports leading to endless network requests
      • Resolving a non-existent import for the custom headers
      • Resolving an existing but incorrect import for the custom headers
    • This change fixes that by forwarding custom headers by value instead of by reference
    • See: dhall-lang#967
  • BUG FIX: Fix GHCJS support
    • Natural/fold was broken in version 1.22, which this change fixes
    • Specifically, it would hang for Natural numbers greater than 1
    • See: dhall-lang#985
  • BUG FIX: dhall diff no longer double-prints key-value separators
  • Feature: Record projection by expression
    • You can now project out a subset of record fields by the expected type
    • let t = { x : Natural } let p = { x = 1, y = 2 } in p.(t) = { x = 1 }
    • See the changelog for standard version 8.0.0 for more details
  • Feature: Inline headers
    • You no longer need to specify custom headers in a separate import. You can now specify them inline within the same file.
    • e.g.: https://example.com/x using [ { header = "Foo", value = "Bar" } ]
    • See the changelog for standard version 8.0.0 for more details
  • Feature: Allow Sort as a type annotation
    • An expression such as Kind → Kind : Sort will now type-check
    • Sort is still disallowed outside of a type annotation
    • See the changelog for standard version 8.0.0 for more details
  • Feature: Allow self-describe-cbor when decoding
    • Dhall expressions serialized as CBOR can be tagged to describe themselves as CBOR without affecting decoding
    • See the changelog for standard version 8.0.0 for more details
  • Feature: New --file option for dhall commands
    • In other words, instead of dhall <<< './some/file you can now use dhall --file some/file
    • See: dhall-lang#949
  • Feature: New --cache flag for dhall freeze command
    • This automates the idiom used by the Prelude to optimistically cache imports but gracefully degrade if the semantic integrity check fails
    • See: dhall-lang#980
  • Feature: Add :clear command to dhall repl
    • This deletes previous bindings from the history so that they can be garbage collected
    • See: dhall-lang#966
  • Feature: New chunkExprs Traversal added to Dhall.Core
  • Feature: New Dhall.Optics module
    • This re-exports some convenient @lens@ utilities used internally for packages trying to avoid a @lens@ dependency
    • See: dhall-lang#986
  • More GHC 8.8 support

1.23.0

  • BREAKING CHANGE: Fix marshaling union literals
    • 1.22.0 introduced two separate bugs in marshaling union literals between Dhall and Haskell, which this release fixes:
      • Dhall enums did not correctly map onto Haskell enums
      • New-style union literals (i.e. < A : T >.A x) were not correctly supported
    • See: dhall-lang#918
    • See: dhall-lang#927
    • See: dhall-lang#936
  • BUG FIX: Fix α-normalization
    • Version 1.22.0 introduced a new faster evaluation algorithm, but the new algorithm introduced two α-normalization regression, which this release fixes
    • The primary effect of this bug was that semantic integrity checks would fail for expressions that contain an if/then/else` expression in their normal form
    • See: dhall-lang#931
    • See: dhall-lang#938
  • BUG FIX: Fix merging of sort-level record types
    • The language standard requires that { a : Kind } ⩓ { b : Kind } is valid, which this change fixes
    • See: dhall-lang#891
  • BUG FIX: dhall freeze respects the --ascii flag
  • BUG FIX: Don't autocomplete fields for record types
    • This prevents the REPL from expanding { x : T }.<TAB> to { x : T }.x
    • See: dhall-lang#937
  • Support MonadFail-related changes in GHC 8.8
  • Add cross flag to simplify cross-compilation
    • This allows the dhall package to be built without using TemplateHaskell
    • See: dhall-lang#928
  • Increase lines of context for error messages
    • Error messages now provide at least 20 lines of context instead of 3 before truncating large expressions
    • See: dhall-lang#916
  • Add line numbers to error messages
    • The bottom of every Dhall type error includes the original source code, which now has line numbers on the left margin
    • See: dhall-lang#919
  • Expand lower bounds on megaparsec/transformers-compat dependencies

1.22.0

  • Supports version 7.0.0 of the standard
  • BREAKING CHANGE: Add support for empty alternatives
    • The Union type now has an optional (Maybe) type for each alternative
    • See the changelog for standard version 7.0.0 for more details
    • See: dhall-lang#863
  • BREAKING CHANGE: Remove support for URL fragments
    • The URL type no longer has a field for a URL fragment since the language no longer supports fragments
    • See the changelog for standard version 7.0.0 for more details
    • See: dhall-lang#851
  • BREAKING CHANGE: Remove deprecated Path type synonym
  • BUG FIX: Correctly parse identifiers beginning with http
    • i.e. httpPort was supposed to be a valid identifier name and now is
    • See: dhall-lang#870
  • BUG FIX: Fix dhall encode bug
    • dhall encode bug was generating binary expressions that were valid (i.e. they would decode correctly) but were non-standard (i.e. hashing them would not match the hash you would normally get from a semantic integrity check)
    • Semantic integrity checks were not affected by this bug since they used a slightly different code path that generated the correct binary input to the hash. Only the dhall decode subcommand was affected
    • See: dhall-lang#859
  • BUG FIX: Fix for Dhall.UnionType
    • This fixes some expressions that would previously fail to marshal into Haskell, specifically those were the marshalling logic was built using the UnionType utilities
    • See: dhall-lang#857
  • Feature: New --alpha flag to α-normalize command-line output
  • Performance improvements

1.21.0

  • Supports version 6.0.0 of the language standard
  • BREAKING CHANGE: Remove the constructors keyword
  • BREAKING CHANGE: CBOR-encode only special Doubles as half-floats
    • ... as standardized in version 6.0.0 of the language standard
    • CBOR Doubles except Infinity/-Infinity/NaN/0.0 are now encoded in at least 32 bits
    • See: dhall-lang#822
  • BREAKING CHANGE: Sort record and union fields when CBOR-encoding
    • Fields and alternatives are now sorted when serialized
    • This does not affect semantic integrity checks, which already sorted these fields/alternatives before hashing expressions
    • This does affect the serialization of expressions that have not been normalized (e.g. uninterpreted expressions transmitted over the wire)
    • See: dhall-lang#835
  • BUG FIX: Fix non-exhaustive pattern match in dhall lint
    • This fixes: Irrefutable pattern failed for pattern Let (l' :| ls') d'
    • This bug would cause dhall lint to fail on some nested let/in expressions
    • See: dhall-lang#780
    • See: dhall-lang#784
  • BUG FIX: Don't fail if $HOME environment variable is unset
    • The interpreter was incorrectly throwing an exception if HOME was unset
    • The standard requires that implementations should handle the HOME environment variable being missing
    • See: dhall-lang#789
  • Feature: Remove version tag from semantic integrity check
    • ... as standardized in version 6.0.0 of the language standard
    • This is not a breaking change because this change also includes backwards-compatible support for semantic integrity checks produced by older versions of the interpreter
  • Feature: Support Unicode path components
    • ... as standardized in version 6.0.0 of the language standard
    • You can now use Unicode in path components if they are quoted
    • i.e. ./families/"禺.dhall" is now legal
  • Feature: Add Text/show built-in
    • ... as standardized in version 6.0.0 of the language standard
    • You can now convert a Text literal to its equivalent Dhall source code (which is itself a Text literal)
    • This comes in handy when using Dhall code to generate JSON or Dhall code
    • See: dhall-lang#811
  • Feature: Add --immediate-dependencies/--transitive-dependencies flags for dhall resolve
    • You can now retrieve all of your immediate or transitive dependencies as a textual list
    • This simplifies integration with other command-line tools (such as file watchers)
    • See: dhall-lang#795
    • See: dhall-lang#803
  • Feature: dhall freeze now only freezes remote imports by default
    • dhall freeze used to freeze all imports (including local imports and environment variables)
    • Now dhall freeze only freezes remote imports by default, which is what most users want
    • You can install freeze all imports using the --all flag
    • See: dhall-lang#808
  • Feature: :save and :load REPL state
    • :save with no arguments now saves the REPL state to a .dhall-repl-N file
    • The file format is a list of dhall repl commands
    • You can use :load to load the saved state back into the REPL
    • See: dhall-lang#807
  • Feature: Add :hash command to dhall repl
    • This lets you conveniently hash expressions within the dhall repl
    • See: dhall-lang#806
  • Feature: Add --check flag to dhall format
    • Use this to check if the input is already formatted
    • Useful for continuous integration when you want to ensure that all code under version control remains formatted
    • See: dhall-lang#810
  • Feature: Add UnionInputType builder for InputTypes
    • This is the union analog of RecordInputType, letting you build a record explicitly instead of deriving the instance using GHC generics
    • See: dhall-lang#775
  • Feature: Add :set/:unset commands to dhall repl
    • You can use these commands to set or unset command-line options
    • Currently only setting/unsetting --explain is supported
  • Standards-compliance fixes:
  • Documentation fixes:
  • Test fixes:
  • Improved error messages:
  • Formatting fixes:
  • REPL fixes:

1.20.1

  • BUG FIX: Fix binary encoding to use correct standard version
    • This fixes computed hashes to correctly match standard version 5.0.0
    • This is not marked as a breaking change since it is a bug fix. The 1.20.0 release will be blacklisted on Hackage and users should upgrade from 1.19.* directly to 1.20.1
    • See: dhall-lang#771

1.20.0

  • Supports version 5.0.0 of the language standard
  • BREAKING CHANGE TO THE LANGUAGE: Implement standardized support for multi-line literals
    • This updates the multi-line support to match the standard
    • This is a breaking change because empty lines within the multi-line literal now require leading whitespace whereas previously they did not
    • This is also a breaking change because now a newline is required after the opening '' quotes whereas previously it was not required
    • If you use dhall format then your multi-line literals already have the necessary leading whitespace
  • BREAKING CHANGE TO THE LANGUAGE: constructors x = x
    • Now the constructors keyword behaves like an identity function, since constructors can already be accessed as fields off the original union type.
    • This is a breaking change since any record of terms that contains a constructors field will now be a forbidden mixed record of types and terms.
    • This is also a breaking change if you annotated the type of what used to be a constructors record.
    • dhall lint will now remove the obsolete constructors keyword for you
    • See: dhall-lang#693
    • See: dhall-lang#701
  • BREAKING CHANGE TO THE API: Restore Parent constructor for Local type
    • This more closely matches the standard and also enables dhall format to produce a leading ../ for imports instead of ./../
    • See: dhall-lang#718
  • BUG FIX: Fix type-checking bug for unions
    • The first fix was that the inferred type was wrong for unions where alternatives were types or kinds
    • The second fix was that unions that mixed terms/types/kinds were not properly rejected
    • See: dhall-lang#763
  • BUG FIX: Change how dhall repl handles prior definitions
    • This changes the REPL to handle previous bindings as if they were defined using a large let expression instead of adding them to the context
    • This fixes some type-checking false negatives
    • See: dhall-lang#729
  • Feature: Autocomplete for dhall repl
    • You can now auto-complete record fields, union constructors, and identifiers that are in scope
    • See: dhall-lang#727
  • Feature: GHCJS support
    • dhall can now be built using GHCJS, although some features are still not supported for GHCJS, such as:
      • Semantic integrity checks
      • Custom HTTP headers
    • Also, HTTP imports only work for URLs that support CORS
    • See: dhall-lang#739
  • Feature: Add support for records of records of types
  • Feature: Add :quit command for dhall repl
  • Feature: Add --json flag for dhall {encode,decode}
    • You can now produce/consume CBOR expressions via JSON instead of binary
    • See: dhall-lang#717
  • Feature: Add decoding logic for as Text
    • You can now preserve the as Text qualifier on imports when serializing them
    • See: dhall-lang#712
  • Prenormalize substituted expressions
    • This is a performance improvement that reduces the time and memory consumption when normalizing expressions
    • See: dhall-lang#765

1.19.1

  • BUG FIX: Fix serious dhall lint bug
    • dhall lint would sometimes remove let expressions that were still in use
    • See: dhall-lang#703
  • BUG FIX: Fix import caching efficiency bug
    • Some imports were being wastefully fetched multiple times
    • See: dhall-lang#702
  • Feature: Generate dot graph to visualize import graph
  • Improve HTTP error messages

1.19.0

  • Supports version 4.0.0 of the language standard
  • BREAKING CHANGE TO THE LANGUAGE AND API: Prevent Hurkens' paradox
    • This fixes a type-checking soundness bug which permitted infinite loops
    • This is a breaking change because infinite loops are no longer possible
    • This is also a breaking change because a record of types is now treated as a kind instead of a type
    • See: dhall-lang#680
  • BREAKING CHANGE TO THE LANGUAGE AND API: Doubles are now double-precision floating point numbers
    • This restricts the range of Doubles to IEEE 754 double-precision floating point
    • This also implies that you can no longer convert Scientific values to Dhall expressions (i.e. no Inject instance for Scientific)
    • See: dhall-lang#667
  • BREAKING CHANGE TO THE API: Preserve field order for record projection
    • The API uses a new Dhall.Set.Set type instead of Data.Set.Set
    • See: dhall-lang#670
  • BREAKING CHANGE TO THE API: Add support for multi-let expressions
    • This changes the Let constructor to now support storing multiple bindings per let expression
    • See: dhall-lang#675
  • Access constructors as if they were fields of the union type
    • In other words: < Left : Bool | Right : Natural >.Left
    • See: dhall-lang#657
  • Support GHC 8.6
  • Add support for quoted path components
    • i.e. /"foo"/bar/"baz qux" or https://example.com/foo/"bar?baz"?qux
    • See: dhall-lang#690
  • Fix parsing of //\\ operator
  • Preserve Unicode characters when formatting code
  • Allow identifier names to begin with Some
  • Add subExpressions Traversal
  • Add normalizeWithM for monadic normalization
  • Custom normalizers now take precedence over default normalization logic
    • This allows one to override the implementation of built-in operators
    • See: dhall-lang#684

1.18.0

  • Supports version 3.0.0 of the language standard:
  • BREAKING CHANGE TO THE LANGUAGE AND API: New Some/None constructors for Optional values
    • Example: [ Some 1, None Natural ]
    • This is a breaking change to the language because Some and None are now reserved keywords
    • This is a breaking change to the API because Some and None are new constructors for the Expr type
  • BREAKING CHANGE TO THE LANGUAGE AND API: Support for kind polymorphism
    • This adds a new Sort constant above Kind in the hierarchy
    • i.e. Type : Kind : Sort
    • This is a breaking change to the language because Sort is now a reserved keyword
    • This is a breaking change to the API because Sort is a new constructor for the Expr type
  • BREAKING CHANGE TO THE API: New Dhall.Map module
    • This replaces InsOrdHashMap in the API
    • The primary motivation is to improve performance and to remove the dependency on insert-ordered-containers
  • BREAKING CHANGE TO THE API: Use standard version instead of protocol version
    • The binary protocol is now versioned alongside the standard
    • The ProtocolVersion type is renamed to StandardVersion and the
    • --protocol-version option is renamed to --standard-version
    • See: dhall-lang#634
  • BUG FIX: Fix import chaining for custom header imports
  • BUG FIX: Fix import chaining for imports protected by semantic integrity checks
  • BUG FIX: Record literals and types produced by // are now sorted
    • This ensures that β-normalization is idempotent
    • See: dhall-lang#572
  • BUG FIX: dhall freeze now correctly handles the starting file being located outside the current working directory
  • BUG FIX: Fix parsing of IPv4-mapped IPv6 addresses
  • FEATURE: New --ascii flag for ASCII output
  • FEATURE: New dhall encode and dhall decode subcommands
    • These allow you to transform Dhall source code to and from its binary representation
    • See: dhall-lang#588
  • LARGE parsing performance improvements
  • Type-checking performance improvements:
  • Normalization performance improvements:
  • dhall freeze now caches the imports as it freezes them
  • dhall freeze now refreezes imports with invalid semantic integrity checks
  • dhall freeze now adds a trailing newline
  • Build against megaparsec-7.0.*
  • Support GHC 8.6
  • Support GHC all the way back to 7.10.3
  • Improvements to error messages:

1.17.0

  • This release corresponds to version 2.0.0 of the language standard
  • BREAKING CHANGE TO THE LANGUAGE AND API: Binary serialization support
    • This is a breaking change to the hash for all semantic integrity checks
    • The hash used by the semantic integrity check is now based on the binary representation instead of a text representation of the expression
    • You can pin the new hashes by supplying the --protocol-version 1.0 option on the command line until you need support for newer language features
    • This also includes a breaking change to ImportType in the API
  • BREAKING CHANGE TO THE LANGUAGE: Disallow combining records of terms and types
    • This is mainly for consistency and to improve type errors that would have otherwise happened further downstream
    • This should not affect the vast majority of code
    • See: dhall-lang#538
  • BUG FIX: Semantic integrity checks now work for imported expression using the constructors keyword
  • BUG FIX: Fix α-normalization of expressions with bound variables named _
  • BUG FIX: Fix isNormalized to match normalize
  • BUG FIX: dhall lint now correctly handles nested let expressions
  • FEATURE: Imports protected by a semantic integrity check are now cached
  • The default dhall command no longer outputs the type to stderr
    • You can add back the type as a type annotation using the --annotate switch
    • See: dhall-lang#544
  • New utilities for building InputTypes
  • Improve parsing performance for long variable names
  • More succinct type diffs for function types
  • Identifier names can now begin with keywords
    • i.e. ifChanged and lettuce are now legal identifiers
    • See: dhall-lang#551

1.16.1

  • Fix test failure due to missing test data file

1.16.0

  • BREAKING CHANGE: Consolidate input family of functions
    • These now take a record of options
    • This also _stack field of the Status type from [Import] to NonEmpty Import
  • Permit $ in quoted variable names

1.15.1

  • Fix infinite loop when formatting expressions containing ?

1.15.0

  • BREAKING CHANGE TO THE API: Support alternative imports using new ? operator
    • This adds a new constructor which affects exhaustive pattern matches
    • See: dhall-lang#473
  • BREAKING CHANGE TO THE API: Add Integer/toDouble built-in function
    • This adds a new constructor which affects exhaustive pattern matches
    • See: dhall-lang#434
  • BREAKING CHANGE TO THE API: Use strict Text instead of lazy Text
  • BREAKING CHANGE TO THE API: Remove Buildable in favor of Pretty
  • BREAKING CHANGE TO THE API: Removed the Parent constructor from FilePrefix
  • BUG FIX: Disallow duplicate fields in records
  • BUG FIX: Fix stripping of leading whitespace in multi-line strings
  • BUG FIX: Fix formatting field access of an import
  • Add dhall freeze command
  • Add dhall diff command
  • Add dhall lint command
  • Change dhall-repl/dhall-hash/dhall-format to dhall subcommands
  • Add with-http cabal flag to disable support for remote imports
  • Added inputFrom and inputFromWith
    • These allow naming the file that the expression is coming from for better error messages
    • See: dhall-lang#464
  • Performance improvements
  • Tutorial recommends GitHub for Prelude instead of IPFS
  • Pretty-print expressions in type errors
  • Formatting improvements
  • Diff improvements

1.14.0

  • BREAKING CHANGE TO THE LANGUAGE: Switch grammar of Natural and Integer
    • Natural number literals are now unsigned and Integer literals always require a sign
    • This is a VERY disruptive change to most Dhall code in the wild but was unanimously agreed upon here: dhall-lang/dhall-lang#138
    • See also: dhall-lang#381
  • BREAKING CHANGE TO THE LANGUAGE: Drop support for importing directories
    • Importing dir/ used to resolve to dir/@, which is no longer supported
    • See: dhall-lang#384
  • BREAKING CHANGE TO THE LANGUAGE: Change to the grammar for imports
    • File path components can no longer contain # or ? characters
    • URL imports must now contain at least one path component
    • URL path components must match the grammar for file path components
    • See: dhall-lang#390
  • BREAKING CHANGE TO THE API: Rename Path{,Mode,Hashed,Type} to Import{,Mode,Hashed,Type}
    • In practice this change is not breaking for the most common use cases since this also provides a Path type synonym for backwards compatibility
    • See: dhall-lang#376
  • BUG FIX: Fix α-equivalence bug when type-checking merge
    • merge expressions would sometimes reject valid code due to a type-checking bug
    • See: dhall-lang#394
  • Improve import caching
  • Increase upper bound on tasty
  • Fix lower bound on insert-ordered-containers

1.13.1

  • Increase upper bound on ansi-terminal and megaparsec

1.13.0

  • BUG FIX: Fix semantic integrity hashing support
    • Both parsing and pretty-printing semantic hashes were broken since version 1.11.0
    • See: dhall-lang#345
  • BUG FIX: Allow leading whitespace in interpolated expresssions
  • BUG FIX: Fix deriving (Interpret) for sum types
    • The types of alternatives were not correctly included in the corresponding Dhall type
    • See: dhall-lang#348
  • BREAKING CHANGE TO LANGUAGE: Records cannot store both types and terms
    • Records can also not store type-level functions (like List)
      • Records might be allowed to store type-level functions again in the future
    • This fixes a potential soundness bug
    • The primarily practical consequence of this change is that if you are hosting a "package" then you will need to split terms and types from your package into different records for your users to import
    • This also implies removing the ./Monoid type-level function from the ./Prelude/package.dhall record
    • See: dhall-lang#335
  • BREAKING CHANGE TO THE API: Replace trifecta with megaparsec
    • This change the API to use the Parser type from megaparsec
    • This also slightly changes the type of exprFromText
    • If you program using the type classes provided by the parsers library then this is not a breaking change as that interface is preserved
    • See: dhall-lang#268
  • BREAKING CHANGE TO THE API: New operator for merging record types
    • Example: { foo : Text } ⩓ { bar : Bool } = { foo : Text, bar : Bool }
    • This is breaking because it adds a new constructor to the Expr type
    • See: dhall-lang#342
  • BREAKING CHANGE TO THE API: New support for projecting a subset of fields
    • Example: { x = 1, y = 2, z = 3 }.{ x, y } = { x = 1, y = 2 }
    • This is breaking because it adds a new constructor to the Expr type
    • See: dhall-lang#350
  • API+UX feature: New support for pretty-printing diffs of Dhall expressions
    • Error messages also use this feature to simplify large type mismatches
    • There is also a new Dhall.Diff module
    • See: dhall-lang#336
  • Add version, resolve, type, and normalize sub-commands to interpreter
  • Support GHC 7.10.3
  • :type command in dhall-repl now only displays the type
    • Before it would also display the original expression
    • See: dhall-lang#344
  • Trim dependency tree

1.12.0

  • Additional changes to support GHC 8.4
  • BREAKING CHANGE TO API: Replace dependency on text-format with formatting
    • This replace the Data.Text.Buildable.Buildable instances with Formatting.Buildable.Buildable instances, which is why this is a breaking change
    • text-format is no longer maintained and blocking GHC 8.4 support
    • See: dhall-lang#330

1.11.1

  • Support GHC 8.4
  • Fix α-normalization bug
    • Note that this is not a type-checking bug. This only affects users who were directly using the alphaNormalize function from the Haskell API because let expressions were not correctly α-normalized
    • See: dhall-lang#319
  • Slight tweak to syntax highlighting
  • Increase upper bound on ansi-terminal and exceptions

1.11.0

  • BREAKING CHANGE TO THE API: Fix {Natural,Optional,List}/build semantics to match standard
    • This is a breaking change because the OptionalLit and ListLit constructors changed their representations to efficiently support the standard semantics
    • ListLit now stores a Data.Sequence.Seq instead of a Data.Vector.Vector
    • OptionalLit now stores a Maybe instead of a Data.Vector.Vector
    • See: dhall-lang#300
  • BREAKING CHANGE TO THE COMMAND LINE: dhall executable always formats output
    • Previously you had to opt into formatting using --pretty
    • Now formatting is obligatory and the --pretty flag is gone
    • See: dhall-lang#303
  • Feature: New :save command for dhall-repl
    • Now you can save an expression to a file: ./yourFile = someExpression
    • See: dhall-lang#309
  • Improvement: Add new simplifications to match standard
  • Improvement: Fix equivalence check to match standard
    • Practically this means that more corner cases of the language correctly type-check than before
  • Improvement: New --plain flag to disable syntax highlighting
  • Improvement: Prelude now provides an umbrella package.dhall import
  • Improvement: Context is now normalized
  • Replace cryptohash dependency with cryptonite
  • Increase upper bound on exceptions
  • Fix type error in tutorial

1.10.0

  • Feature: Records/unions can now have fields/alternatives that are types
  • Feature: New dhall-repl for interactively evaluating Dhall expressions
  • Feature: Syntax highlighting
  • Feature: BREAKING CHANGE TO THE API: dhall-format preserves field order
    • This changes the syntax tree to use an InsOrdHashMap instead of a Map
  • BREAKING CHANGE TO THE API: Use Haskell's Scientific type
    • This is fixes the interpreter to correct handle really large/small numbers
    • This also allows marshaling into Haskell's Scientific type
    • See: dhall-lang#256
  • BREAKING CHANGE TO THE API: Remove system-filepath/system-fileio dependencies
  • Feature: Labels can now begin with reserved names
  • Fix: Rendered labels are now correctly escaped if they are numbers
  • Add the instance Interpret String.
  • Fix: Custom contexts passed to typeWith are now checked
    • This prevents a custom context from triggering an infinite loop
    • See: dhall-lang#259

1.9.1

  • dhall-format now emits single-quoted strings for multi-line strings
  • Improved error messages for list elements with the wrong type
  • Change lens dependency to lens-family-core

1.9.0

  • Feature: BREAKING CHANGE TO LANGUAGE AND API: Add constructors keyword
    • This new keyword generates constructors from a union type
      • See the updated Haskell tutorial for more details
    • This means that constructors is now a reserved keyword
    • This adds a new Constructors constructor to the Expr type
    • See: dhall-lang#199
  • Feature: BREAKING CHANGE TO THE API: dhall-format preserves interpolation
    • This changes the TextLit constructor to represent an interpolated Text literal
    • See: dhall-lang#220
  • Feature: You can now define type synonyms using let
  • Feature: Extend valid set of quoted labels
  • Performance: Improve startup time when importing files, but not URLs
  • Security: localhost/127.0.0.1 imports no longer count as local imports
    • Specifically: they cannot import environment variables or files
    • See: dhall-lang#197
  • Security: Fix potential type-checking bug
  • Fix: BREAKING CHANGE TO API: Improve localization of error messages
    • This required fixing the type of normalize/shift/subst to preserve the first type parameter of Expr (i.e. they no longer delete Note constructors)
    • A new denote function was added for the explicit purpose of deleting Note constructors
    • See: dhall-lang#218
  • Expose MissingEnvironmentVariable exception type
  • Add genericAuto
  • Add inputWith
  • AddloadWithContext
  • Add pair/unit/string/list

1.8.2

  • Add typeWithA for type-checking custom Embedded values
  • Fix dhall{,-*} executables to ignore ambient locale and use UTF8
  • Increase upper bound on tasty dependency

1.8.1

  • dhall executable can now format output using --pretty
  • Improved Unicode suppport on Windows

1.8.0

  • BREAKING CHANGE TO LANGUAGE: Add support for import integrity checks
    • In practice, the likelihood of this breaking code in the wild is astronomically low
    • This would only break code of the form sha256:aaa...aaa (i.e. a variabled named sha256 with a type annotation for a type with a name 64 characters long drawn from the first 6 characters of the alphabet)
  • BUG FIX: Fix parsing of single quotes in single-quoted strings
  • BUG FIX: Fix superfluous parentheses introduced by dhall-format
  • New dhall-hash executable
    • This goes hand-in-hand with the added support for integrity checks since the executable lets you compute the current hash of an import

1.7.0

  • BREAKING CHANGE TO LANGUAGE: Update parser to match standardized grammar
    • Trailing commas and bars no longer supported for union and record literals
    • Paths no longer permit commas
    • URL grammar is now RFC-compliant
    • Environment variables can now be quoted to support full range of POSIX-compliant names
    • Text literals support full set of JSON escape sequences (such as \u2192)
  • BREAKING CHANGE TO LANGUAGE: Single quoted strings strip leading newlines
  • BUG FIX: Fixed type-checking infinite loops due to non-type-checked variables in context
  • BUG FIX: Fixed type-checking bug due to missing context when type-checking certain expressions
  • BUG FIX: Fixed type-checking bug due to off-by-one errors in name shadowing logic
  • New dhall-format executable to automatically format code
  • Performance optimizations to Natural/fold and List/fold
  • Improved parsing performance (over 3x faster)
  • Union literals can now specify the set value anywhere in the literal
    • i.e. < A : Integer | B = False | C : Text >
  • New Inject instance for ()
  • Several tutorial fixes and improvements

1.6.0

  • BREAKING CHANGE TO THE API: Drop support for GHC 7.*
  • BREAKING CHANGE TO THE API: Add support for customizing Dhall import
    • This is a breaking change because this changes the type of loadWith
  • BREAKING CHANGE TO THE API: Add field to UnboundVariable error containing
  • BUG FIX: Fix parsing single quotes in string literals the name of the unbound variable
  • Add List/concatMap to the Prelude
  • You can now derive Inject and Interpret for types with unlabeled fields
  • Add new instances for Interpret:
    • []
    • (,)
  • Add new instance for Inject
    • [], Data.Set.Set, Data.Sequence.Seq
    • (,)
    • Int, Word8, Word16, Word32, Word64
  • Add Eq instance for Src

1.5.1

  • Increase upper bound on vector and optparse-generic

1.5.0

  • BREAKING CHANGE: Add list concatenation operator: (#)
    • This is a breaking change because it adds a new constructor to the Expr type which breaks exhaustive pattern matches
  • BREAKING CHANGE: Add Interpret support for lazy Text
    • This is a breaking change because it renames text to strictText
  • Add Interpret instance for decoding (a limited subset of) Dhall functions
  • Dhall no longer requires Template Haskell to compile
    • This helps with cross-compilation
  • Add rawInput utility for decoding a Haskell value from the Expr type
  • Add loadWith/normalizeWith utilities for normalizing/importing modules with a custom context
  • Export Type constructor

1.4.2

  • Fix missing Prelude files in package archive uploaded to Hackage

1.4.1

  • Fix missing tests/Tutorial.hs module in package archive uploaded to Hackage

1.4.0

  • BREAKING CHANGE TO THE LANGUAGE AND API: You can now supply custom headers for URL imports with the new using keyword
    • This is a breaking change to the language because this adds a new reserved using keyword
    • This is a breaking change to the API because this adds a new field to the URL constructor to store optional custom headers
  • BUG FIX: : is no longer a disallowed path character
    • This was breaking URL imports with a port
  • BUG FIX: If you import a home-anchored path (i.e. ~/foo) and that imports a relative path (like ./bar), then the canonical path of the relative import should be home-anchored (i.e. ~/bar). However, there was a bug that made lose the home anchor (i.e. ./foo/bar), which this release fixes likely fail due to no longer being home-anchored (i.e. `./foob
  • Add support for string interpolation
  • merge no longer requires a type annotation if you are merging at least one alternative
  • Expanded Prelude
    • ./Prelude/Optional/all
    • ./Prelude/Optional/any
    • ./Prelude/Optional/filter
    • ./Prelude/Optional/length
    • ./Prelude/Optional/null
    • ./Prelude/Text/concatMap
    • ./Prelude/Text/concatMapSep
    • ./Prelude/Text/concatSep
  • Rearrange detailed error messages to put summary information at the bottom of the message

1.3.0

  • BREAKING CHANGE TO THE API: Add support for new primitives, specifically:
    • (//) - Right-biased and shallow record merge
    • Optional/build (now a built-in in order to support build/fold fusion)
    • Natural/show
    • Integer/show
    • Double/show
    • Natural/toInteger
    • These all add new constructors to the Expr type, which would break exhaustive pattern matches
  • BREAKING CHANGE TO THE LANGUAGE: Imported paths and URLs no longer support the characters: "()[]{}<>:"
    • This reduces the number of cases where you have to add a space after imports
    • Note that this does not exclude the : in the URL scheme (i.e. http://)
  • Increase connection timeout for imports
  • Variable names now allow the - character for all but the first character
  • You can now escape identifiers with backticks
    • This lets you name identifiers so that they don't conflict with reserved key words
    • This is most useful when converting Dhall to other file formats (like JSON) where you might need to emit a field that conflicts with one of Dhall's reserved keywords
  • New --version flag for the dhall executable

1.2.0

  • BREAKING CHANGE: Add support for customizing derived Interpret instances
    • This is a breaking change to the Dhall library API since this changes the signature of the Interpret class by replacing the auto method with a more general autoWith method. This autoWith now takes an InterpretOptions argument that lets you customize derived field and constuctor names
    • In practice user programs that use the common path will be unaffected by this change
    • This is not a breaking change to the Dhall language
  • BREAKING CHANGE: Type annotations now bind more tightly than lambda abstraction
    • This is a breaking change to the Dhall language. An expression like this:

      λ(x : A) → y : B
      

      ... used to parenthesized implicitly as:

      (λ(x : A) → y) : T
      

      ... but is now parenthesized implicitly as:

      λ(x : A) → (y : T)
      

      This is now consistent with Haskell's precedence and also consistent with the precedence of List and Optional type annotations

    • This change affects programs with an expression like this:

      -- Assuming that `y : B`
      λ(x : A) → y : A → B
      

      The above program would type-check before this change but not type-check after this change. You would you need to fix the above program by either changing the type signature to annotate just the type of y like this:

      λ(x : A) → y : B
      

      ... or by adding explicit parentheses like this:

      (λ(x : A) → y) : A → B
      
    • This is not a breaking change to the Dhall library API

  • BREAKING CHANGE: Add support for importing a path's contents as raw Text by adding as Text after the import
    • This is a breaking change to the Dhall language

    • This is technically a breaking change, but is extremely unlikely to affect you program. This only changes the behavior of old programs that had an expression of the form:

      /some/imported/function as Text
      

      ... where /some/imported/function is an imported function being applied to two arguments, the first of which is a bound variable named as and the second of which is the type Text

    • This is not a breaking change to the Dhall library API

  • BREAKING CHANGE: Add support for importing environment variables using env:VAR syntax
    • This is a breaking change to the Dhall library API since it adds a new Path constructor

    • This also technically a breaking change to the Dhall language but extremely unlikely to affect your program. This only changes the behavior of old programs that had an expression of the form:

      env:VAR
      

      ... where env was the name of a bound variable and :VAR was a type annotation without spaces around the type annotation operator

      After this change the program would be interpreted as an import of the contents for the environment variable named VAR

  • BREAKING CHANGE: Support importing paths relative to home directory using ~/some/path syntax
    • This is a breaking change to the Dhall library API since it adds a new field to the File constructor indicating whether or not the imported path is relative to the home directory
    • This is not a breaking change to the Dhall language and the new syntax does not override any old syntax
  • Permit trailing commas and bars in record/union syntax
  • Improve location information for parsing errors

1.1.0

  • BREAKING CHANGE: Non-empty lists no longer require a type annotation
    • This is a breaking change to the Haskell library, not the Dhall language
    • This change does not break existing Dhall programs
    • The Expr type was modified in a non-backwards-compatible way
  • Add new exprA parser
  • Add new InvalidType exception if input fails on an invalid Type
  • Improve documentation and tutorial

1.0.2

  • Add support for Nix-style "double single-quote" multi-line string literals
  • Add isNormalized
  • Improve documentation and tutorial
  • Build against wider range of http-client versions

1.0.1

  • Initial release

1.0.0

  • Accidental premature upload to Hackage. This release was blacklisted