Tool for assembly, compilation, and validation of component manifests
USAGE:
    cmc [OPTIONS] <SUBCOMMAND>
OPTIONS:
    -h, --help
            Prints help information
    -V, --version
            Prints version information
    -s, --stamp <stamp>
            Stamp this file on success
SUBCOMMANDS:
    check-includes         check if given includes are present in a given component manifest
    compile                compile a CML file
    debug-print-cm         print pretty rust-debug-format-string representation of .cm file
    format                 format a json file
    help                   Prints this message or the help of the given subcommand(s)
    include                recursively process contents from includes, and optionally validate the result
    merge                  merge the listed manifest files. Does NOT validate the resulting manifest
    print-cml-reference    print generated .cml reference documentation
    validate-references    validate a component manifest against package manifest
check-includes
cmc-check-includes
check if given includes are present in a given component manifest
USAGE:
    cmc check-includes [OPTIONS] <FILE> [--] [expect]...
ARGS:
    <FILE>
            file to process
    <expect>...
OPTIONS:
    -h, --help
            Prints help information
    -V, --version
            Prints version information
    -d, --depfile <depfile>
            depfile for includes
            If specified, include paths will be listed here, delimited by newlines.
    -f, --fromfile <fromfile>
            response file for includes to expect
            If specified, additional includes to expect will be read from the path provided. The input format is
            delimited by newlines.
    -p, --includepath <includepath>...
            base paths for resolving includes \[default: ]
    -r, --includeroot <includeroot>
            base path for resolving include paths that start with "//" \[default: ]
compile
cmc-compile
compile a CML file
USAGE:
    cmc compile [OPTIONS] <FILE> --output <output>
ARGS:
    <FILE>
            file to format
OPTIONS:
    -h, --help
            Prints help information
    -V, --version
            Prints version information
        --config-package-path <config-package-path>
            path within the component's package at which its configuration will be available
    -d, --depfile <depfile>
            depfile for includes
            If specified, include paths will be listed here, delimited by newlines.
        --experimental-force-runner <experimental-force-runner>
            override runner to this value in resulting CML
            If specified, the program.runner field will be set to this value. This option is EXPERIMENTAL and subject to
            removal without warning.
    -f, --features <features>...
            The set of non-standard features to compile with. Only applies to CML files
    -p, --includepath <includepath>...
            base paths for resolving includes \[default: ]
    -r, --includeroot <includeroot>
            base path for resolving include paths that start with "//" \[default: ]
        --must-offer-dictionary <must-offer-dictionary>...
            dictionaries to verify that all children and collections are used
            If specified, for each offer named, cmc will require that the offer is in a use block. This can be used to
            help find missing usages of important capabilities, like diagnostics
        --must-offer-protocol <must-offer-protocol>...
            protocols to verify that all children and collections are offered
            If specified, for each offer named, cmc will require that all children or collections in `files` have been
            offered a capability named for the offer specified.  This can be used to help find missing offers of
            important capabilities, like fuchsia.logger.LogSink
        --must-use-protocol <must-use-protocol>...
            protocols to verify that all children and collections are used
            If specified, for each offer named, cmc will require that the offer is in a use block. This can be used to
            help find missing usages of important capabilities, like fuchsia.logger.LogSink
    -o, --output <output>
            file to write the formatted results to
debug-print-cm
cmc-debug-print-cm
print pretty rust-debug-format-string representation of .cm file
USAGE:
    cmc debug-print-cm <FILE>
OPTIONS:
    -h, --help       Prints help information
    -V, --version    Prints version information
ARGS:
    <FILE>    file to process
format
cmc-format
format a json file
USAGE:
    cmc format [FLAGS] [OPTIONS] [FILE]
OPTIONS:
        --cml         deprecated and ignored. Please do not use (https://fxbug.dev/42060365)
    -h, --help        Prints help information
    -i, --in-place    replace the input file with the formatted output (implies `--output <inputfile>`)
    -p, --pretty      deprecated and ignored. Please do not use (https://fxbug.dev/42060365)
    -V, --version     Prints version information
    -o, --output <output>    file to write the formatted results to, will print to stdout if not provided
ARGS:
    <FILE>    file to format. If missing, use stdin
include
cmc-include
recursively process contents from includes, and optionally validate the result
USAGE:
    cmc include [OPTIONS] <FILE>
ARGS:
    <FILE>
            file to process
OPTIONS:
    -h, --help
            Prints help information
    -V, --version
            Prints version information
    -d, --depfile <depfile>
            depfile for includes
            If specified, include paths will be listed here, delimited by newlines.
    -f, --features <features>...
            The set of non-standard features to compile with. Only applies to CML files
    -p, --includepath <includepath>...
            base paths for resolving includes \[default: ]
    -r, --includeroot <includeroot>
            base path for resolving include paths that start with "//" \[default: ]
    -o, --output <output>
            file to write the merged results to, will print to stdout if not provided
        --validate <validate>
            validate the result \[default: true]
merge
cmc-merge
merge the listed manifest files. Does NOT validate the resulting manifest.
The semantics for merging are the same ones used for `include`: https://fuchsia.dev/reference/cml#include
USAGE:
    cmc merge [OPTIONS] [FILE]...
ARGS:
    <FILE>...
            files to process
            If any file contains an array at its root, every object in the array will be merged into the final object.
OPTIONS:
    -h, --help
            Prints help information
    -V, --version
            Prints version information
    -d, --depfile <depfile>
            depfile for includes
            If specified, include paths will be listed here, delimited by newlines.
    -f, --fromfile <fromfile>
            response file for files to process
            If specified, additional files to merge will be read from the path provided. The input format is delimited
            by newlines.
    -o, --output <output>
            file to write the merged results to, will print to stdout if not provided
print-cml-reference
cmc-print-cml-reference
print generated .cml reference documentation
USAGE:
    cmc print-cml-reference [OPTIONS]
OPTIONS:
    -h, --help       Prints help information
    -V, --version    Prints version information
    -o, --output <file path>    If provided, will output generated reference documentation to a text file at the file
                                path provided
validate-references
cmc-validate-references
validate a component manifest against package manifest
USAGE:
    cmc validate-references [OPTIONS] --component-manifest <Component Manifest> --package-manifest <Package Manifest>
OPTIONS:
    -h, --help       Prints help information
    -V, --version    Prints version information
    -c, --component-manifest <Component Manifest>
    -e, --context <Free text label, for instance as context for errors printed>
    -p, --package-manifest <Package Manifest>