.. _MessageFormatterFunction: MessageFormatterFunction ++++++++++++++++++++++++ .. py:currentmodule:: buildbot.reporters.message This formatter can be used to generate arbitrary messages bodies according to arbitrary calculations. As opposed to :ref:`MessageFormatterRenderable`, more information is made available to this reporter. As opposed to :ref:`MessageFormatterFunctionRaw`, only the message body can be customized. .. py:class:: MessageFormatterFunction(function, template_type, want_properties=True, want_steps=False, want_logs=False, want_logs_content=False) :param callable function: A callable that will be called with a dictionary. If the message formatter is used to format a build, the dictionary contains ``build`` key with the build dictionary as received from the data API. If the message formatter is used to format a buildset (e.g. when used from :bb:reportgen:`BuildSetCombinedStatusGenerator`), the dictionary contains the following: - ``buildset`` key with the buildset dictionary as received from the data API. - ``builds`` key with the builds dictionaries as received from the data API. :param string template_type: either ``plain``, ``html`` or ``json`` depending on the output of the formatter. JSON output must not be encoded. :param boolean want_properties: include 'properties' in the build dictionary :param boolean want_steps: include 'steps' in the build dictionary :param boolean wantLogs: deprecated, use ``want_logs`` and ``want_logs_content`` set to the same value. :param boolean want_logs: include 'logs' in the steps dictionaries. This implies `want_steps=True`. This includes only log metadata, for content use ``want_logs_content``. :param want_logs_content: include logs content in the logs dictionaries. `False` disables log content inclusion. `True` enables log content inclusion for all logs. A list of strings specifies which logs to include. The logs can be included by name; or by step name and log name separated by dot character. If log name is specified, logs with that name will be included regardless of the step it is in. If both step and log names are specified, then logs with that name will be included only from the specific step. `want_logs_content` being not `False` implies `want_logs=True` and `want_steps=True`. Enabling `want_logs_content` dumps the *full* content of logs and may consume lots of memory and CPU depending on the log size. :type want_logs_content: boolean or list[str]