Writing in Tuleap

This section covers the general rules that apply on texts in Tuleap.

Markdown

Tuleap supports writing Text content in Markdown format. To be more precise, Tuleap supports the CommonMark specification for Markdown.

Here is a link to an explanation of Markdown Syntax that will help you understand how to write Markdown.

If you’re already a little bit familiar with it, check the Markdown syntax cheat-sheet for a quick reminder.

Code Highlighting

Tuleap also adds a few extensions to make life easier. In Markdown, you can write “code fence” blocks to show little snippets of code. For example:

```typescript
function add(a: number, b: number): number {
  return a + b;
}
```

These snippets are syntax highlighted when rendered in HTML. There are more than 250 languages supported by the underlying lib used for the syntax highlighting, PrismJS.

Graphs

You can also write graphs in a text format called Mermaid in Markdown code blocks:

Flow-chart example:

```mermaid
  graph TD;
    A-->B;
    A-->C;
    B-->D;
    C-->D;
```

This will produce a flow-chart graph like this:

../_images/flowchart-example.png

At the time of writing (Tuleap 12.7), Tuleap uses Mermaid v8 and supports following graph type:

The configuration is Strict and cannot be modified. It means that clicks are forbidden and texts are encoded.

Charts can be quite large, don’t worry. There is a zoom built-in, just click on the graph and it will show the diagram in a dedicated, full screen modal. You can zoom-in and out with the mouse wheel and move as in a map.

Where can I write Markdown ?

Tuleap references

References are a powerful tool that allow cross-referencing of Tuleap objects. Based on a text pattern, Tuleap automatically creates hyperlinks to the desired object.

When typing a follow-up comment or a commit message, any text containing the pattern XXX #NNN will be interpreted as a reference to the object of type XXX with ID number NNN.

For instance, artifact #123 is recognized as a reference to artifact number 123, and Tuleap automatically creates a hyperlink that directly points to the details of artifact 123.

You may also reference an object that belongs to another project. In that case, use either XXX #project_id:NNN or XXX #project_name:NNN to reference object XXX number NNN belonging to project which ID is project_id or which short name is project_name. For instance, doc #myproj:567 is a reference to the document 567 of the project myproj.

Some reference patterns may need more than one parameter. In this case, use / as a separator between parameters. For example, git #a_repo/6eef1d01 creates a reference to the git commit 6eef1d01 in the repository a_repo

Platform and projects can define their own references.