Skip to content

Conversation

@mgrojo
Copy link
Contributor

@mgrojo mgrojo commented Sep 23, 2023

This functionality can be used to provide on-line versions of the help messages for alire.ada.dev.

The help is generated in a single markdown page with appropiate section titles, so it can have a table of contents.

This functionality can be used to provide on-line versions of the help
messages for alire.ada.dev.

The help is generated in a single markdown page with appropiate
section titles, so it can have a table of contents.
@mgrojo
Copy link
Contributor Author

mgrojo commented Sep 23, 2023

It goes with alire-project/clic#30
It supersedes #1460

@mgrojo
Copy link
Contributor Author

mgrojo commented Sep 23, 2023

I've seen there are some descriptive paragraphs which have grave accents used as quoting of commands:

& " issue `alr publish` after committing and pushing"

This has a positive (involuntary?) impact in the formatting of the markdown version. If this is considered valid also for the terminal, shouldn't this be standardized and use the same quoting for similar paragraphs containing natural language and command lines?

Other examples of grave accent quoting:

$ git grep -n "\".*\`.*alr.*\`.*\""
src/alire/alire-config-builtins.ads:        "If true, `alr with` will replace 'any' dependencies with the"
src/alire/alire-config-builtins.ads:      & "through `alr update`");
src/alire/alire-github.adb:               "Closed using `alr " & Version.Current & "` with reason: "
src/alire/alire-publish-submit.adb:                      & " (via `alr publish --submit`)").Assert;
src/alire/alire-publish-submit.adb:                "Created via `alr publish` with `alr "
src/alire/alire-roots.adb:                  & " (use `alr with --solve` for details).");
src/alr/alr-commands-get.adb:                          " use `alr update` to apply dependency changes");
src/alr/alr-commands-install.adb:         & "), as well as crates initialized with `alr` using default "
src/alr/alr-commands-pin.adb:               & " specified with --branch. Use `alr update` to refresh the"
src/alr/alr-commands-publish.ads:                & " issue `alr publish` after committing and pushing"
src/alr/alr-commands-toolchain.ads:         ("Run `" & TTY.Terminal ("alr help toolchains") & "` for further "
src/alr/alr-commands-withing.adb:                & " specified with --branch. Use `alr update` to refresh the"

On the contrary, see, for example, these other places where apostrophe quoting has been used and could be changed:

$ git grep -n "\".*'.*alr.*'.*\""
src/alire/alire-toml_index.adb:223:               & " '" & TTY.Terminal ("alr index --reset-community") & "'. "
src/alire/alire.adb:183:           & " with 'alr help identifiers'";
src/alire/os_windows/alire-platforms-current__windows.adb:172:           ("Run 'alr config --global --set msys2.do_not_install false'" &
src/alr/alr-commands-build.adb:156:       .Append ("Running '" & TTY.Terminal ("alr build") & "' without profile "
src/alr/alr-commands-init.adb:256:              ("You can edit this information at any time with 'alr config'");
src/alr/alr-commands-run.adb:166:               & " (see declared list with 'alr run --list')");
src/alr/alr-commands-search.adb:301:               & " 'alr show <crate>=<version>'.")
src/alr/alr-commands-withing.adb:366:                & " for comments that contain the sequence 'alr with'. "

Nevertheless, my initial approach was that these text paragraphs should use something like CLIC.Formatter.Emph (which maybe should be named in a semantic way, e.g. Code) so they can be emphasized in the terminal and quoted as code in markdown.

I won't proceed with any of these changes until I get your feedback.

@mgrojo mgrojo changed the title Support for markdown output in help messages Dev command to output help page in markdown format Sep 23, 2023
@mgrojo
Copy link
Contributor Author

mgrojo commented Sep 30, 2023

Continuation from the closed pull request at clic: alire-project/clic#29 (comment)

I've made a test with pandoc and the output is already pretty acceptable. The kind of errors that are shown, are already present in the markdown output and they are the kind of part where a code formatting should be applied, as I mention in
#1464 (comment)

alr.pdf

The man page has to be copied to a file and displayed running: man -l alr.1

The man pages maybe should be split per command, so a different argument for alr dev might be useful.

.\" Automatically generated by Pandoc 2.9.2.1
.\"
.TH "alr help" "" "" "" ""
.hy
.SH Usage Help
.PP
alr \f[I]2.0-dev\f[R]
.SS USAGE
.PP
\f[I]alr\f[R] global options [command options] []
.PP
\f[I]alr\f[R] \f[I]help\f[R] [|]
.SS ARGUMENTS
.PP
\f[C]<command>\f[R] Command to execute
.PD 0
.P
.PD
\f[C]<arguments>\f[R] List of arguments for the command
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS COMMANDS
.PP
\f[I]General\f[R]
.PD 0
.P
.PD
\f[C]help\f[R] Shows help on the given command/topic
.PD 0
.P
.PD
\f[C]config\f[R] List, Get, Set or Unset configuration options
.PD 0
.P
.PD
\f[C]install\f[R] Manage installation prefixes
.PD 0
.P
.PD
\f[C]toolchain\f[R] Manage Alire-provided toolchains
.PD 0
.P
.PD
\f[C]version\f[R] Show detailed version, configuration, and environment
information
.PP
\f[I]Index\f[R]
.PD 0
.P
.PD
\f[C]get\f[R] Fetch a published crate
.PD 0
.P
.PD
\f[C]index\f[R] Manage indexes used by current configuration
.PD 0
.P
.PD
\f[C]search\f[R] Search for a string in names and properties of crates
.PD 0
.P
.PD
\f[C]show\f[R] Display information about a crate version
.PP
\f[I]Crate\f[R]
.PD 0
.P
.PD
\f[C]build\f[R] Build the library or executables of the crate
.PD 0
.P
.PD
\f[C]clean\f[R] Clean generated files or downloaded dependencies
.PD 0
.P
.PD
\f[C]edit\f[R] Start GNAT Studio with Alire build environment setup
.PD 0
.P
.PD
\f[C]exec\f[R] Run the given command in the alire project context
.PD 0
.P
.PD
\f[C]init\f[R] Create a new crate for an executable or library
.PD 0
.P
.PD
\f[C]pin\f[R] Pin dependencies to exact versions
.PD 0
.P
.PD
\f[C]printenv\f[R] Print the build environment variables
.PD 0
.P
.PD
\f[C]run\f[R] Launch an executable built by the crate
.PD 0
.P
.PD
\f[C]update\f[R] Update some or all dependencies to a newer version
.PD 0
.P
.PD
\f[C]with\f[R] Add or remove dependencies
.PP
\f[I]Testing\f[R]
.PD 0
.P
.PD
\f[C]action\f[R] List or manually trigger action hooks
.PD 0
.P
.PD
\f[C]dev\f[R] Developer helpers
.PD 0
.P
.PD
\f[C]test\f[R] Test the compilation of all or some releases
.PP
\f[I]Publish\f[R]
.PD 0
.P
.PD
\f[C]publish\f[R] Help publishing a new version of a crate
.SS TOPICS
.PP
\f[C]aliases\f[R] User defined command aliases
.PD 0
.P
.PD
\f[C]identifiers\f[R] Naming rules for crate and index names
\f[C]toolchains\f[R] Configuration and use of toolchains
.PD 0
.P
.PD
### ALIASES \f[C]gnatcov\f[R] exec -P2 \[en] gnatcov
.PD 0
.P
.PD
\f[C]gnatprove\f[R] exec -P1 \[en] gnatprove
.SH General Commands
.SS \f[C]alr help\f[R]
.SS SUMMARY
.PP
Shows help on the given command/topic
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]help\f[R] options [|]
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Shows information about commands and topics.
See available commands with `alr help commands' See available topics
with `alr help topics'.
.SS \f[C]alr config\f[R]
.SS SUMMARY
.PP
List, Get, Set or Unset configuration options
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]config\f[R] options [\[en]list] [\[en]show-origin]
[key_regex] | \[en]get | \[en]set | \[en]unset
.SS OPTIONS
.PP
\f[C]--list\f[R] List configuration options
.PD 0
.P
.PD
\f[C]--show-origin\f[R] Show origin of configuration values in \[en]list
.PD 0
.P
.PD
\f[C]--get\f[R] Print value of a configuration option
.PD 0
.P
.PD
\f[C]--set\f[R] Set a configuration option
.PD 0
.P
.PD
\f[C]--unset\f[R] Unset a configuration option
.PD 0
.P
.PD
\f[C]--global\f[R] Set and Unset global configuration instead of the
local one \f[C]--builtins-doc\f[R] Print Markdown list of built-in
configuration options
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Provides a command line interface to the Alire configuration option
files.
.PP
Option names (keys) can use lowercase and uppercase alphanumeric
characters from the Latin alphabet.
Underscores and dashes can also be used except as first or last
character.
Dot `.' is used to specify sub-categories, e.g.
`user.name' or `user.email'.
.PP
Option values can be integers, float, Boolean (true or false) or
strings.
The type detection is automatic, e.g.\ 10 is integer, 10.1 is float,
true is Boolean.
You can force a value to be set a string by using double-quotes, e.g.
\[lq]10.1\[rq] or \[lq]true\[rq].
Extra type checking is used for built-in options (see below).
.PP
Built-in configuration options:
.IP \[bu] 2
dependencies.shared [Boolean][Default:FALSE] When true, dependencies are
downloaded and built in a shared location inside the global cache.
When false, dependencies are sandboxed in each workspace.
.IP \[bu] 2
distribution.disable_detection [Boolean][Default:FALSE] If true, Alire
will report an unknown distribution and will not attempt to use the
system package manager.
.IP \[bu] 2
editor.cmd [String][Default:gnatstudio -P ${GPR_FILE}] Editor command
and arguments for editing crate code (alr edit).
The executables and arguments are separated by a single space character.
The token ${GPR_FILE} is replaced by a path to the project file to open.
.IP \[bu] 2
index.auto_community [Boolean][Default:TRUE] When unset or true, the
community index will be added automatically when required if no other
index is configured.
.IP \[bu] 2
index.host [String][Default:https://github.com] URL of the community
index host
.IP \[bu] 2
index.owner [String][Default:alire-project] Owner of the index
repository (GitHub user/org).
.IP \[bu] 2
index.repository_name [String][Default:alire-index] Name of the index
repository.
.IP \[bu] 2
solver.autonarrow [Boolean][Default:TRUE] If true, \f[C]alr with\f[R]
will replace `any' dependencies with the appropriate caret/tilde
dependency.
.IP \[bu] 2
toolchain.assistant [Boolean][Default:TRUE] If true, and assistant to
select the default toolchain will run when first needed.
.IP \[bu] 2
update.manually_only [Boolean][Default:FALSE] If true, Alire will not
attempt to update dependencies even after the manifest is manually
edited, or when no valid solution has been ever computed.
All updates have to be manually requested through \f[C]alr update\f[R]
.IP \[bu] 2
user.email [Email address][Default:] User email address.
Used for the authors and maintainers field of a new crate.
.IP \[bu] 2
user.github_login [GitHub login][Default:] User GitHub login/username.
Used to for the maintainers-logins field of a new crate.
.IP \[bu] 2
user.name [String][Default:] User full name.
Used for the authors and maintainers field of a new crate.
.IP \[bu] 2
warning.caret [Boolean][Default:TRUE] If true, Alire will warn about the
use of caret (\[ha]) for pre-1 dependencies, for which tilde (\[ti]) is
recommended instead.
.IP \[bu] 2
warning.old_index [Boolean][Default:TRUE] If unset or true, a warning
will be emitted when using a compatible index with a lower version than
the newest known.
.SS \f[C]alr install\f[R]
.SS SUMMARY
.PP
Manage installation prefixes
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]install\f[R] options [[\[en]info] |
[crate[versions]]\&...]
.SS OPTIONS
.PP
\f[C]--prefix=ARG\f[R] Override installation prefix (default is
${CRATE_ROOT}/alire/prefix)) \f[C]--info\f[R] Show info about a
installation prefix
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Manages installations of releases to a common prefix.
The default install location is /home/mgr/.alire
.PP
Installation prefixes are intended to make binaries or dynamic libraries
available outside of the Alire environment, normally by adding the /bin
folder to the user\[cq]s path.
.PP
Although Alire will vet trivially detectable conflicts (e.g., trying to
install two executable release with different versions), Alire is not
aware of the exact binary artifacts produced by compiled crates.
Thus, you are \[lq]on your own\[rq] in regard to the final consistency
of installations.
.PP
That said, binary crates from the Alire project (gnat, gnatprove,
gprbuild), as well as crates initialized with \f[C]alr\f[R] using
default templates, should be able to coexist in a same installation
prefix without issue.
.PP
You can use the \f[C]--force\f[R] to reinstall already installed
releases.
.SS \f[C]alr toolchain\f[R]
.SS SUMMARY
.PP
Manage Alire-provided toolchains
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]toolchain\f[R] options [-u|\[en]uninstall]
[-i|\[en]install crate[version set]] | \[en]select [\[en]local]
[releases] [\[en]disable-assistant]
.SS OPTIONS
.PP
\f[C]--disable-assistant\f[R] Disable autorun of selection assistant
.PD 0
.P
.PD
\f[C]-i\f[R] (\[en]install) Install one or more toolchain component
.PD 0
.P
.PD
\f[C]--install-dir=ARG\f[R] Toolchain component(s) installation
directory
.PD 0
.P
.PD
\f[C]--local\f[R] Store toolchain configuration in local workspace
\f[C]--select\f[R] Run the toolchain selection assistant
.PD 0
.P
.PD
\f[C]-u\f[R] (\[en]uninstall) Uninstall one or more toolchain component
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Download toolchain elements, like GNAT and gprbuild, in the shared cache
of the active configuration.
.PP
Run it without arguments to get a list of downloaded tools.
.PP
Use \f[C]--select\f[R] without arguments to run the assistant to select
the default toolchain for this configuration.
Adding \f[C]--local\f[R] will instead make the selection apply only to
the workspace (overriding a possible configuration- wide selection).
Giving one or more releases argument will skip the assistant and set the
release as the default.
.PP
Specify \f[C]--install/--uninstall\f[R] and one or more crates name with
optional version set to make available or remove a tool.
.PP
Run \f[C]alr help toolchains\f[R] for further information about
toolchain management and use.
.SS \f[C]alr version\f[R]
.SS SUMMARY
.PP
Show detailed version, configuration, and environment information
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]version\f[R] options
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Shows assorted metadata about the alr executable, and about the crate or
sandbox found in the current directory, if any.
.SH Index Commands
.SS \f[C]alr get\f[R]
.SS SUMMARY
.PP
Fetch a published crate
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]get\f[R] options [allowed versions]
.SS OPTIONS
.PP
\f[C]-b\f[R] (\[en]build) Build after download
.PD 0
.P
.PD
\f[C]--dirname\f[R] Display deployment folder
.PD 0
.P
.PD
\f[C]-o\f[R] (\[en]only) Retrieve requested crate only, without
dependencies
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Retrieve a crate, in the case of regular ones, or install a system
package provided by the platform.
A regular crate is deployed under an immediate folder with naming
`name_version_hash'.
.PP
Version selection syntax (global policy applies within the allowed
version subsets):
.PP
crate Newest/oldest version crate=version Exact version
crate\[ha]version Major-compatible version crate\[ti]version
Minor-compatible version
.SS \f[C]alr index\f[R]
.SS SUMMARY
.PP
Manage indexes used by current configuration
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]index\f[R] options \[en]add \[en]name [\[en]before ]
| \[en]del | [\[en]list] | \[en]update-all | \[en]check
.SS OPTIONS
.PP
\f[C]--add=URL\f[R] Add an index
.PD 0
.P
.PD
\f[C]--before=NAME\f[R] Priority order (defaults to last)
.PD 0
.P
.PD
\f[C]--check\f[R] Runs diagnostics on index contents (unknown values,
hosts, etc.) \f[C]--del=NAME\f[R] Remove an index
.PD 0
.P
.PD
\f[C]--list\f[R] List configured indexes (default)
.PD 0
.P
.PD
\f[C]--name=NAME\f[R] User given name for the index
.PD 0
.P
.PD
\f[C]--update-all\f[R] Update configured indexes
.PD 0
.P
.PD
\f[C]--reset-community\f[R] Add the community index, or reset any local
changes
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Add, remove, list and update indexes used by the current alr
configuration.
.PP
Updating applies only to repository-stored indexes, in which case a pull
operation will be performed on them.
An index initially set up with a specific commit will not be updated.
.SS \f[C]alr search\f[R]
.SS SUMMARY
.PP
Search for a string in names and properties of crates
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]search\f[R] options | [\[en]crates] [\[en]full]
\[en]list
.SS OPTIONS
.PP
\f[C]--crates\f[R] Restrict search and output to crate names and
descriptions \f[C]--external-detect\f[R] Detect externally-provided
releases (implies \[en]external)
.PD 0
.P
.PD
\f[C]--full\f[R] Show all versions of a crate (newest only otherwise)
.PD 0
.P
.PD
\f[C]--list\f[R] List all available releases
.PD 0
.P
.PD
\f[C]--external\f[R] Include externally-provided releases in search
.PD 0
.P
.PD
\f[C]--property=TEXT\f[R] Search TEXT in property values
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Searches the given substring in crate names (or properties with
\f[C]--    property\f[R]), and shows the most recent release of matching
crates (unless \f[C]--    full\f[R] is specified).
.PP
Use \f[C]--crates\f[R] to get a simple list of only crate names and
descriptions.
Otherwise, besides version, description and release notes, a status
column with the following status flags is provided:
.PP
E: the release is externally provided.
S: the release is available through a system package.
U: the release is not available in the current platform.
X: the release has dependencies that cannot be resolved.
.PP
The reasons for unavailability (U) can be ascertained with `alr show ='.
.PP
Unresolvable releases (X) should not happen in platforms with assigned
maintainers.
Common reasons are missing system dependencies that have been phased out
by the platform without being updated yet in the community index.
.SS \f[C]alr show\f[R]
.SS SUMMARY
.PP
Display information about a crate version
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]show\f[R] options [[allowed versions]] [\[en]system]
[\[en]external[-detect]] | \[en]graph | \[en]jekyll | \[en]solve |
\[en]tree | \[en]nested| \[en]dependents[=direct|shortest|all]
.SS OPTIONS
.PP
\f[C]--dependents[=ARG]\f[R] Show dependent crates
(ARG=direct|shortest|all) \f[C]--detail\f[R] Show additional details
about dependencies
.PD 0
.P
.PD
\f[C]--external-detect\f[R] Add detected externals to available releases
.PD 0
.P
.PD
\f[C]--external\f[R] Show info about external definitions for a crate
\f[C]--graph\f[R] Print ASCII graph of dependencies
.PD 0
.P
.PD
\f[C]--system\f[R] Show info relevant to current environment
.PD 0
.P
.PD
\f[C]--solve\f[R] Solve dependencies and report
.PD 0
.P
.PD
\f[C]--tree\f[R] Show complete dependency tree
.PD 0
.P
.PD
\f[C]--jekyll\f[R] Enable Jekyll output format
.PD 0
.P
.PD
\f[C]--nested\f[R] Show info on nested crates
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Shows information found in the loaded indexes about a specific release
(see below to narrow the searched milestones).
By default, only direct dependencies are reported.
With \f[C]--solve\f[R], a full solution is resolved and reported in list
and graph form.
.PP
With \f[C]--external\f[R], the external definitions for a crate are
shown, instead of information about a particular release
.PP
The \f[C]--dependents\f[R] switch accepts these values: * direct
(default) shows direct dependents.
* all shows all dependents, including indirect ones, and all dependency
chains.
* shortest shows all dependents, including indirect ones, but only once,
and a shortest-length chain.
.PP
Version selection syntax (global policy applies within the allowed
version subsets):
.PP
crate Newest/oldest version crate=version Exact version
crate\[ha]version Major-compatible version crate\[ti]version
Minor-compatible version
.SH Crate Commands
.SS \f[C]alr build\f[R]
.SS SUMMARY
.PP
Build the library or executables of the crate
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]build\f[R] options [\[en]] [gprbuild switches and
arguments]
.SS OPTIONS
.PP
\f[C]--release\f[R] Set root build profile to Release
.PD 0
.P
.PD
\f[C]--validation\f[R] Set root build profile to Validation
.PD 0
.P
.PD
\f[C]--development\f[R] Set root build profile to Development (default)
.PD 0
.P
.PD
\f[C]--profiles=ARG\f[R] Comma-separated list of = values (see
description)
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Invokes gprbuild to compile all targets in the current crate.
.PP
A build profile can be selected with the appropriate switch.
The profile is applied to the root release only, whereas dependencies
are built in release mode.
Use \f[C]--profiles\f[R] for more overrides.
.PP
\f[C]--profiles=*|%|<crate1>=<profile>[,<crate2>=<profile\f[R]>\&...]
Apply profiles to individual crates.
Use *= to set all profiles.
Use %= to set profiles of crates without a setting in a manifest only.
.PP
Running `alr build' without profile switches defaults to development
(root crate) + release (dependencies).
Indirect builds through, e.g., `alr run' will use the last `alr build'
configuration.
.SS \f[C]alr clean\f[R]
.SS SUMMARY
.PP
Clean generated files or downloaded dependencies
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]clean\f[R] options [\[en]cache] [\[en]temp] [\[en]]
[gprclean switches and arguments]
.SS OPTIONS
.PP
\f[C]--cache\f[R] Delete cache of releases
.PD 0
.P
.PD
\f[C]--temp\f[R] Delete dangling temporary files
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
no options: gprclean -r will be called to clean up the build
environment.
.PP
\f[C]--cache\f[R]: All downloaded dependencies will be deleted.
.PP
\f[C]--temp\f[R]: All alr-???.tmp files in the subtree will be deleted.
These files may remain when alr is interrupted via Ctrl-C or other
forceful means.
.SS \f[C]alr edit\f[R]
.SS SUMMARY
.PP
Start GNAT Studio with Alire build environment setup
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]edit\f[R] options
.SS OPTIONS
.PP
\f[C]--project=ARG\f[R] Select the project file to open if the crate
provides multiple project files, ignored otherwise
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Start GNAT Studio with Alire build environment setup.
.SS \f[C]alr exec\f[R]
.SS SUMMARY
.PP
Run the given command in the alire project context
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]exec\f[R] options [-P?] [\[en]] []
.SS OPTIONS
.PP
\f[C]-P[ARG]\f[R] Add \[lq]-P \[rq] to the command switches
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Alr sets up the environment variables (GPR_PROJECT_PATH, PATH, etc.) and
then spawns the given command.
.PP
This can be used to run tools or scripts on Alire projects.
.PP
The \[lq]-P\[rq] switch can be used to ask Alire to insert a \[lq]-P
\[rq] switch to the command arguments.
\[lq]-P\[rq] takes an optional position argument to specify where to
insert the extra switch.
\[lq]-P1\[rq] means first position, \[lq]-P2\[rq] second position, etc.
\[lq]-P-1\[rq] means last position, \[lq]-P-2\[rq] penultimate position,
etc.
\[lq]-P\[rq] equals \[lq]-P1\[rq].
For example \[lq]alr exec -P2 \[en] python3 main.py arg1\[rq] will run
the following command: [\[lq]python3\[rq], \[lq]main.py\[rq],
\[lq]-P\[rq], \[lq]crate.gpr\[rq], \[lq]arg1\[rq]]
.SS \f[C]alr init\f[R]
.SS SUMMARY
.PP
Create a new crate for an executable or library
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]init\f[R] options {\[en]bin|\[en]lib}
.SS OPTIONS
.PP
\f[C]--bin\f[R] New project is an executable
.PD 0
.P
.PD
\f[C]--lib\f[R] New project is a library
.PD 0
.P
.PD
\f[C]--in-place\f[R] Create alr files in current folder
.PD 0
.P
.PD
\f[C]--no-skel\f[R] Do not generate non-alire skeleton files
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Initializes a new crate containing a ready-to-build GNAT project.
The crate is created as a child of the current directory, containing
minimal sources for an executable or library, as specified.
.PP
\f[C]--in-place\f[R] is intended to be used inside the crate directory.
.SS \f[C]alr pin\f[R]
.SS SUMMARY
.PP
Pin dependencies to exact versions
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]pin\f[R] options [[crate[=]] | crate \[en]use=
[\[en]commit=REF] [\[en]branch=NAME] | \[en]all]
.SS OPTIONS
.PP
\f[C]--all\f[R] Pin the complete solution
.PD 0
.P
.PD
\f[C]--unpin\f[R] Unpin a release
.PD 0
.P
.PD
\f[C]--branch=NAME\f[R] Branch to be tracked in repository
.PD 0
.P
.PD
\f[C]--commit=REF\f[R] Reference to be retrieved from repository
.PD 0
.P
.PD
\f[C]--use=PATH|URL\f[R] Use a directory or repository to fulfill a
dependency
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Pin releases to a particular version.
By default, the current solution version is used.
A pinned release is not affected by automatic updates.
.PP
Without arguments, show existing pins.
.PP
Use \f[C]--all\f[R] to pin the whole current solution.
.PP
Specify a single crate to modify its pin.
.PP
Use the \f[C]--use\f[R] <PATH|URL> switch to use the target to fulfill a
dependency locally instead of looking for indexed releases.
An optional reference can be specified with \f[C]--commit\f[R]; the pin
will be frozen at the commit currently matching the reference.
Alternatively, a branch to track can be specified with
\f[C]--branch\f[R].
Use \f[C]alr update\f[R] to refresh the tracking pin contents.
.SS \f[C]alr printenv\f[R]
.SS SUMMARY
.PP
Print the build environment variables
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]printenv\f[R] options
.SS OPTIONS
.PP
\f[C]--details\f[R] Print details about the environment variables and
their origin \f[C]--unix\f[R] Use a UNIX shell format for the export
(default)
.PD 0
.P
.PD
\f[C]--powershell\f[R] Use a Windows PowerShell format for the export
.PD 0
.P
.PD
\f[C]--wincmd\f[R] Use a Windows CMD shell format for the export
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Print the environment variables used to build the crate.
This command can be used to setup a build environment, for instance
before starting an IDE.
.PP
Examples: - eval $(alr printenv \f[C]--unix\f[R]) - alr printenv
\f[C]--powershell\f[R] | Invoke-Expression
.SS \f[C]alr run\f[R]
.SS SUMMARY
.PP
Launch an executable built by the crate
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]run\f[R] options [executable] [\[en]args=ARGS]
[\[en]skip-build] | [\[en]list]
.SS OPTIONS
.PP
\f[C]-a\f[R] (\[en]args=ARGS) Arguments to pass through (quote them if
more than one) \f[C]--list\f[R] List executables produced by current
release
.PD 0
.P
.PD
\f[C]-s\f[R] (\[en]skip-build) Skip building step
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Compiles the crate (unless \f[C]--skip-build\f[R] is specified) and then
executes the default or given resulting executable.
.PP
With \f[C]--list\f[R], a list of declared executables is produced
instead of invoking the compiler, and its location (if already built) is
given.
.SS \f[C]alr update\f[R]
.SS SUMMARY
.PP
Update some or all dependencies to a newer version
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]update\f[R] options [crate]\&...
.SS OPTIONS
.PP
\f[C]--online\f[R] Fetch index updates before attempting crate updates
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Resolves unpinned dependencies using available indexes.
.PP
Invoked without arguments will consider all unpinned crates for
updating.
.PP
One or more crates can be given as argument, in which case only these
crates will be candidates for updating.
Requesting the update of a pinned crate is not allowed.
.SS \f[C]alr with\f[R]
.SS SUMMARY
.PP
Add or remove dependencies
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]with\f[R] options [{ [\[en]del] [versions]\&... |
\[en]from \&... | [versions] \[en]use [\[en]commit REF] [\[en]branch
NAME]} ] | \[en]solve | \[en]tree | \[en]versions
.SS OPTIONS
.PP
\f[C]--del\f[R] Remove given dependencies
.PD 0
.P
.PD
\f[C]--from\f[R] Use dependencies declared within GPR project file
\f[C]--graph\f[R] Show ASCII graph of dependencies
.PD 0
.P
.PD
\f[C]--branch=NAME\f[R] Branch to track in repository
.PD 0
.P
.PD
\f[C]--commit=REF\f[R] Commit to retrieve from repository
.PD 0
.P
.PD
\f[C]--use=PATH|URL\f[R] Add a dependency pinned to some external source
.PD 0
.P
.PD
\f[C]--solve\f[R] Show complete solution to dependencies
.PD 0
.P
.PD
\f[C]--tree\f[R] Show complete dependency tree
.PD 0
.P
.PD
\f[C]--versions\f[R] Show version status of dependencies
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Inspect and manage dependencies.
.IP \[bu] 2
Inspecting dependencies: Run without arguments prints current
dependencies.
Use \f[C]--solve\f[R] to print the solution in use for these
dependencies.
.IP \[bu] 2
Adding dependencies from the command line: Dependencies are added by
giving their name, and removed by using the \f[C]--del\f[R] flag.
Dependencies cannot be simultaneously added and removed in a single
invocation.
.IP \[bu] 2
Adding dependencies pinned to external sources: When a single crate name
is accompanied by an \f[C]--use\f[R] PATH|URL argument, the crate is
always fulfilled for any required version by the sources found at the
given target.
An optional reference can be specified with \f[C]--commit\f[R]; the pin
will be frozen at the commit currently matching the reference.
Alternatively, a branch to track can be specified with
\f[C]--branch\f[R].
Use \f[C]alr     update\f[R] to refresh the tracking pin contents.
.IP \[bu] 2
Adding dependencies from a GPR file: The project file given with
\f[C]--from\f[R] will be scanned looking for comments that contain the
sequence `alr with'.
These will be processed individually as if they had been given in the
command line, starting with no dependencies.
That is, only dependencies given in the GPR file will be preserved.
.PP
Example of GPR file contents:
.PP
with \[lq]libhello\[rq]; \[en] alr with libhello
.PP
Version selection syntax (global policy applies within the allowed
version subsets):
.PP
crate Newest/oldest version crate=version Exact version
crate\[ha]version Major-compatible version crate\[ti]version
Minor-compatible version
.SH Testing Commands
.SS \f[C]alr action\f[R]
.SS SUMMARY
.PP
List or manually trigger action hooks
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]action\f[R] options
[post-fetch|pre-build|post-build|test]
.SS OPTIONS
.PP
\f[C]-r\f[R] (\[en]recursive) List or trigger actions also in
dependencies
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
List or manually trigger action hooks.
.SS \f[C]alr dev\f[R]
.SS SUMMARY
.PP
Developer helpers
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]dev\f[R] options
.SS OPTIONS
.PP
\f[C]--custom\f[R] Execute current custom code
.PD 0
.P
.PD
\f[C]--filter\f[R] Used by scope filtering test
.PD 0
.P
.PD
\f[C]--raise\f[R] Raise an exception
.PD 0
.P
.PD
\f[C]--test\f[R] Run self-tests
.PD 0
.P
.PD
\f[C]--utf8\f[R] Print a known UTF-8 sequence
.PD 0
.P
.PD
\f[C]--markdown-help\f[R] Print help pages in markdown format
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Internal command for development help.
Options and features are not stable and may change without warning.
.SS \f[C]alr test\f[R]
.SS SUMMARY
.PP
Test the compilation of all or some releases
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]test\f[R] options [crate[versions]]\&...
.SS OPTIONS
.PP
\f[C]--continue\f[R] Skip testing of releases already in folder
.PD 0
.P
.PD
\f[C]--full\f[R] Test all indexed crates
.PD 0
.P
.PD
\f[C]--newest\f[R] Test only the newest release in crates
.PD 0
.P
.PD
\f[C]--redo\f[R] Retest releases already in folder (implies
\[en]continue)
.PD 0
.P
.PD
\f[C]--search\f[R] Interpret arguments as substrings instead of exact
crate names
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Tests the retrievability and buildability of all or specific releases.
Unless \f[C]--continue\f[R] or \f[C]--redo\f[R] is given, the command
expects to be run in an empty folder.
.PP
After completion, a report in text, markup and junit format will be
available in the current directory.
A complete log of each release building process will be available in
respective /alire/alr_test.log files.
.PP
Version selection syntax (global policy applies within the allowed
version subsets):
.PP
crate Newest/oldest version crate=version Exact version
crate\[ha]version Major-compatible version crate\[ti]version
Minor-compatible version
.SH Publish Commands
.SS \f[C]alr publish\f[R]
.SS SUMMARY
.PP
Help publishing a new version of a crate
.SS USAGE
.PP
\f[I]alr\f[R] \f[I]publish\f[R] options [\[en]skip-build]
[\[en]skip-submit] [\[en]tar] [\[en]manifest ] [ [commit]]]
[\[en]request-review NUM]
.SS OPTIONS
.PP
\f[C]--manifest=ARG\f[R] Selects a manifest file other than ./alire.toml
.PD 0
.P
.PD
\f[C]--skip-build\f[R] Skip the build check step
.PD 0
.P
.PD
\f[C]--skip-submit\f[R] Do not create the online pull request onto the
community index
.PD 0
.P
.PD
\f[C]--cancel=NUM\f[R] Prematurely close a pull request without waiting
for the merge
.PD 0
.P
.PD
\f[C]--reason=\[aq]short text\[aq]\f[R] Give a message for the record on
why the PR is being closed
.PD 0
.P
.PD
\f[C]--request-review=NUM\f[R] Remove draft status from the pull request
and request a review
.PD 0
.P
.PD
\f[C]--status\f[R] Check the status of the last pull request for the
crate
.PD 0
.P
.PD
\f[C]--tar\f[R] Start the publishing assistant to create a source
archive from a local directory \f[C]--trusted-sites\f[R] Print a list of
trusted git repository sites
.SS GLOBAL OPTIONS
.PP
\f[C]-c\f[R] (\[en]config=ARG) Override configuration folder location
.PD 0
.P
.PD
\f[C]-f\f[R] (\[en]force) Keep going after a recoverable troublesome
situation
.PD 0
.P
.PD
\f[C]-h\f[R] (\[en]help) Display general or command-specific help
.PD 0
.P
.PD
\f[C]-n\f[R] (\[en]non-interactive) Assume default answers for all user
prompts
.PD 0
.P
.PD
\f[C]--no-color\f[R] Disables colors in output
.PD 0
.P
.PD
\f[C]--no-tty\f[R] Disables control characters in output
.PD 0
.P
.PD
\f[C]--prefer-oldest\f[R] Prefer oldest versions instead of newest when
resolving dependencies \f[C]--version\f[R] Displays version and exits
.PD 0
.P
.PD
\f[C]-q\f[R] Limit output to errors
.PD 0
.P
.PD
\f[C]-v\f[R] Be more verbose (use twice for extra detail)
.PD 0
.P
.PD
\f[C]-d\f[R] (\[en]debug[]) Enable debug-specific log messages
.SS DESCRIPTION
.PP
Checks a release and generates an index manifest
.PP
See full details at
.IP
.nf
\f[C]
https://github.com/alire-project/alire/blob/master/doc/publishing.md
\f[R]
.fi
.PP
URL is an optional path to a remote source archive, or a local or remote
git repository.
.PP
For the common use case of a github-hosted repository, issue
\f[C]alr publish\f[R] after committing and pushing the new release
version.
.PP
Use \f[C]--tar\f[R] to create a source archive ready to be uploaded.
.PP
Use \f[C]--manifest\f[R] to use metadata in a non-default file.
.PP
See the above link for help with other scenarios.
.SH Topics
.SS aliases
.SS User defined command aliases
.PP
Command aliases can be defined in local or global configuration.
.PP
For example the following command: \[lq]$ alr config \f[C]--set\f[R]
\f[C]--global\f[R] alias.graph `show \f[C]--graph\f[R]'\[rq] Defines a
global alias for the `show' command with a `\[en]graph' switch.
.PP
\[lq]$ alr graph\[rq] is equivalent to \[lq]alr show
\f[C]--graph\f[R]\[rq]
.SS identifiers
.SS Naming rules for crate and index names
.PP
Identifiers for crates and indexes must use lowercase alphanumeric
characters from the latin alphabet.
Underscores can also be used, except as the first character.
.PP
Length must be of 3 to 64 characters.
.SS toolchains
.SS Configuration and use of toolchains
.PP
Alire indexes binary releases of GNAT and gprbuild.
The compilers are indexed with their target name, e.g., gnat_native or
gnat_riscv_elf.
.PP
Use alr toolchain \f[C]--help\f[R] to obtain information about toolchain
management.
Alire can be configured to rely on a toolchain installed by the user in
the environment, or to use one of the indexed toolchains whenever
possible.
.PP
Some crates may override the default toolchain by specifying
dependencies on particular compiler crates, for example to use a
cross-compiler.
In this situation, a compiler already available (selected as default or
already installed) will take precedence over a compiler available in the
index.
.PP
See also https://alire.ada.dev/docs/#toolchains for additional details
about compiler dependencies and toolchain interactions.
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" lang="" xml:lang="">
<head>
  <meta charset="utf-8" />
  <meta name="generator" content="pandoc" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=yes" />
  <title>alr help</title>
  <style>
    code{white-space: pre-wrap;}
    span.smallcaps{font-variant: small-caps;}
    span.underline{text-decoration: underline;}
    div.column{display: inline-block; vertical-align: top; width: 50%;}
    div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;}
    ul.task-list{list-style: none;}
  </style>
</head>
<body>
<header id="title-block-header">
<h1 class="title">alr help</h1>
</header>
<h1 id="usage-help">Usage Help</h1>
<p>alr <em>2.0-dev</em></p>
<h3 id="usage">USAGE</h3>
<p><em>alr</em> <a href="#global-options-23">global options</a> <command> [command options] [<arguments>]</p>
<p><em>alr</em> <em>help</em> [<command>|<topic>]</p>
<h3 id="arguments">ARGUMENTS</h3>
<p><code>&lt;command&gt;</code> Command to execute<br />
<code>&lt;arguments&gt;</code> List of arguments for the command</p>
<h3 id="global-options">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="commands">COMMANDS</h3>
<p><em>General</em><br />
<code>help</code> Shows help on the given command/topic<br />
<code>config</code> List, Get, Set or Unset configuration options<br />
<code>install</code> Manage installation prefixes<br />
<code>toolchain</code> Manage Alire-provided toolchains<br />
<code>version</code> Show detailed version, configuration, and environment information</p>
<p><em>Index</em><br />
<code>get</code> Fetch a published crate<br />
<code>index</code> Manage indexes used by current configuration<br />
<code>search</code> Search for a string in names and properties of crates<br />
<code>show</code> Display information about a crate version</p>
<p><em>Crate</em><br />
<code>build</code> Build the library or executables of the crate<br />
<code>clean</code> Clean generated files or downloaded dependencies<br />
<code>edit</code> Start GNAT Studio with Alire build environment setup<br />
<code>exec</code> Run the given command in the alire project context<br />
<code>init</code> Create a new crate for an executable or library<br />
<code>pin</code> Pin dependencies to exact versions<br />
<code>printenv</code> Print the build environment variables<br />
<code>run</code> Launch an executable built by the crate<br />
<code>update</code> Update some or all dependencies to a newer version<br />
<code>with</code> Add or remove dependencies</p>
<p><em>Testing</em><br />
<code>action</code> List or manually trigger action hooks<br />
<code>dev</code> Developer helpers<br />
<code>test</code> Test the compilation of all or some releases</p>
<p><em>Publish</em><br />
<code>publish</code> Help publishing a new version of a crate</p>
<h3 id="topics">TOPICS</h3>
<p><code>aliases</code> User defined command aliases<br />
<code>identifiers</code> Naming rules for crate and index names <code>toolchains</code> Configuration and use of toolchains<br />
### ALIASES <code>gnatcov</code> exec -P2 – gnatcov<br />
<code>gnatprove</code> exec -P1 – gnatprove</p>
<h1 id="general-commands">General Commands</h1>
<h2 id="alr-help"><code>alr help</code></h2>
<h3 id="summary">SUMMARY</h3>
<p>Shows help on the given command/topic</p>
<h3 id="usage-1">USAGE</h3>
<p><em>alr</em> <em>help</em> <a href="#options-20">options</a> [<command>|<topic>]</p>
<h3 id="global-options-1">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description">DESCRIPTION</h3>
<p>Shows information about commands and topics. See available commands with ‘alr help commands’ See available topics with ‘alr help topics’.</p>
<h2 id="alr-config"><code>alr config</code></h2>
<h3 id="summary-1">SUMMARY</h3>
<p>List, Get, Set or Unset configuration options</p>
<h3 id="usage-2">USAGE</h3>
<p><em>alr</em> <em>config</em> <a href="#options-20">options</a> [–list] [–show-origin] [key_regex] | –get <key> | –set <key> <value> | –unset <key></p>
<h3 id="options">OPTIONS</h3>
<p><code>--list</code> List configuration options<br />
<code>--show-origin</code> Show origin of configuration values in –list<br />
<code>--get</code> Print value of a configuration option<br />
<code>--set</code> Set a configuration option<br />
<code>--unset</code> Unset a configuration option<br />
<code>--global</code> Set and Unset global configuration instead of the local one <code>--builtins-doc</code> Print Markdown list of built-in configuration options</p>
<h3 id="global-options-2">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-1">DESCRIPTION</h3>
<p>Provides a command line interface to the Alire configuration option files.</p>
<p>Option names (keys) can use lowercase and uppercase alphanumeric characters from the Latin alphabet. Underscores and dashes can also be used except as first or last character. Dot ‘.’ is used to specify sub-categories, e.g. ‘user.name’ or ‘user.email’.</p>
<p>Option values can be integers, float, Boolean (true or false) or strings. The type detection is automatic, e.g. 10 is integer, 10.1 is float, true is Boolean. You can force a value to be set a string by using double-quotes, e.g. “10.1” or “true”. Extra type checking is used for built-in options (see below).</p>
<p>Built-in configuration options:</p>
<ul>
<li><p>dependencies.shared [Boolean][Default:FALSE] When true, dependencies are downloaded and built in a shared location inside the global cache. When false, dependencies are sandboxed in each workspace.</p></li>
<li><p>distribution.disable_detection [Boolean][Default:FALSE] If true, Alire will report an unknown distribution and will not attempt to use the system package manager.</p></li>
<li><p>editor.cmd [String][Default:gnatstudio -P ${GPR_FILE}] Editor command and arguments for editing crate code (alr edit). The executables and arguments are separated by a single space character. The token ${GPR_FILE} is replaced by a path to the project file to open.</p></li>
<li><p>index.auto_community [Boolean][Default:TRUE] When unset or true, the community index will be added automatically when required if no other index is configured.</p></li>
<li><p>index.host [String][Default:https://github.com] URL of the community index host</p></li>
<li><p>index.owner [String][Default:alire-project] Owner of the index repository (GitHub user/org).</p></li>
<li><p>index.repository_name [String][Default:alire-index] Name of the index repository.</p></li>
<li><p>solver.autonarrow [Boolean][Default:TRUE] If true, <code>alr with</code> will replace ‘any’ dependencies with the appropriate caret/tilde dependency.</p></li>
<li><p>toolchain.assistant [Boolean][Default:TRUE] If true, and assistant to select the default toolchain will run when first needed.</p></li>
<li><p>update.manually_only [Boolean][Default:FALSE] If true, Alire will not attempt to update dependencies even after the manifest is manually edited, or when no valid solution has been ever computed. All updates have to be manually requested through <code>alr update</code></p></li>
<li><p>user.email [Email address][Default:] User email address. Used for the authors and maintainers field of a new crate.</p></li>
<li><p>user.github_login [GitHub login][Default:] User GitHub login/username. Used to for the maintainers-logins field of a new crate.</p></li>
<li><p>user.name [String][Default:] User full name. Used for the authors and maintainers field of a new crate.</p></li>
<li><p>warning.caret [Boolean][Default:TRUE] If true, Alire will warn about the use of caret (^) for pre-1 dependencies, for which tilde (~) is recommended instead.</p></li>
<li><p>warning.old_index [Boolean][Default:TRUE] If unset or true, a warning will be emitted when using a compatible index with a lower version than the newest known.</p></li>
</ul>
<h2 id="alr-install"><code>alr install</code></h2>
<h3 id="summary-2">SUMMARY</h3>
<p>Manage installation prefixes</p>
<h3 id="usage-3">USAGE</h3>
<p><em>alr</em> <em>install</em> <a href="#options-20">options</a> [[–info] | [crate[versions]]…]</p>
<h3 id="options-1">OPTIONS</h3>
<p><code>--prefix=ARG</code> Override installation prefix (default is ${CRATE_ROOT}/alire/prefix)) <code>--info</code> Show info about a installation prefix</p>
<h3 id="global-options-3">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-2">DESCRIPTION</h3>
<p>Manages installations of releases to a common prefix. The default install location is /home/mgr/.alire</p>
<p>Installation prefixes are intended to make binaries or dynamic libraries available outside of the Alire environment, normally by adding the <prefix>/bin folder to the user’s path.</p>
<p>Although Alire will vet trivially detectable conflicts (e.g., trying to install two executable release with different versions), Alire is not aware of the exact binary artifacts produced by compiled crates. Thus, you are “on your own” in regard to the final consistency of installations.</p>
<p>That said, binary crates from the Alire project (gnat, gnatprove, gprbuild), as well as crates initialized with <code>alr</code> using default templates, should be able to coexist in a same installation prefix without issue.</p>
<p>You can use the <code>--force</code> to reinstall already installed releases.</p>
<h2 id="alr-toolchain"><code>alr toolchain</code></h2>
<h3 id="summary-3">SUMMARY</h3>
<p>Manage Alire-provided toolchains</p>
<h3 id="usage-4">USAGE</h3>
<p><em>alr</em> <em>toolchain</em> <a href="#options-20">options</a> [-u|–uninstall] [-i|–install crate[version set]] | –select [–local] [releases] [–disable-assistant]</p>
<h3 id="options-2">OPTIONS</h3>
<p><code>--disable-assistant</code> Disable autorun of selection assistant<br />
<code>-i</code> (–install) Install one or more toolchain component<br />
<code>--install-dir=ARG</code> Toolchain component(s) installation directory<br />
<code>--local</code> Store toolchain configuration in local workspace <code>--select</code> Run the toolchain selection assistant<br />
<code>-u</code> (–uninstall) Uninstall one or more toolchain component</p>
<h3 id="global-options-4">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-3">DESCRIPTION</h3>
<p>Download toolchain elements, like GNAT and gprbuild, in the shared cache of the active configuration.</p>
<p>Run it without arguments to get a list of downloaded tools.</p>
<p>Use <code>--select</code> without arguments to run the assistant to select the default toolchain for this configuration. Adding <code>--local</code> will instead make the selection apply only to the workspace (overriding a possible configuration- wide selection). Giving one or more releases argument will skip the assistant and set the release as the default.</p>
<p>Specify <code>--install/--uninstall</code> and one or more crates name with optional version set to make available or remove a tool.</p>
<p>Run <code>alr help toolchains</code> for further information about toolchain management and use.</p>
<h2 id="alr-version"><code>alr version</code></h2>
<h3 id="summary-4">SUMMARY</h3>
<p>Show detailed version, configuration, and environment information</p>
<h3 id="usage-5">USAGE</h3>
<p><em>alr</em> <em>version</em> <a href="#options-20">options</a></p>
<h3 id="global-options-5">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-4">DESCRIPTION</h3>
<p>Shows assorted metadata about the alr executable, and about the crate or sandbox found in the current directory, if any.</p>
<h1 id="index-commands">Index Commands</h1>
<h2 id="alr-get"><code>alr get</code></h2>
<h3 id="summary-5">SUMMARY</h3>
<p>Fetch a published crate</p>
<h3 id="usage-6">USAGE</h3>
<p><em>alr</em> <em>get</em> <a href="#options-20">options</a> <crate>[allowed versions]</p>
<h3 id="options-3">OPTIONS</h3>
<p><code>-b</code> (–build) Build after download<br />
<code>--dirname</code> Display deployment folder<br />
<code>-o</code> (–only) Retrieve requested crate only, without dependencies</p>
<h3 id="global-options-6">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-5">DESCRIPTION</h3>
<p>Retrieve a crate, in the case of regular ones, or install a system package provided by the platform. A regular crate is deployed under an immediate folder with naming ‘name_version_hash’.</p>
<p>Version selection syntax (global policy applies within the allowed version subsets):</p>
<p>crate Newest/oldest version crate=version Exact version crate^version Major-compatible version crate~version Minor-compatible version</p>
<h2 id="alr-index"><code>alr index</code></h2>
<h3 id="summary-6">SUMMARY</h3>
<p>Manage indexes used by current configuration</p>
<h3 id="usage-7">USAGE</h3>
<p><em>alr</em> <em>index</em> <a href="#options-20">options</a> –add <url> –name <name> [–before <name>] | –del <name> | [–list] | –update-all | –check</p>
<h3 id="options-4">OPTIONS</h3>
<p><code>--add=URL</code> Add an index<br />
<code>--before=NAME</code> Priority order (defaults to last)<br />
<code>--check</code> Runs diagnostics on index contents (unknown values, hosts, etc.) <code>--del=NAME</code> Remove an index<br />
<code>--list</code> List configured indexes (default)<br />
<code>--name=NAME</code> User given name for the index<br />
<code>--update-all</code> Update configured indexes<br />
<code>--reset-community</code> Add the community index, or reset any local changes</p>
<h3 id="global-options-7">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-6">DESCRIPTION</h3>
<p>Add, remove, list and update indexes used by the current alr configuration.</p>
<p>Updating applies only to repository-stored indexes, in which case a pull operation will be performed on them. An index initially set up with a specific commit will not be updated.</p>
<h2 id="alr-search"><code>alr search</code></h2>
<h3 id="summary-7">SUMMARY</h3>
<p>Search for a string in names and properties of crates</p>
<h3 id="usage-8">USAGE</h3>
<p><em>alr</em> <em>search</em> <a href="#options-20">options</a> <search term> | [–crates] [–full] –list</p>
<h3 id="options-5">OPTIONS</h3>
<p><code>--crates</code> Restrict search and output to crate names and descriptions <code>--external-detect</code> Detect externally-provided releases (implies –external)<br />
<code>--full</code> Show all versions of a crate (newest only otherwise)<br />
<code>--list</code> List all available releases<br />
<code>--external</code> Include externally-provided releases in search<br />
<code>--property=TEXT</code> Search TEXT in property values</p>
<h3 id="global-options-8">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-7">DESCRIPTION</h3>
<p>Searches the given substring in crate names (or properties with <code>--    property</code>), and shows the most recent release of matching crates (unless <code>--    full</code> is specified).</p>
<p>Use <code>--crates</code> to get a simple list of only crate names and descriptions. Otherwise, besides version, description and release notes, a status column with the following status flags is provided:</p>
<p>E: the release is externally provided. S: the release is available through a system package. U: the release is not available in the current platform. X: the release has dependencies that cannot be resolved.</p>
<p>The reasons for unavailability (U) can be ascertained with ‘alr show <crate>=<version>’.</p>
<p>Unresolvable releases (X) should not happen in platforms with assigned maintainers. Common reasons are missing system dependencies that have been phased out by the platform without being updated yet in the community index.</p>
<h2 id="alr-show"><code>alr show</code></h2>
<h3 id="summary-8">SUMMARY</h3>
<p>Display information about a crate version</p>
<h3 id="usage-9">USAGE</h3>
<p><em>alr</em> <em>show</em> <a href="#options-20">options</a> [<crate>[allowed versions]] [–system] [–external[-detect]] | –graph | –jekyll | –solve | –tree | –nested| –dependents[=direct|shortest|all]</p>
<h3 id="options-6">OPTIONS</h3>
<p><code>--dependents[=ARG]</code> Show dependent crates (ARG=direct|shortest|all) <code>--detail</code> Show additional details about dependencies<br />
<code>--external-detect</code> Add detected externals to available releases<br />
<code>--external</code> Show info about external definitions for a crate <code>--graph</code> Print ASCII graph of dependencies<br />
<code>--system</code> Show info relevant to current environment<br />
<code>--solve</code> Solve dependencies and report<br />
<code>--tree</code> Show complete dependency tree<br />
<code>--jekyll</code> Enable Jekyll output format<br />
<code>--nested</code> Show info on nested crates</p>
<h3 id="global-options-9">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-8">DESCRIPTION</h3>
<p>Shows information found in the loaded indexes about a specific release (see below to narrow the searched milestones). By default, only direct dependencies are reported. With <code>--solve</code>, a full solution is resolved and reported in list and graph form.</p>
<p>With <code>--external</code>, the external definitions for a crate are shown, instead of information about a particular release</p>
<p>The <code>--dependents</code> switch accepts these values: * direct (default) shows direct dependents. * all shows all dependents, including indirect ones, and all dependency chains. * shortest shows all dependents, including indirect ones, but only once, and a shortest-length chain.</p>
<p>Version selection syntax (global policy applies within the allowed version subsets):</p>
<p>crate Newest/oldest version crate=version Exact version crate^version Major-compatible version crate~version Minor-compatible version</p>
<h1 id="crate-commands">Crate Commands</h1>
<h2 id="alr-build"><code>alr build</code></h2>
<h3 id="summary-9">SUMMARY</h3>
<p>Build the library or executables of the crate</p>
<h3 id="usage-10">USAGE</h3>
<p><em>alr</em> <em>build</em> <a href="#options-20">options</a> [–] [gprbuild switches and arguments]</p>
<h3 id="options-7">OPTIONS</h3>
<p><code>--release</code> Set root build profile to Release<br />
<code>--validation</code> Set root build profile to Validation<br />
<code>--development</code> Set root build profile to Development (default)<br />
<code>--profiles=ARG</code> Comma-separated list of <crate>=<profile> values (see description)</p>
<h3 id="global-options-10">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-9">DESCRIPTION</h3>
<p>Invokes gprbuild to compile all targets in the current crate.</p>
<p>A build profile can be selected with the appropriate switch. The profile is applied to the root release only, whereas dependencies are built in release mode. Use <code>--profiles</code> for more overrides.</p>
<p><code>--profiles=*|%|&lt;crate1&gt;=&lt;profile&gt;[,&lt;crate2&gt;=&lt;profile</code>&gt;…] Apply profiles to individual crates. Use *=<profile> to set all profiles. Use %=<profile> to set profiles of crates without a setting in a manifest only.</p>
<p>Running ‘alr build’ without profile switches defaults to development (root crate) + release (dependencies). Indirect builds through, e.g., ‘alr run’ will use the last ‘alr build’ configuration.</p>
<h2 id="alr-clean"><code>alr clean</code></h2>
<h3 id="summary-10">SUMMARY</h3>
<p>Clean generated files or downloaded dependencies</p>
<h3 id="usage-11">USAGE</h3>
<p><em>alr</em> <em>clean</em> <a href="#options-20">options</a> [–cache] [–temp] [–] [gprclean switches and arguments]</p>
<h3 id="options-8">OPTIONS</h3>
<p><code>--cache</code> Delete cache of releases<br />
<code>--temp</code> Delete dangling temporary files</p>
<h3 id="global-options-11">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-10">DESCRIPTION</h3>
<p>no options: gprclean -r will be called to clean up the build environment.</p>
<p><code>--cache</code>: All downloaded dependencies will be deleted.</p>
<p><code>--temp</code>: All alr-???.tmp files in the subtree will be deleted. These files may remain when alr is interrupted via Ctrl-C or other forceful means.</p>
<h2 id="alr-edit"><code>alr edit</code></h2>
<h3 id="summary-11">SUMMARY</h3>
<p>Start GNAT Studio with Alire build environment setup</p>
<h3 id="usage-12">USAGE</h3>
<p><em>alr</em> <em>edit</em> <a href="#options-20">options</a></p>
<h3 id="options-9">OPTIONS</h3>
<p><code>--project=ARG</code> Select the project file to open if the crate provides multiple project files, ignored otherwise</p>
<h3 id="global-options-12">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-11">DESCRIPTION</h3>
<p>Start GNAT Studio with Alire build environment setup.</p>
<h2 id="alr-exec"><code>alr exec</code></h2>
<h3 id="summary-12">SUMMARY</h3>
<p>Run the given command in the alire project context</p>
<h3 id="usage-13">USAGE</h3>
<p><em>alr</em> <em>exec</em> <a href="#options-20">options</a> [-P?] [–] <executable/script> [<switches and arguments>]</p>
<h3 id="options-10">OPTIONS</h3>
<p><code>-P[ARG]</code> Add “-P <PROJECT_FILE>” to the command switches</p>
<h3 id="global-options-13">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-12">DESCRIPTION</h3>
<p>Alr sets up the environment variables (GPR_PROJECT_PATH, PATH, etc.) and then spawns the given command.</p>
<p>This can be used to run tools or scripts on Alire projects.</p>
<p>The “-P” switch can be used to ask Alire to insert a “-P <PROJECT_FILE>” switch to the command arguments. “-P” takes an optional position argument to specify where to insert the extra switch. “-P1” means first position, “-P2” second position, etc. “-P-1” means last position, “-P-2” penultimate position, etc. “-P” equals “-P1”. For example “alr exec -P2 – python3 main.py arg1” will run the following command: [“python3”, “main.py”, “-P”, “crate.gpr”, “arg1”]</p>
<h2 id="alr-init"><code>alr init</code></h2>
<h3 id="summary-13">SUMMARY</h3>
<p>Create a new crate for an executable or library</p>
<h3 id="usage-14">USAGE</h3>
<p><em>alr</em> <em>init</em> <a href="#options-20">options</a> {–bin|–lib} <crate name></p>
<h3 id="options-11">OPTIONS</h3>
<p><code>--bin</code> New project is an executable<br />
<code>--lib</code> New project is a library<br />
<code>--in-place</code> Create alr files in current folder<br />
<code>--no-skel</code> Do not generate non-alire skeleton files</p>
<h3 id="global-options-14">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-13">DESCRIPTION</h3>
<p>Initializes a new crate containing a ready-to-build GNAT project. The crate is created as a child of the current directory, containing minimal sources for an executable or library, as specified.</p>
<p><code>--in-place</code> is intended to be used inside the crate directory.</p>
<h2 id="alr-pin"><code>alr pin</code></h2>
<h3 id="summary-14">SUMMARY</h3>
<p>Pin dependencies to exact versions</p>
<h3 id="usage-15">USAGE</h3>
<p><em>alr</em> <em>pin</em> <a href="#options-20">options</a> [[crate[=<version>]] | crate –use=<path> [–commit=REF] [–branch=NAME] | –all]</p>
<h3 id="options-12">OPTIONS</h3>
<p><code>--all</code> Pin the complete solution<br />
<code>--unpin</code> Unpin a release<br />
<code>--branch=NAME</code> Branch to be tracked in repository<br />
<code>--commit=REF</code> Reference to be retrieved from repository<br />
<code>--use=PATH|URL</code> Use a directory or repository to fulfill a dependency</p>
<h3 id="global-options-15">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-14">DESCRIPTION</h3>
<p>Pin releases to a particular version. By default, the current solution version is used. A pinned release is not affected by automatic updates.</p>
<p>Without arguments, show existing pins.</p>
<p>Use <code>--all</code> to pin the whole current solution.</p>
<p>Specify a single crate to modify its pin.</p>
<p>Use the <code>--use</code> &lt;PATH|URL&gt; switch to use the target to fulfill a dependency locally instead of looking for indexed releases. An optional reference can be specified with <code>--commit</code>; the pin will be frozen at the commit currently matching the reference. Alternatively, a branch to track can be specified with <code>--branch</code>. Use <code>alr update</code> to refresh the tracking pin contents.</p>
<h2 id="alr-printenv"><code>alr printenv</code></h2>
<h3 id="summary-15">SUMMARY</h3>
<p>Print the build environment variables</p>
<h3 id="usage-16">USAGE</h3>
<p><em>alr</em> <em>printenv</em> <a href="#options-20">options</a></p>
<h3 id="options-13">OPTIONS</h3>
<p><code>--details</code> Print details about the environment variables and their origin <code>--unix</code> Use a UNIX shell format for the export (default)<br />
<code>--powershell</code> Use a Windows PowerShell format for the export<br />
<code>--wincmd</code> Use a Windows CMD shell format for the export</p>
<h3 id="global-options-16">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-15">DESCRIPTION</h3>
<p>Print the environment variables used to build the crate. This command can be used to setup a build environment, for instance before starting an IDE.</p>
<p>Examples: - eval $(alr printenv <code>--unix</code>) - alr printenv <code>--powershell</code> | Invoke-Expression</p>
<h2 id="alr-run"><code>alr run</code></h2>
<h3 id="summary-16">SUMMARY</h3>
<p>Launch an executable built by the crate</p>
<h3 id="usage-17">USAGE</h3>
<p><em>alr</em> <em>run</em> <a href="#options-20">options</a> [executable] [–args=ARGS] [–skip-build] | [–list]</p>
<h3 id="options-14">OPTIONS</h3>
<p><code>-a</code> (–args=ARGS) Arguments to pass through (quote them if more than one) <code>--list</code> List executables produced by current release<br />
<code>-s</code> (–skip-build) Skip building step</p>
<h3 id="global-options-17">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-16">DESCRIPTION</h3>
<p>Compiles the crate (unless <code>--skip-build</code> is specified) and then executes the default or given resulting executable.</p>
<p>With <code>--list</code>, a list of declared executables is produced instead of invoking the compiler, and its location (if already built) is given.</p>
<h2 id="alr-update"><code>alr update</code></h2>
<h3 id="summary-17">SUMMARY</h3>
<p>Update some or all dependencies to a newer version</p>
<h3 id="usage-18">USAGE</h3>
<p><em>alr</em> <em>update</em> <a href="#options-20">options</a> [crate]…</p>
<h3 id="options-15">OPTIONS</h3>
<p><code>--online</code> Fetch index updates before attempting crate updates</p>
<h3 id="global-options-18">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-17">DESCRIPTION</h3>
<p>Resolves unpinned dependencies using available indexes.</p>
<p>Invoked without arguments will consider all unpinned crates for updating.</p>
<p>One or more crates can be given as argument, in which case only these crates will be candidates for updating. Requesting the update of a pinned crate is not allowed.</p>
<h2 id="alr-with"><code>alr with</code></h2>
<h3 id="summary-18">SUMMARY</h3>
<p>Add or remove dependencies</p>
<h3 id="usage-19">USAGE</h3>
<p><em>alr</em> <em>with</em> <a href="#options-20">options</a> [{ [–del] <crate>[versions]… | –from <gpr_file>… | <crate>[versions] –use <path> [–commit REF] [–branch NAME]} ] | –solve | –tree | –versions</p>
<h3 id="options-16">OPTIONS</h3>
<p><code>--del</code> Remove given dependencies<br />
<code>--from</code> Use dependencies declared within GPR project file <code>--graph</code> Show ASCII graph of dependencies<br />
<code>--branch=NAME</code> Branch to track in repository<br />
<code>--commit=REF</code> Commit to retrieve from repository<br />
<code>--use=PATH|URL</code> Add a dependency pinned to some external source<br />
<code>--solve</code> Show complete solution to dependencies<br />
<code>--tree</code> Show complete dependency tree<br />
<code>--versions</code> Show version status of dependencies</p>
<h3 id="global-options-19">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-18">DESCRIPTION</h3>
<p>Inspect and manage dependencies.</p>
<ul>
<li><p>Inspecting dependencies: Run without arguments prints current dependencies. Use <code>--solve</code> to print the solution in use for these dependencies.</p></li>
<li><p>Adding dependencies from the command line: Dependencies are added by giving their name, and removed by using the <code>--del</code> flag. Dependencies cannot be simultaneously added and removed in a single invocation.</p></li>
<li><p>Adding dependencies pinned to external sources: When a single crate name is accompanied by an <code>--use</code> PATH|URL argument, the crate is always fulfilled for any required version by the sources found at the given target. An optional reference can be specified with <code>--commit</code>; the pin will be frozen at the commit currently matching the reference. Alternatively, a branch to track can be specified with <code>--branch</code>. Use <code>alr     update</code> to refresh the tracking pin contents.</p></li>
<li><p>Adding dependencies from a GPR file: The project file given with <code>--from</code> will be scanned looking for comments that contain the sequence ‘alr with’. These will be processed individually as if they had been given in the command line, starting with no dependencies. That is, only dependencies given in the GPR file will be preserved.</p></li>
</ul>
<p>Example of GPR file contents:</p>
<p>with “libhello”; – alr with libhello</p>
<p>Version selection syntax (global policy applies within the allowed version subsets):</p>
<p>crate Newest/oldest version crate=version Exact version crate^version Major-compatible version crate~version Minor-compatible version</p>
<h1 id="testing-commands">Testing Commands</h1>
<h2 id="alr-action"><code>alr action</code></h2>
<h3 id="summary-19">SUMMARY</h3>
<p>List or manually trigger action hooks</p>
<h3 id="usage-20">USAGE</h3>
<p><em>alr</em> <em>action</em> <a href="#options-20">options</a> [post-fetch|pre-build|post-build|test]</p>
<h3 id="options-17">OPTIONS</h3>
<p><code>-r</code> (–recursive) List or trigger actions also in dependencies</p>
<h3 id="global-options-20">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-19">DESCRIPTION</h3>
<p>List or manually trigger action hooks.</p>
<h2 id="alr-dev"><code>alr dev</code></h2>
<h3 id="summary-20">SUMMARY</h3>
<p>Developer helpers</p>
<h3 id="usage-21">USAGE</h3>
<p><em>alr</em> <em>dev</em> <a href="#options-20">options</a></p>
<h3 id="options-18">OPTIONS</h3>
<p><code>--custom</code> Execute current custom code<br />
<code>--filter</code> Used by scope filtering test<br />
<code>--raise</code> Raise an exception<br />
<code>--test</code> Run self-tests<br />
<code>--utf8</code> Print a known UTF-8 sequence<br />
<code>--markdown-help</code> Print help pages in markdown format</p>
<h3 id="global-options-21">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-20">DESCRIPTION</h3>
<p>Internal command for development help. Options and features are not stable and may change without warning.</p>
<h2 id="alr-test"><code>alr test</code></h2>
<h3 id="summary-21">SUMMARY</h3>
<p>Test the compilation of all or some releases</p>
<h3 id="usage-22">USAGE</h3>
<p><em>alr</em> <em>test</em> <a href="#options-20">options</a> [crate[versions]]…</p>
<h3 id="options-19">OPTIONS</h3>
<p><code>--continue</code> Skip testing of releases already in folder<br />
<code>--full</code> Test all indexed crates<br />
<code>--newest</code> Test only the newest release in crates<br />
<code>--redo</code> Retest releases already in folder (implies –continue)<br />
<code>--search</code> Interpret arguments as substrings instead of exact crate names</p>
<h3 id="global-options-22">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-21">DESCRIPTION</h3>
<p>Tests the retrievability and buildability of all or specific releases. Unless <code>--continue</code> or <code>--redo</code> is given, the command expects to be run in an empty folder.</p>
<p>After completion, a report in text, markup and junit format will be available in the current directory. A complete log of each release building process will be available in respective <release>/alire/alr_test.log files.</p>
<p>Version selection syntax (global policy applies within the allowed version subsets):</p>
<p>crate Newest/oldest version crate=version Exact version crate^version Major-compatible version crate~version Minor-compatible version</p>
<h1 id="publish-commands">Publish Commands</h1>
<h2 id="alr-publish"><code>alr publish</code></h2>
<h3 id="summary-22">SUMMARY</h3>
<p>Help publishing a new version of a crate</p>
<h3 id="usage-23">USAGE</h3>
<p><em>alr</em> <em>publish</em> <a href="#options-20">options</a> [–skip-build] [–skip-submit] [–tar] [–manifest <file>] [<URL> [commit]]] [–request-review NUM]</p>
<h3 id="options-20">OPTIONS</h3>
<p><code>--manifest=ARG</code> Selects a manifest file other than ./alire.toml<br />
<code>--skip-build</code> Skip the build check step<br />
<code>--skip-submit</code> Do not create the online pull request onto the community index<br />
<code>--cancel=NUM</code> Prematurely close a pull request without waiting for the merge<br />
<code>--reason='short text'</code> Give a message for the record on why the PR is being closed<br />
<code>--request-review=NUM</code> Remove draft status from the pull request and request a review<br />
<code>--status</code> Check the status of the last pull request for the crate<br />
<code>--tar</code> Start the publishing assistant to create a source archive from a local directory <code>--trusted-sites</code> Print a list of trusted git repository sites</p>
<h3 id="global-options-23">GLOBAL OPTIONS</h3>
<p><code>-c</code> (–config=ARG) Override configuration folder location<br />
<code>-f</code> (–force) Keep going after a recoverable troublesome situation<br />
<code>-h</code> (–help) Display general or command-specific help<br />
<code>-n</code> (–non-interactive) Assume default answers for all user prompts<br />
<code>--no-color</code> Disables colors in output<br />
<code>--no-tty</code> Disables control characters in output<br />
<code>--prefer-oldest</code> Prefer oldest versions instead of newest when resolving dependencies <code>--version</code> Displays version and exits<br />
<code>-q</code> Limit output to errors<br />
<code>-v</code> Be more verbose (use twice for extra detail)<br />
<code>-d</code> (–debug[]) Enable debug-specific log messages</p>
<h3 id="description-22">DESCRIPTION</h3>
<p>Checks a release and generates an index manifest</p>
<p>See full details at</p>
<pre><code>https://github.com/alire-project/alire/blob/master/doc/publishing.md</code></pre>
<p>URL is an optional path to a remote source archive, or a local or remote git repository.</p>
<p>For the common use case of a github-hosted repository, issue <code>alr publish</code> after committing and pushing the new release version.</p>
<p>Use <code>--tar</code> to create a source archive ready to be uploaded.</p>
<p>Use <code>--manifest</code> to use metadata in a non-default file.</p>
<p>See the above link for help with other scenarios.</p>
<h1 id="topics-1">Topics</h1>
<h2 id="aliases">aliases</h2>
<h3 id="user-defined-command-aliases">User defined command aliases</h3>
<p>Command aliases can be defined in local or global configuration.</p>
<p>For example the following command: “$ alr config <code>--set</code> <code>--global</code> alias.graph ‘show <code>--graph</code>’” Defines a global alias for the ‘show’ command with a ‘–graph’ switch.</p>
<p>“$ alr graph” is equivalent to “alr show <code>--graph</code></p>
<h2 id="identifiers">identifiers</h2>
<h3 id="naming-rules-for-crate-and-index-names">Naming rules for crate and index names</h3>
<p>Identifiers for crates and indexes must use lowercase alphanumeric characters from the latin alphabet. Underscores can also be used, except as the first character.</p>
<p>Length must be of 3 to 64 characters.</p>
<h2 id="toolchains">toolchains</h2>
<h3 id="configuration-and-use-of-toolchains">Configuration and use of toolchains</h3>
<p>Alire indexes binary releases of GNAT and gprbuild. The compilers are indexed with their target name, e.g., gnat_native or gnat_riscv_elf.</p>
<p>Use alr toolchain <code>--help</code> to obtain information about toolchain management. Alire can be configured to rely on a toolchain installed by the user in the environment, or to use one of the indexed toolchains whenever possible.</p>
<p>Some crates may override the default toolchain by specifying dependencies on particular compiler crates, for example to use a cross-compiler. In this situation, a compiler already available (selected as default or already installed) will take precedence over a compiler available in the index.</p>
<p>See also https://alire.ada.dev/docs/#toolchains for additional details about compiler dependencies and toolchain interactions.</p>
</body>
</html>

@mosteo
Copy link
Member

mosteo commented Oct 2, 2023

This has a positive (involuntary?) impact in the formatting of the markdown version. If this is considered valid also for the terminal, shouldn't this be standardized and use the same quoting for similar paragraphs containing natural language and command lines?

Yes, I started using the grave accents at some point for monospace things, e.g. terminal commands. But then, instead of putting the in there manually, they should be part of TTY.Terminal.

* Use `Formatter.Terminal` for command lines and switches not passed
  through `Hightlight_Switches`
* Avoid any <placeholder> which is not quoted as code
* Use consistent formatting for lists with "*" and not "-"
* Use indentation as a way to get preformat in appropriate cases
# Conflicts:
#	deps/clic
#	src/alr/alr-commands.ads
Add a new line before lists

* It can be read better in the terminal
* It make the list work with `pandoc`

Add new CLIC commit also for `pandoc`.
@mgrojo
Copy link
Contributor Author

mgrojo commented Oct 14, 2023

I've made an update to the three repositories to fix some of the problems that were still pending. Both the web and the pandoc output are working pretty well. See attached PDF and the PR alire-project/alire.ada.dev#32 for the web.
alr.pdf

There are still a pair of minor issues:

  • Some command lines (most of them examples) are not passed through Terminal to get a monospace font. The reason is that they don't interact well with the Highlight_Switches function which is calling Emph, which in turn also adds `code quotes`. I haven't found a way to solve this.
  • There's no alignment in list of options. The ideal solution would be to make AAA.Table_IO know how to print these tables in markdown, but the problem is that markdown tables are proper tables, with headings, borders and all the paraphernalia, so they're not for basic alignment. I don't know of any solution to get alignment besides full preformat, which will remove the distinction between switches and help line. See also this fix for a related problem. It could be reverted if a better solution for these tables is found. alire-project/clic@65b825b

You probably want to review the changes to the terminal output, just in case something is not of your liking. Most visible change is that the usage line has the Terminal color.

I don't know if I can fix the PR checks from my side, since it is related to the commits of the dependencies not being yet in your repositories.

Unless you have ideas about these points that I could include, the pull requests are ready for your review.

When the line has three digits, the space is not present.

Example:

[Alr.Commands.Dev.Execute] (alr-commands-dev.adb:32 ) debug: In dev --filter

versus

[Alr.Commands.Dev.Execute] (alr-commands-dev.adb:100) debug: In dev --filter
@mgrojo
Copy link
Contributor Author

mgrojo commented Oct 15, 2023

By the way, I just saw that the Debian distribution already has man pages for Alire. I don't know if their work is automatic or semi-automatic, but they have this note:

Generated with generate-man from Alire execution

https://manpages.debian.org/testing/alire/alr.1.en.html

I mention this because I was experimenting with tables, and it might be feasible to get markdown tables for alignment to work on Jekyll but not for pandoc at the same time, unless headers are added to them. The reason is that markdown is not a fully defined standard, after all.

For example, this table without actual header works on Jekyll, but not on pandoc (or github).

### OPTIONS

|`--list`        |List configuration options                                 |
|`--show-origin` |Show origin of configuration values in `--list`            |
|`--get`         |Print value of a configuration option                      |
|`--set`         |Set a configuration option                                 |
|`--unset`       |Unset a configuration option                               |
|`--global`      |Set and Unset global configuration instead of the local one|
|`--builtins-doc`|Print Markdown list of built-in configuration options      |

imagen

But remove the blank line between the section heading and the table and everything will get broken, so it might be working by chance.

This would work for all (although with borders on GitHub):

### OPTIONS
|Switch          |Description                                                |
|----------------|-----------------------------------------------------------|
|`--list`        |List configuration options                                 |
|`--show-origin` |Show origin of configuration values in `--list`            |
|`--get`         |Print value of a configuration option                      |
|`--set`         |Set a configuration option                                 | 
|`--unset`       |Unset a configuration option                               |
|`--global`      |Set and Unset global configuration instead of the local one|
|`--builtins-doc`|Print Markdown list of built-in configuration options      |

Conclusion: supporting aligment could be done in Jekyll (adding a blank line to separate from the section heading, which should be avoided for the terminal) but not for Pandoc, unless a full header is added. The option without header is a bit messy and the one with header too verbose, so I'd leave it as is, but if you prefer with alignment, I could implement any of the two.

@github-actions
Copy link

This PR is stale because it has been open 60 days with no activity. Remove stale label or comment or this will be closed in 30 days.

@github-actions github-actions bot added the Stale label Apr 10, 2025
@github-actions
Copy link

This PR was closed because it has been stalled for 90 days with no activity.

@github-actions github-actions bot closed this May 11, 2025
@mosteo mosteo reopened this May 13, 2025
@github-actions github-actions bot removed the Stale label May 14, 2025
@github-actions
Copy link

This PR is stale because it has been open 60 days with no activity. Remove stale label or comment or this will be closed in 30 days.

@github-actions github-actions bot added the Stale label Jul 13, 2025
@github-actions
Copy link

This PR was closed because it has been stalled for 90 days with no activity.

@github-actions github-actions bot closed this Aug 13, 2025
@mosteo mosteo reopened this Aug 15, 2025
@github-actions github-actions bot removed the Stale label Aug 16, 2025
@github-actions
Copy link

This PR is stale because it has been open 60 days with no activity. Remove stale label or comment or this will be closed in 30 days.

@github-actions github-actions bot added the Stale label Oct 16, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants