# Documentation Coding Style
## Where are the docs?
TL;DR version: [`docs`](https://github.com/StackExchange/dnscontrol/tree/master/docs) is the [marketing website](https://dnscontrol.org). [`documentation`](https://github.com/StackExchange/dnscontrol/tree/master/documentation) is the [docs.dnscontrol.org](https://docs.dnscontrol.org/) website. (Yes, the names are backwards!)
**The two websites**
1.
* The main website
* Source code: [`docs`](https://github.com/StackExchange/dnscontrol/tree/master/docs)
* Mostly "marketing" for the project.
* Rarely changes. Updated via GitHub "pages" feature.
2.
* Project documentation
* Source code: [`documentation`](https://github.com/StackExchange/dnscontrol/tree/master/documentation)
* Users and developer documentation
* Changes frequently. Updated via [GitBook](https://www.gitbook.com/)
**The directory structure**
Within the git repo, docs are grouped:
* [`documentation/`](https://github.com/StackExchange/dnscontrol/tree/master/documentation): general docs
* [`documentation/providers/`](https://github.com/StackExchange/dnscontrol/tree/master/documentation/providers/): One file per provider
* [`documentation/functions/`](https://github.com/StackExchange/dnscontrol/tree/master/documentation/functions/): One file per `dnsconfig.js` language feature
* [`documentation/assets/FOO/`](https://github.com/StackExchange/dnscontrol/tree/master/documentation/assets/): Images for page FOO(PNGs only, please!)
## How to add a new page?
1. Add the page to the `documentation` folder (possibly a sub folder)
2. List the page in `SUMMARY.md` so that it will appear in the table of contents, sidebar, etc.
## Documentation previews
> "Preview links are only accessible by GitBook users. We're working on a feature that will allow preview links to be viewable by anyone who accesses the PR." — _[GitBook](https://docs.gitbook.com/product-tour/git-sync/github-pull-request-preview#how-to-access-preview-links)_
## Formatting tips
### General
Break lines every 80 chars.
Include a blank line between paragraphs.
Leave one blank line before and after a heading.
Javascript code should use double quotes (`"`) for strings, not single quotes
(`'`). They are equivalent but consistency is good.
### Headings
```markdown
# Title of the page
## Heading
At least one paragraph.
## Subheadings
At least one paragraph.
* **Step 1: Foo**
Description of the step.
* **Step 2: Bar**
Description of the step.
(further sub sub headings are discouraged encouraged)
```
### Code Snippets
See the examples below, for the Markdown syntax click on the 'Source code'.
Long example: (with filename)
{% code title="dnsconfig.js" %}
```javascript
var REG_NONE = NewRegistrar('none');
var DNS_BIND = NewDnsProvider('bind');
D('example.com', REG_NONE, DnsProvider(DNS_BIND),
A('@', '1.2.3.4')
);
```
{% endcode %}
[Source code](markdown-examples/code/dnsconfig-code-example-with-filename.md?plain=1)
Long example: (without filename)
{% code %}
```javascript
var REG_NONE = NewRegistrar('none');
var DNS_BIND = NewDnsProvider('bind');
D('example.com', REG_NONE, DnsProvider(DNS_BIND),
A('@', '1.2.3.4')
);
```
{% endcode %}
[Source code](markdown-examples/code/dnsconfig-code-example-without-filename.md?plain=1)
### Hint
Hints are a great way to bring the reader's attention to specific elements in your documentation.
There are 4 different types of hints, and both inline content and formatting are supported.
### Example of a hint
{% hint style="info" %}
**Info hints** are great for showing general information, or providing tips and tricks.
{% endhint %}
[Source code](markdown-examples/hint/hint-info.md?plain=1)
{% hint style="success" %}
**Success hints** are good for showing positive actions or achievements.
{% endhint %}
[Source code](markdown-examples/hint/hint-success.md?plain=1)
{% hint style="warning" %}
**Warning hints** are good for showing important information or non-critical warnings.
{% endhint %}
[Source code](markdown-examples/hint/hint-warning.md?plain=1)
{% hint style="danger" %}
**Danger hints** are good for highlighting destructive actions or raising attention to critical information.
{% endhint %}
[Source code](markdown-examples/hint/hint-danger.md?plain=1)
{% hint style="info" %}
### This is a heading
This is a line
This is a second line
{% endhint %}
### Technical references
#### Mentioning language features
Not every mention to A, CNAME, or function
needs to be a link to the manual for that record type.
However, the first mention on a page should always
be a link. Others are at the authors digression.
```markdown
The [`PTR`](functions/domain/PTR.md) feature is helpful in LANs.
```
#### Mentioning functions from the Source code
```markdown
The function `GetRegistrarCorrections()` returns...
```
### Links
#### Internal links
```markdown
Blah blah blah [M365_BUILDER](functions/record/M365_BUILDER.md)
```
{% hint style="info" %}
**NOTE**: The `.md` is required.
{% endhint %}
#### Link to another website
Just list the URL.
```markdown
Blah blah blah blah blah.
```
#### Link with anchor text
```markdown
Blah blah blah [a search engine](https://www.google.com) blah blah.
```
## Proofreading
Please spellcheck documents before submitting a PR.
Don't be surprised if Tom rewrites your text. He often does that to keep the
documentation consistent and make it more approachable by new users. It's not
[because he has a big ego](https://www.amazon.com/stores/author/B004J0QIVM).
Well, not usually.