Syntax Selector
===============

.. warning::

    Try syntax is antiquated and hard to understand. If you aren't already
    familiar with try syntax, you might want to use the ``fuzzy`` selector
    instead.

Try syntax is a command line string that goes into the commit message. Using
``mach try syntax`` will automatically create a temporary commit with your
chosen syntax and then delete it again after pushing to try.

Try syntax can contain all kinds of different options parsed by various
places in various repos, but the majority are parsed by `try_option_syntax.py`_.
The most common arguments include:

    * ``-b/--build`` - One of ``d``, ``o`` or ``do``. This is the build type,
      either opt, debug or both (required).
    * ``-p/--platform`` - The platforms you want to build and/or run tests on
      (required).
    * ``-u/--unittests`` - The test tasks you want to run (optional).
    * ``-t/--talos`` - The talos tasks you want to run (optional).

Here are some examples:

.. code-block:: shell

    $ mach try syntax -b do -p linux,macosx64 -u mochitest-e10s-1,crashtest -t none
    $ mach try syntax -b d -p win64 -u all
    $ mach try syntax -b o -p linux64

Unfortunately, knowing the magic strings that make it work can be a bit of a
guessing game. If you are unsure of what string will get your task to run, try
using :doc:`mach try fuzzy <fuzzy>` instead.

While using ``mach try syntax -b do -p all -u all -t all`` will work, heavy use
of ``all`` is discouraged as it consumes a lot of unnecessary resources (some of
which are hardware constrained).

..  _try_option_syntax.py: https://searchfox.org/mozilla-central/source/taskcluster/gecko_taskgraph/try_option_syntax.py