Skip to content

Releases: FHIR/sushi

SUSHI 3.14.0

31 Dec 19:36
92bf4e4
Compare
Choose a tag to compare

SUSHI 3.14.0 (almost pi) is a minor release with several enhancements and bug fixes. The most notable changes are:

  • When resolving the Canonical keyword (e.g., Canonical(MyResource)), SUSHI now considers all canonical resources in your appropriate input/* folders and dependency packages. Previous versions only resolved canonicals for StructureDefinitions, ValueSets, and CodeSystems.
  • When resolving the Canonical keyword, SUSHI will consider the target type (where the canonical is being assigned), choosing the appropriate resolution when there are multiple matches. Previous versions of SUSHI always selected the first match, even if it was of the wrong type.
  • SUSHI now properly encodes URLs for cross-version extensions representing choice elements (i.e., elements with names ending in [x]). For example, the cross-version extension for R5's Questionnaire.versionAlgorithm[x] now correctly specifies its URL as http://hl7.org/fhir/5.0/StructureDefinition/extension-Questionnaire.versionAlgorithm%5Bx%5D.
  • The automatic hl7.fhir.uv.tools dependency now resolves to the latest published release-specific version of the package (e.g., hl7.fhir.uv.tools.r4#0.3.0). This aligns more closely with the behavior of the IG Publisher.

What's Changed

Install or Update

SUSHI 3.14.0 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.14.0, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release, run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.13.1...v3.14.0

SUSHI 3.13.1

21 Dec 19:18
853a04e
Compare
Choose a tag to compare

SUSHI 3.13.1 is a patch release that fixes issues in SUSHI 3.13.0's file system interaction that occurred for users using Node 18 versions prior to Node 18.20.0.

What's Changed

  • Update FPL and avoid using readdirSync w/ recursive flag by @cmoesel in #1546

Install or Update

SUSHI 3.13.1 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.13.1, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release (3.12.1, since 3.13.0 contained significant bugs in Node < 18.20.0), run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.13.0...v3.13.1

SUSHI 3.13.0

20 Dec 19:59
214a1f3
Compare
Choose a tag to compare

SUSHI 3.13.0 integrates the brand new FHIR Package Loader (FPL) 2.0.0. While this SUSHI release does not introduce any significant new features related to FPL 2.0.0, it sets up SUSHI to more easily support future enhancements and fixes to dependency handling.

SUSHI 3.13.0 also includes several bug fixes and minor enhancements.

What's Changed

Install or Update

SUSHI 3.13.0 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.13.0, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release (3.12.1), run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.12.1...v3.13.0

SUSHI 3.12.1

08 Nov 19:30
9dbee85
Compare
Choose a tag to compare

SUSHI 3.12.1 is a patch release that contains a fix for a bug related to using FHIR R6 ballot versions. R5 terminology and extension packages will be automatically loaded when building a FHIR R6 project. This is because R6 versions of these packages are not yet available.

What's Changed

Install or Update

SUSHI 3.12.1 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.12.1, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release (3.12.0), run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.12.0...v3.12.1

SUSHI 3.12.0

11 Oct 16:09
faaf076
Compare
Choose a tag to compare

SUSHI 3.12.0 contains several enhancements and bug fixes, the most notable of which is support for FHIR R6 ballot 2. To base an IG on FHIR R6 ballot 2, specify fhirVersion as follows in your sushi-config.yaml:

fhirVersion: 6.0.0-ballot2

What's Changed

Software Changes

Documentation Changes

Install or Update

SUSHI 3.12.0 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.12.0, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release (3.11.1), run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.11.1...v3.12.0

SUSHI 3.11.1

29 Aug 00:46
ada1c22
Compare
Choose a tag to compare

What's Changed

Software Changes

Documentation Changes

New Contributors

Install or Update

SUSHI 3.11.1 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.11.1, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release (3.10.0), run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.11.0...v3.11.1

SUSHI 3.11.0

05 Jun 16:25
657a136
Compare
Choose a tag to compare

SUSHI 3.11.0 contains the following enhancements and bug fixes:

What's Changed

  • Add new snapshot option to FshToFhir API by @joepaquette in #1465
  • Remove releaseLabel coded options from sushi-config.yaml created by sushi init by @jafeltra in #1462
  • Warn when sushi-config.yaml does not include a menu and there is no provided menu.xml by @KaelynJefferson in #1464
  • Set a default for Logical Model and Resource root elements to prevent empty/missing definition by @KaelynJefferson in #1466

New Contributors

Install or Update

SUSHI 3.11.0 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.11.0, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release (3.10.0), run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.10.0...v3.11.0

SUSHI 3.10.0

02 May 20:37
2b2f51b
Compare
Choose a tag to compare

SUSHI 3.10.0 contains the following enhancements and bug fixes:

What's Changed

New options for sushi init command

The sushi init command now allows users to specify the project name via a command line argument and other project metadata via command line options. In addition, there are flags to automatically choose default values and to automatically confirm initialization of the project folder.

For example, to start the initialization dialog for a project named MyBreakfastIG, run the following command:

$ sushi init MyBreakfastIG

Or to create a test IG called MyTestIG with status unknown and version 0.0.1, accepting all other default metadata values and immediately creating the project folder, run this command:

$ sushi init -c status:unknown -c version:0.0.1 -d -a MyTestIG

This feature is most helpful for people who create projects often (either for testing or as part of a script). For full usage information, run sushi help init or sushi init --help:

$ sushi help init
Usage: sushi init [options] [name]

initialize a SUSHI project

Arguments:
  name                     project name

Options:
  -c, --config <config>    configure a specific property for the project (supported: 'id', 'canonical', 'status',
                           'version', 'releaselabel', 'publisher-name', 'publisher-url') (eg: --config status:draft)
  -d, --default            accept all remaining defaults
  -a, --auto-initialize    automatically initialize the SUSHI project in the current directory
  -l, --log-level <level>  specify the level of log messages (default: "info") (choices: "error", "warn", "info",
                           "debug")
  -h, --help               display help for command

Override sushi-config options from command line

Typically, SUSHI uses the sushi-config.yaml file to define the configuration options it uses when processing FSH. However, in rare cases, it may be useful to override the values provided in sushi-config.yaml without changing the file itself. For these cases, the --config (or -c) option can be used to specify a configuration property and the override value for it. Currently, this option only allows version, status, and releaselabel to be overridden.

For example, to temporarily change the version to 1.2.3 and status to draft when building the current directory, run:

$ sushi build -c version:1.2.3 -c status:draft .

Many thanks to @LodewijkSioen for thinking of and implementing this feature!

Set version based on sushi-config.yaml in FSHOnly projects

In SUSHI 2.x, SUSHI always defaulted the version of conformance resources to the version of the IG (as specified in sushi-config.yaml). In SUSHI 3.x, we removed this feature so that the version assignment could be controlled by the IG Publisher instead. This change, however, adversely impacted FSHOnly projects that do not use the IG Publisher. Now, starting in SUSHI 3.10.0, if a project has FSHOnly: true in its sushi-config.yaml, SUSHI will default the version of conformance resources to the project version specified in sushi-config.yaml. This restores the previous SUSHI 2.x behavior for FSHOnly projects.

New Contributors

Install or Update

SUSHI 3.10.0 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.10.0, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release (3.9.0), run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.9.0...v3.10.0

SUSHI 3.9.0

11 Apr 19:35
1ed4c56
Compare
Choose a tag to compare

SUSHI 3.9.0 contains the following enhancements and bug fixes:

What's Changed

Support extensions on IG.definition in sushi-config.yaml

SUSHI now supports adding extensions to the ImplementationGuide definition element. To add extensions, authors can add definition as a top-level property in the sushi-config.yaml file and add an extension list below it. This will add extensions to the ImplementationGuide.definition element in the generated ImplementationGuide.

An example of this configuration within sushi-config.yaml is below:

definition:
  extension:
    - url: http://example.org/example/ig-definition-ext
      valueBoolean: true

Note that all other IG.definition properties are available as top-level properties within sushi-config.yaml. Those properties should continue to be used. Only extensions can be added to the new definition configuration property.

Install or Update

SUSHI 3.9.0 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.9.0, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release (3.8.0), run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.8.0...v3.9.0

SUSHI 3.8.0

15 Mar 17:09
466cd7b
Compare
Choose a tag to compare

SUSHI 3.8.0 contains the following enhancements and bug fixes:

What's Changed

Assign FSH Code or Reference to CodeableReference element

Authors can now assign a FSH Coding or reference directly to CodeableReference types. Previously, authors needed to access either the concept or reference portions of the CodeableReference directly to assign values. Now, the top level CodeableReference element can be used instead.

For example, to assign the concept and reference properties of a code element that is a CodeableReference type, the following rules can be used:

* code = $SCT#1003754000 "Natural rubber latex (substance)"
* code = Reference(NaturalLatexSubstanceDefinitionExample)

These two rules are equivalent to the following rules that assign the values directly:

* code.concept = $SCT#1003754000 "Natural rubber latex (substance)"
* code.reference = Reference(NaturalLatexSubstanceDefinitionExample)

For more information and examples, see the Assignments with CodeableReference Data Type section of the FSH 3.0.0 Current Build Specification.

Quantity may omit numeric value

Authors can now assign the units of measure without assigning a value. Authors can specify the units using the FSH syntax for UCUM units and omit the value. For example, you can se the units of Observation.valueQuantity to millimeters using UCUM units and a display string, without setting a value, using the following rule:

* valueQuantity = 'mm' "millimeter"

For more details on this syntax, see the Assignments with the Quantity Data Type section of the FSH 3.0.0 Current Build Specification.

Install or Update

SUSHI 3.8.0 is the latest stable release of fsh-sushi. To install or update to SUSHI 3.8.0, run the following command:

$ npm install -g fsh-sushi

To revert to the previous SUSHI stable release (3.7.0), run the following command:

$ npm install -g [email protected]

To check or confirm what version of SUSHI you have installed, you can run the following command:

$ sushi -v

Full Changelog: v3.7.0...v3.8.0