daml/daml-lf/archive
dylant-da a74c020ddd
Add version 1.15 - move interfaces into them (#14770)
* Add version 1.15 - move interfaces into them

* Update Ast/Version & docs for 1.15, split interface into simple/extended

* Stage 1.15 protobuf

* Remove references to dev from 1.15 protobufs

* Add Tests file for 1.15 in ledger API testtool

* Update Version 1.15 changelog with Call/implements

* Make 1.14 default again

* Add 1.15 as preview version

* Add 1.15 test suite to testtool

* Reinclude 1.15 in COMPILER_LF_VERSIONS to build model-tests-1.15

* Move v1_15 ledger-api-tests into own suite

* Fix InterfaceNotSupported message to 1.15 or higher

* satisfy changelog check

CHANGELOG_BEGIN
CHANGELOG_END

* Update tests with extended interface features to only run on 1.dev

* Allow unsafe_from_interface and interface_template_type_rep in 1.15

* Fix StableVersions back to 1.14, make EarlyAccessVersions 1.15

* Run retroactive implements tests only in extended interfaces

* lint

* Temporarily disable 1.15 conformance tests - handle in another PR

* Also disable conformance-test-tls1.2-or-newer-1.15

* Disable PureConfigReaderWriter tests that assume early-access == stable

* lint
2022-08-23 13:39:16 +00:00
..
encoder update copyright headers (#12240) 2022-01-03 16:36:51 +00:00
src Add version 1.15 - move interfaces into them (#14770) 2022-08-23 13:39:16 +00:00
buf.yaml update copyright headers (#12240) 2022-01-03 16:36:51 +00:00
BUILD.bazel Improve MessageDigest and Mac instance creation to solve lock contention [DPP-956] (#13221) 2022-03-09 22:15:32 +01:00
proto_breaking_changes.sh update copyright headers (#12240) 2022-01-03 16:36:51 +00:00
proto_check_hash.sh update copyright headers (#12240) 2022-01-03 16:36:51 +00:00
README.md LF: replace "dev" LF version by "1.dev" in bazel files (#11894) 2021-11-26 12:23:17 +00:00

Daml-LF archive

This component contains the .proto definitions specifying the format in which Daml-LF packages are stored -- the Daml-LF archive. All the proto definitions are kept in the directory src/protobuf/com/daml/daml_lf_dev/

The entry point definition is Archive in src/protobuf/com/daml/daml_lf_dev/daml_lf.proto. Archive contains some metadata about the actual archive (currently the hashing function and the hash), and then a binary blob containing the archive. The binary blob must be an ArchivePayload -- we keep it in binary form to facilitate hashing, signing, etc. The encoding and decoding of the payload is handled by Haskell and Java libraries in daml-core-package, so that consumers and producers do not really need to worry about it.

ArchivePayload is a sum type containing the various Daml-LF versions supported by the Daml-LF archive. Currently we have two major versions:

Snapshot versions

The component contains also an arbitrary number of snapshots of the protobuf definitions as they were as the time a particular version of Daml-LF was frozen. Those snapshots are kept in the directories src/protobuf/com/daml/daml_lf_x_y/, where x.y is an already frozen Daml-LF version. A snapshot for version x.y can be used to read any Daml-LF version from 1.6 to x.y without suffering breaking changes (at the generated code level) often introduced in the current version.

Building

It produces several libraries containing code to encode / decode such definition, a Haskell one, and several Java ones:

$ bazel build //daml-lf/archive:daml_lf_dev_archive_haskell_proto
$ bazel build //daml-lf/archive:daml_lf_1.dev_archive_proto_java
$ bazel build //daml-lf/archive:daml_lf_1_14_archive_proto_java

Editing the .proto definitions

When editing the proto definitions, you must make sure to not change them in a backwards-incompatible way. To make sure this doesn't happen:

  • DO NOT delete message fields;
  • DO NOT change the number of a message field or an enum value;
  • DO NOT change the type of a message field;

Note that "fields" include oneof fields. Also note that the "don't delete fields" rule is there not because they introduce a backwards incompatible change, but rather because after a field has been deleted another commiter might redefine it with a different type without realizing.

What is OK is renaming message fields while keeping the number and semantics unchanged. For example, if you have

message Foo {
  bytes blah = 1;
}

it's OK to change it to

message Foo {
  // this field is deprecated -- use baz instead!
  bytes blah_deprecated = 1;
  string baz = 2;
}

Conversion from the .proto to AST

The .proto definitions contain the serialized format for Daml-LF packages, however the code to convert from the .proto definitions to the actual AST lives elsewhere.