Documenting the API
This document contains general guidelines for describing the Tarantool API, as well as examples and templates.
Please write as simply as possible. Describe functionality using short sentences in the present simple tense. A short sentence consists of no more than two clauses. Consider using LanguageTool or Grammarly to check your English. For more style-related specifics, consult the Language and style section.
For every new module, function, or method, specify the version it first appears in.
For a new parameter, specify the version it first appears in if this parameter is a «feature» and the version it’s been introduced in differs from the version introducing the function/method and all other parameters.
To specify the version, use the following Sphinx directive:
Since :doc:`2.10.0 </release/2.10.0>`.
This is a link to the release notes on the Tarantool documentation website.
The result looks like this:
Since Tarantool 2.10.0. This is a link to the release notes on the Tarantool documentation website.
Use one of the two options:
- Start with a verb in the imperative mood. Example: Create a fiber.
- Start with a noun. Example: The directory where memtx stores snapshot files.
Each list item is a characteristic to be described. Some items can be optional.
- Since which Tarantool version
- General description
- Parameters
- What this function returns (if nothing, write „none“)
- Return type (if exists)
- Possible errors (if exist)
- Complexity factors (for CRUD operations and index access functions)
- Usage with memtx and vinyl (if differs)
- Example(s)
- Extra information (if needed)
- Since which Tarantool version (if added later)
- General description
- Type
- Default value (if optional), possible values
If the parameter is optional, make sure it is enclosed in square brackets in the function declaration (in the «heading»). Do not mark parameters additionaly as «optional» or «required»:
.. function:: format(URI-components-table[, include-password])
Construct a URI from components.
:param URI-components-table: a series of ``name:value`` pairs, one for each component
:param include-password: boolean. If this is supplied and is ``true``, then
the password component is rendered in clear text,
otherwise it is omitted.
Configuration parameters are not to be confused with class and method parameters. Configuration parameters are passed to Tarantool via the command line or in an initialization file. You can find a list of Tarantool configuration parameters in the configuration reference.
- Since which Tarantool version
- General description
- Type
- Corresponding environment variable (if applicable)
- Default value
- Possible values (can be included in the general description, for example, as a list)
- Dynamic (yes or no)
In the «Possible errors» section of a function or class method, consider explaining what happens if any parameter hasn’t been defined or has the wrong value.
We use the Sphinx directives .. module::
and .. function::
to describe functions of Tarantool modules:
.. module:: fiber
.. function:: create(function [, function-arguments])
Create and start a fiber. The fiber is created and begins to run immediately.
:param function: the function to be associated with the fiber
:param function-arguments: what will be passed to function.
:return: created fiber object
:rtype: userdata
**Example:**
.. code-block:: tarantoolsession
tarantool> fiber = require('fiber')
---
...
tarantool> function function_name()
> print("I'm a fiber")
> end
---
...
tarantool> fiber_object = fiber.create(function_name); print("Fiber started")
I'm a fiber
Fiber started
---
...
The resulting output looks like this:
-
fiber.
create
(function[, function-arguments])¶ Create and start a fiber. The fiber is created and begins to run immediately.
Параметры: - function – the function to be associated with the fiber
- function-arguments – what will be passed to function.
Return: created fiber object
Rtype: userdata
Example:
tarantool> fiber = require('fiber') --- ... tarantool> function function_name() > print("I'm a fiber") > end --- ... tarantool> fiber_object = fiber.create(function_name); print("Fiber started") I'm a fiber Fiber started --- ...
Methods are described similarly to functions, but the .. class::
directive, unlike .. module::
, requires nesting.
As for data, it’s enough to write the description, the return type, and an example.
Here is the example documentation describing
the method and data of the index_object
class:
.. class:: index_object
.. method:: get(key)
Search for a tuple :ref:`via the given index <box_index-note>`.
:param index_object index_object: :ref:`object reference
<app_server-object_reference>`
:param scalar/table key: values to be matched against the index key
:return: the tuple whose index-key fields are equal to the passed key values
:rtype: tuple
**Possible errors:**
* No such index
* Wrong type
* More than one tuple matches
**Complexity factors:** index size, index type.
See also :ref:`space_object:get() <box_space-get>`.
**Example:**
.. code-block:: tarantoolsession
tarantool> box.space.tester.index.primary:get(2)
---
- [2, 'Music']
...
.. data:: unique
True if the index is unique, false if the index is not unique.
:rtype: boolean
.. code-block:: tarantoolsession
tarantool> box.space.tester.index.primary.unique
---
- true
...
And the resulting output looks like this:
-
object
index_object
¶ -
index_object:
get
(key)¶ Search for a tuple via the given index.
Параметры: - index_object (
index_object
) – object reference - key (
scalar/table
) – values to be matched against the index key
Return: the tuple whose index-key fields are equal to the passed key values
Rtype: tuple
Possible errors:
- No such index
- Wrong type
- More than one tuple matches
Complexity factors: index size, index type. See also space_object:get().
Example:
tarantool> box.space.tester.index.primary:get(2) --- - [2, 'Music'] ...
- index_object (
-
index_object.
unique
¶ True if the index is unique, false if the index is not unique.
Rtype: boolean tarantool> box.space.tester.index.primary.unique --- - true ...
-
Example:
.. confval:: wal_dir
Since version 1.6.2.
A directory where write-ahead log (.xlog) files are stored. Can be relative
to :ref:`work_dir <cfg_basic-work_dir>`. Sometimes ``wal_dir`` and
:ref:`memtx_dir <cfg_basic-memtx_dir>` are specified with different values, so
that write-ahead log files and snapshot files can be stored on different
disks. If not specified, defaults to ``work_dir``.
| Type: string
| Default: "."
| Environment variable: TT_WAL_DIR
| Dynamic: no
Result:
Since version 1.6.2. A directory where write-ahead log (.xlog) files are stored. Can be relative to work_dir. Sometimes
wal_dir
and memtx_dir are specified with different values, so that write-ahead log files and snapshot files can be stored on different disks. If not specified, defaults towork_dir
.Type: stringDefault: «.»Environment variable: TT_WAL_DIRDynamic: no