Liking cljdoc? Tell your friends :D

cljdoc-exerciser.core

Here we look at cljdoc features for APIs

Namespace docstrings can contain markdown.

And should support links repo to articles and inline repo images

«test image 1 should appear»

Here we look at cljdoc features for APIs

Namespace docstrings **can** contain markdown.

And should support links repo [to articles](/doc/tests/md-features.md)
and inline repo images

![«test image 1 should appear»](/images/test-image-1.png)
raw docstring

exercise1clj/s

(exercise1 d e f)

Will someone ever link to me?

Will someone ever link to me?
sourceraw docstring

exercise2clj/s

(exercise2)

A function docstring can contain CommonMark formatted text.

Lists

  1. one
  2. two
    • buckle
      • my
        • shoe

Blockquotes

A quote

a nested quote

a very nested quote

Paragraphs

If you want a paragraph to include a linebreak,
you can do that.

Tables

Tables are a CommonMark extension but supported by cljdoc

LeftCenteredRight
letspeanut butter100
filland10
thispickles1

Code blocks

(defn exercise
  "A docstring can contain CommonMark formatted text."
  []
  (+ 4 5 6))

Links

An external link to the CommonMark website.

A docstring can reference resources on GitHub. You'll need to use a GitHub root relative link for this. Root relative links start with /. A root relative link has the following benefits:

  • it will also work when users decide to download your cljdocs into an offline bundle
  • does not specify project coords, making it GitHub fork friendly

Examples:

Wikilinks

Wikilinks are a cljdoc extension to CommonMark and allow you to link to API functions. They only work in docstrings, here's the markdown to link to another function is the current namespace:

Let's link to the exercise1 function in this namespace.

**A function docstring can contain CommonMark formatted text.**

**Lists**

1. one
2. two
    - buckle
        - my
          - shoe

**Blockquotes**

> A quote
>> a nested quote
>>> a very nested quote

**Paragraphs**

If you want a paragraph to include a linebreak, \
you can do that.

**Tables**

Tables are a CommonMark extension but supported by cljdoc

| Left     |  Centered     | Right |
|----------|:-------------:|------:|
| lets     | peanut butter |   100 |
| fill     | and           |    10 |
| this     | pickles       |     1 |

**Code blocks**

```clojure
(defn exercise
  "A docstring can contain CommonMark formatted text."
  []
  (+ 4 5 6))
```

**Links**

An external link to [the CommonMark website](https://commonmark.org/).

A docstring can reference resources on GitHub.
You'll need to use a GitHub root relative link for this.
Root relative links start with `/`.
A root relative link has the following benefits:
- it will also work when users decide to download your cljdocs into an offline bundle
- does not specify project coords, making it GitHub fork friendly

Examples:
- [an imported article will be shown on cljdoc](/doc/tests/md-features.md)
- [another resource will link you to GitHub](/doc/tests/excluded.md)
- [specifying a relative link results in error link](doc/tests/excluded.md)

**Wikilinks**

Wikilinks are a cljdoc extension to CommonMark and allow you to link to API functions.
They only work in docstrings, here's the markdown to link to another function is the current
namespace:

Let's link to the [[exercise1]] function in this namespace.
sourceraw docstring

exercise3clj/s

(exercise3 x y z)

Linking to images might be of interest.

Specify your images as root relative (starting with a /):

«my local test image should appear here»

Otherwise they will result in errored references:

«alt image text»

An external image should work fine too:

«an external image should appear here»

Linking to images might be of interest.

Specify your images as root relative (starting with a `/`):

![«my local test image should appear here»](/images/test-image-1.png "my local test image text")

Otherwise they will result in errored references:

![«alt image text»](../../images/test-image-1.png)

An external image should work fine too:

![«an external image should appear here»](https://dummyimage.com/300x100/000000/fff&text=an+external+image)
sourceraw docstring

exercise4clj/s

(exercise4 a b c)

Using headings in a docstring might be ridiculous, but you can do it.

Heading 1

Heading 2

Heading 3

Heading 4

Heading 5

this is too much, I am heading home.

Using headings in a docstring might be ridiculous, but you can do it.

# Heading 1
## Heading 2
### Heading 3
#### Heading 4
##### Heading 5
this is too much, I am heading home.
sourceraw docstring

exercise5cljs

(exercise5 j s)

This function is for ClojureScript only.

This function is for ClojureScript only.
sourceraw docstring

exercise6clj

(exercise6 j v m)

This function is for Clojure only.

This function is for Clojure only.
sourceraw docstring

exercise7clj/s

(exercise7)

How does a docstring handle embedded html?

It is not <b>bold</b> enough to render it.

How does a docstring handle embedded html?

It is not <b>bold</b> enough to render it.
sourceraw docstring

cljdoc is a website building & hosting documentation for Clojure/Script libraries

× close