title |
---|
Style Guide for SDK Documents |
This document describes the writing style used in authoring open source IntelliJ Platform SDK documentation. Before you begin, please read this page thoroughly as well as the Code of Conduct and License documents. For information about contributing to the IntelliJ Platform itself, please visit Contributing to the IntelliJ Platform.
First and foremost, we should keep in mind our audience and their objectives: Someone reading technical content is usually looking to answer a specific question. That question might be broad or narrowly-focused, but either way, our goal is to provide answers without distraction.
The style of the Intellij Platform SDK documentation is captured by using a markup language named Markdown. The following sections describe the SDK documentation style in terms of the Markdown formats:
- bullet list {:toc}
By default, when building the site, all files are copied to the destination _site
folder.
Some files are excluded in the _config.yml
and sdkdocs-template/jekyll/_config-defaults.yml
files.
The documentation files themselves are Markdown files (*.md
) that get automatically converted to HTML when the site is built.
Only Markdown files beginning with a YAML header are converted to HTML.
If the Markdown file doesn't contain a header, it won't be converted.
In other words, to convert a .md
file to HTML, it should look like this:
---
---
Lorem ipsum...
The two lines at the top of the file are the markers of the YAML front matter. Fields can be added in between these markers, and are used when generating the HTML. Typically, this header is empty, although it is required by Jekyll (if omitted, the file isn't converted).
The YAML header can contain data that is used when generating the site.
For example, the page title can be specified as a simple piece of Markdown - # Title
, or it can be specified in the YAML, and the page template displays it appropriately:
NOTE The page copyright notice should appear immediately below the YAML header as shown below. Use the IntelliJ Platform SDK copyright profile.
---
title: The Title Of The Page
---
<!-- Copyright 2000-2020 JetBrains s.r.o. and other contributors. Use of this source code is governed by the Apache 2.0 license that can be found in the LICENSE file. -->
Lorem ipsum...
The YAML header can also include redirect information.
Line spacing around headings in Markdown files generally doesn't affect the HTML conversion, but it does make MD pages more readable for authors:
- No space between a heading and the first content below it.
- One space before a heading if it is the same level or a sub-heading of the previous section.
- Two spaces before a heading that is higher-level than the heading of the previous section.
The documentation site is set up to include the jekyll-redirect-from plugin, which will generate "dummy" pages that automatically redirect to a given page.
For example, to specify that the index.html
page be generated to redirect to README.md
, the README.md
file should include the following in the YAML header:
---
redirect_from:
- /index.html
---
Lorem ipsum...
The redirect will create an index.html
file that will automatically redirect to the generated README.html
file.
Redirects enable the site URL to automatically show the README.html
file - http://localhost:4001/foo-test/
will try to load index.html
, which will automatically redirect to README.html
.
It is also useful to redirect when renaming or moving files. Multiple redirects can be added to the YAML header.
NOTE Please update all existing internal links to the new page location.
The site is configured to use the Kramdown Markdown converter, which adds some extra features over traditional Markdown. For example, "attribute lists" that can apply attributes to the generated elements.
One useful attribute is {:toc}
, which can be applied to a list item, which will get replaced with a list of links to header items.
E.g. the following list item will be replaced by links to all of the header items in the page:
* Dummy list item
{:toc}
Further Kramdown features are described on the converter page, and attribute lists are described on the syntax page. Note that source code formatting is configured to use GitHub Flavoured Markdown and "code fences", see below.
Jekyll uses the Liquid templating language to process files. This process means standard Liquid tags and filters are available. There should be little need to use them, however, as the Markdown format is already quite rich. See the Jekyll site for more details.
Consistent text styles are used to standardize references and keywords:
- Menu paths are formatted as bold with pipe characters separating each level: **Preferences \| Editor** (Preferences | Editor)
- Keywords and quotations are formatted as italic: _UI Theme_ (UI Theme)
- File names and paths, and language keywords are formatted as code: `interface` (
interface
) See Syntax Highlighting for more details about representing in-paragraph code fragments. - File formats are shown as all capital letters: PNG and XML.
- File name extensions are not capitalized when part of a full file name, path, or URL:
filename.ext
. - Represent keyboard shortcuts with HTML elements:
press <kbd>Alt</kbd>+<kbd>Insert</kbd>
becomes "press Alt+Insert" - Links have a particular format depending on the type of link.
Consistent terminology helps the reader grasp new concepts more quickly:
- The open source code in the GitHub repository
intellij-community
is known as the IntelliJ Platform. Use the full phrase in SDK documentation. - IDEs based on the IntelliJ Platform are described as IntelliJ Platform-based IDEs. Once that term is used on a page, authors may use IDEs
- When referring to JetBrains products always use the full name such as IntelliJ IDEA Ultimate Edition. However, only use product names when extensibility or functionality is particular to a product.
In-paragraph code fragments and IntelliJ Platform APIs are formatted according to these rules:
- Avoid using qualifiers like "
Foo
interface" or "Foo
abstract class". Just refer toFoo
. - The FQN is used for the first reference to an interface, class or package on a page.
Rather than
AnAction
, introduce it ascom.intellij.openapi.actionSystem.AnAction
. Subsequent references on the page can beAnAction
. Exception: the FQN is not used with an upsource link. - Use the FQN when first introducing an extension point (EP) on a page.
Rather than
stubIndex
, introducecom.intellij.stubIndex
. Subsequent mentions on the page can bestubIndex
. Exception: the FQN is not used when an extension point is introduced in an upsource link. - For XML elements, use the tag notation with syntax highlighting:
<idea-version>
. Attributes are shown with syntax highlighting, and attribute values are shown in quotes:since-build="191"
- Method names always use empty parentheses: "call
bar()
to apply". Method names are prefixed with the class/interface name when needed for clarity:Foo.bar()
.
Source code can be represented by using GitHub Flavoured Markdown code fences, which are three backticks:
```
// Source code goes here...
```
Source code blocks must have one blank line before and after them.
Syntax highlighting can be applied by specifying the language after the first set of ticks:
```csharp
// Some C# code
```
```java
// Some Java code
```
Here is the list of supported languages, and also Kotlin, of course.
Whole files can be imported on a page.
The advantage is the code can come from code_samples
directory, so it will be live code that isn't silently stale.
The disadvantage is the file may contain a large class, too large for the documentation page to be effective.
```java
// include statement
```
In any case, please keep code samples concise and avoid any unnecessary "surrounding" code or import statements.
The Kramdown parser also supports tables.
The syntax is to use the pipe (|
) and minus symbols:
```md
| Column 1 | Column 2 | Column 3 |
|----------|----------|----------|
| Blah | Blah | Blah |
```
Links are handled as normal Markdown links and can be anchored to external sites, pages within the sites, or headings in the sites.
When a Markdown header is converted to an HTML header, it is assigned an ID so that it can be linked.
For example, ## Introduction
will get the ID of introduction
, and can be linked either in the same page or cross-page as described below.
Links to files in the IntelliJ Platform (intellij-community
) repository use upsource:///
instead of the full URL to the repository.
The upsource:///
URI effectively points to the root of the intellij-community
repository.
[README.md](upsource:///README.md)
for links to general files in the repository.[
`AnAction`](upsource:///platform/editor-ui-api/src/com/intellij/openapi/actionSystem/AnAction.java)
for links to source code files for interfaces and classes.- Note the use of `` characters surrounding the class name in the link.
- When linking to an API in this manner the FQN isn't necessary in the link.
- Be judicious when using such links. Generally only one link is needed for a given file on a documentation page.
General links have one of the following formats:
[External site](https://example.org)
links to an external site.- Linking to pages in the SDK documentation:
[SDK doc page in current directory](Page2.md)
links to an SDK doc page in the same directory as the current page. Note that the extension is.md
, NOT.html
.[SDK page in another folder](/Folder2/Page2.md)
links to a page in another folder. Note that the URL is navigating from the project root - this works even if the site is hosted in a sub-folder (e.g. this link will work forhttp://localhost:4000/devguide/Folder2/Page2.html
). Relative links also work (../Folder2/Page2.md
).
- Linking to specific sections on pages in the SDK documentation.
The anchor name will be all lower case, and spaces are replaced with
-
, e.g.## Page setup
becomes#page-setup
.[Link to a section on the current page](#another-section)
links to a heading on the current page.[Link to the section on another page](Page2.md#another-section)
links to a heading on another page.
Notes and callouts can be specified using the blockquote syntax. The converter looks at the first following word to see if it is bold. If so, it applies a callout style. The example below will be displayed as a callout, styled as a "note":
> **NOTE** This is a note
NOTE This is a note
The styles available for callouts are:
- TODO - Generally not used in SDK documentation.
Embed
<--! //TODO: explanation... -->
instead, which is not visible in published documentation. - TIP - Information that makes the reader more productive.
- NOTE - Information that is important for the reader to understand. This callout is reserved for key points and concepts.
- WARNING - Information critical to the user. Use this callout for information that prevents failures or errors.
Images can be included by adding the file directly to the intellij-sdk-docs
repository.
Each subject directory typically has an img
subdirectory.
Keep images close to the corresponding documentation file in the repository directory structure.
Images in this documentation are generally screenshots. The preferred image format is PNG at 144 DPI resolution. A resolution of 72 DPI is acceptable but may look blurry on high-resolution monitors.
It is important to reduce the size of image files to prevent bloating the repository and impacting the performance of the documentation site. Resize an image to be nearly the desired width on a documentation page. Reducing an image's dimensions is the most effective way to reduce image file size. Also optimize the image files using a tool such as the PNG optimizer.
Images are embedded in a document by adding a Markdown link to the image like so:
![Alt text](path-to-img.png)
If the width of an image needs to be adjusted, use Kramdown markup:
![Alt text](path-to-img.png){:width="42px"}
The table of contents for the site is displayed in the tree view on the left-hand side of the site, and it is generated from the _SUMMARY.md
file.
It is a simple Markdown list, with each item in the list being a link to another Markdown page, either in the root folder, or sub-folders.
The list can have nested items, which are displayed as child items in the table of contents.
WARNING Every Markdown (
*.md
) document within the SDK repository (intellij-sdk-docs
) must have an entry in_SUMMARY.md
.
# Summary
* [Introduction](README.md)
* [About This Guide](Intro/About.md)
* [Key Topics](Intro/KeyTopics.md)
The contents can be split into "parts" by separating the list into several lists, each new list starting with a level 2 heading (##
).
# Summary
* [Introduction](README.md)
* [About This Guide](Intro/About.md)
* [Key Topics](Intro/KeyTopics.md)
## Part I - Extending the Platform
* [Getting Started](Docs/GettingStarted.md)
* ...
If a node doesn't have a link but is just plain text, it will still appear in the table of contents but will be greyed out and not clickable. It acts as a placeholder for a documentation item. A placeholder is useful to keep track of what should be documented, but hasn't yet, and can be useful to show readers that the topic exists, but isn't yet documented (Pull Requests always welcome!).