Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Emphasize MyST, various other improvements #104

Merged
merged 2 commits into from
Aug 12, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
26 changes: 18 additions & 8 deletions content/building.md
Original file line number Diff line number Diff line change
@@ -1,14 +1,24 @@
# Building the lesson

It is built the normal Sphinx way:
```{highlight} console
```

It is built the normal Sphinx ways. Using Sphinx directly, one would
run:

```
$ sphinx-build -M html content/ _build
```

If you have `make` installed, you can:

```
make html
# or
make dirhtml
# full build
make clean html
$ make html
## or
$ make dirhtml
## full build
$ make clean html
```

However, there are different ways to set up a Sphinx project. Our
sample project puts the results in `_build/`.
However, there are different ways to set up a Sphinx project.
CodeRefinery lessons puts the results in `_build/`.
3 changes: 3 additions & 0 deletions content/changelog.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
# Changelog

This isn't very up to date right now. There haven't been significant
backwards-incompatible changes, so this hasn't been kept in earnest.

## 0.8.0

- First PyPI release
5 changes: 4 additions & 1 deletion content/cheatsheet.md
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
# Cheatsheet

This is the cheatsheet.
Nothing here yet. See the sample episodes:

* [MyST markdown](https://github.com/coderefinery/sphinx-lesson/blob/master/content/sample-episode-myst.md?plain=1)
* [ReST](https://github.com/coderefinery/sphinx-lesson/blob/master/content/sample-episode-rst.rst?plain=1)
5 changes: 4 additions & 1 deletion content/conf.py
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@
# -- Project information -----------------------------------------------------

project = 'Sphinx-lesson'
copyright = '2020, CodeRefinery'
copyright = '2020-2024, CodeRefinery'
author = 'CodeRefinery'

# roundabout way to get version. "import sphinx_lesson" would be easier, but
Expand Down Expand Up @@ -47,6 +47,9 @@
'sphinx_rtd_theme_ext_color_contrast',
]

# Sphinx-lesson config:
sphinx_lesson_transform_html_img = False

# Settings for myst_nb:
# https://myst-nb.readthedocs.io/en/latest/computation/execute.html#notebook-execution-modes
#nb_execution_mode = "off"
Expand Down
15 changes: 8 additions & 7 deletions content/contributing-to-a-lesson.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,10 +9,11 @@ is fairly easy:
- (optional) Set up the Python environment and preview
- Send your contribution

In summary, each lesson is a Python project, with content in the
`content/` directory. It uses the Sphinx documentation system,
which is a popular, extendable tool. We have only minor extensions to
make it suitable to lessons.
In summary, each lesson is like a Python project, with the lesson
content as its documentation in the `content/` directory (and no
Python code). Everything is fairly standard: it uses the Sphinx
documentation system, which is a popular, extendable tool. We have
only minor extensions to make it suitable to lessons.

Instead of going through this process, you can also open an issue
instead with your proposed change, and let someone else add it.
Expand All @@ -35,7 +36,7 @@ $ git clone git://github.com/ORGANIZATION/LESSON.git
## Edit the material

The material is in the `content/` directory. Depending on the
lesson, in may be in ReStructured Text, MyST Markdown, or Jupyter
lesson, in may be in MyST Markdown, ReStructured Text, or Jupyter
notebooks.

### ReStructured Text and MyST Markdown
Expand All @@ -47,10 +48,10 @@ this is not unstructured Markdown, but there are particular
text. (In fact, "markdown" is a broad concept and everyone uses some
different extensions of it).

- {doc}`sphinx-lesson directives for markup <directives>`
- {doc}`md-and-rst`
- {ref}`ReStructured Text reference <sphinx:rst-primer>`
- [MyST reference](https://myst-parser.readthedocs.io/en/latest/using/syntax.html)
- {doc}`sphinx-lesson directives for markup <directives>`
- {ref}`ReStructured Text reference <sphinx:rst-primer>`

*Do not worry about getting syntax right*. Send your improvement, and
editing is easy and you will learn something.
Expand Down
3 changes: 3 additions & 0 deletions content/convert-old-lessons.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
# Converting an old lesson

**This was the old CodeRefinery procedure. It is now unmaintained
but might be useful for someone. Let us know if you need it revived.**

% highlight: console

## Convert a Jekyll lesson
Expand Down
2 changes: 1 addition & 1 deletion content/executing-code.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ kernelspec:
---


# Try executing code cells in markdown
# Executing code cells in MyST markdown

This is a `.md` file that has a special header and a `{code-cell}`
directive, that lets it
Expand Down
50 changes: 37 additions & 13 deletions content/exercise-list.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,32 +7,52 @@ instructors and helpers, and more.

## Usage

ReST:

```
.. exerciselist::
```

MyST:

````
```{exerciselist}```
````

ReST:

```
.. exerciselist::
```

One can give the optional directive arguments to specify lists of
admonition classes to include (default: `exercise`, `solution`,
`exerciselist-include`) or exclude (default:
`exerciselist-exclude`) if you want to (any {doc}`directives
<directives>` which match any `include`, and do not match any
`exclude` are included). Specify the options this way (ReST):

MyST:

````md
```{exerciselist}
:include: exercise solution instructor-note
:exclude: exclude-this
```

:::{exercise} Exercise title
:class: exclude-this

Exercise content
:::
````


ReST:

```rst
.. exerciselist::
:include: exercise solution instructor-note
:exclude: exclude-this

.. exercise::
.. exercise:: Exercise title
:class: exclude-this

Exercise content
```

This feature is new as of early 2022, there may be possible problems
Expand Down Expand Up @@ -74,8 +94,9 @@ source for hint on fixing).
(advanced) Also create packaging using pyproject.toml and compare (20 min)
```

- Consider giving your exercises permanent identifiers. They are not
auto-numbered yet for a reason (what happens when more exercises are
- Consider giving your exercises permanent identifiers. They are
intentionally not
auto-numbered yet (what happens when more exercises are
added/removed?), but if you give them an ID, they will be findable
even later. Suggestion is `Episodetopic-N`:

Expand Down Expand Up @@ -103,10 +124,13 @@ source for hint on fixing).

## Example

This section contains the exercise list of sphinx-lesson. Note that
the directives occur many times in random contexts, so many of them
don't really make sense. Keep in mind how to ensure that your cases
are better.
**This section contains the exercise list of sphinx-lesson. Since
sphinx-lesson has many examples of exercises, the list below is
confusing and doesn't make a lot of sense. You can see a better
example at [git-intro's exercise
list](https://coderefinery.github.io/git-intro/exercises/).**

**Example begins:**

:::{exerciselist}
:::
3 changes: 2 additions & 1 deletion content/getting-started.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,8 @@ the lesson develops - you might want to check back for them, later.

## Convert an existing jekyll lesson

See {doc}`convert-old-lessons`.
See {doc}`convert-old-lessons`. This hasn't been used in years so may
be out of date.

## From scratch

Expand Down
13 changes: 11 additions & 2 deletions content/gh-action.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# Deployment with Github Actions

In this repository, there is a `.github/workflows/sphinx.yml` file
In sphinx-lesson-template (and this lesson...), there is a `.github/workflows/sphinx.yml` file
that contains a Github Action that:

- Installs dependencies
Expand All @@ -9,11 +9,20 @@ that contains a Github Action that:

- Deploys it

- If branch = `master` (to be renamed to `main`), deploy to github pages normally
- If branch = `main`, deploy to github pages normally
- For other branches, deploy to github-pages but put the result in
the `branch/{branch-name}` subdirectory. If the branch name has
a `/` in it, replace it with `--`.
- Keep all previous deployments, but remove branch subdirectories
for branches that no longer exist.

This allows you to view builds from pull requests or other branches.

## Usage

It is recommended to copy from
[sphinx-lesson-template](https://github.com/coderefinery/sphinx-lesson-template/),
since that is the primary copy that is updated with all of the latest developments.

Direct link:
<https://github.com/coderefinery/sphinx-lesson-template/blob/main/.github/workflows/sphinx.yml>
18 changes: 12 additions & 6 deletions content/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,10 @@ sphinx-lesson is a set of Sphinx extensions and themes for creating
interactive, hands-on lessons. It was originally made to replace the
CodeRefinery jekyll themes, but is designed to be used by others.

The broad idea is that making teaching materials should be quite
similar to good software documentation. Sphinx-lesson adds a model
and a few nice extras to bring them closer together.

As the name says, it is based on the [Sphinx documentation generator](https://www.sphinx-doc.org/). It is also inspired by and based on
[jupyter-book](https://jupyterbook.org/), but both is jupyter-book
and isn't. It *is* because jupyter-book is based on Sphinx and
Expand All @@ -25,16 +29,18 @@ Features:
- Based on jupyter-book, cross-compatible.
- Built with Sphinx, providing a structured, controlled output.
- Distributed as Python pip packages
- Markdown and ReStructured equally supported (yes, including all
directives), though ReStructured Text is still a bit nicer
- Markdown and ReStructured equally supported as input formats (yes, including all
directives).
- Jupyter notebooks as an input format. Can execute code (in jupyter
and other formats, too)
- Transparent transformation of jekyll-style markdown styles into
CommonMark with directives
- Also renders with sphinx-book-theme (theme of jupyterbook) ([preview](https://coderefinery.github.io/sphinx-lesson/branch/sphinx-book-theme/))
CommonMark with directives (mainly of use for old CodeRefinery lessons)
- Also renders with sphinx-book-theme (theme of jupyterbook)
([preview](https://coderefinery.github.io/sphinx-lesson/branch/sphinx-book-theme/))
and other Sphinx themes.

This is in an alpha state: we use it for lessons, but there is still
refinement work to go.
This is in heavy internal use, and about ready for other users who are
interested.

:::{prereq}
- If you know Sphinx, it helps some. If not, it's easy to copy
Expand Down
46 changes: 26 additions & 20 deletions content/indexing.md
Original file line number Diff line number Diff line change
Expand Up @@ -41,24 +41,11 @@ subentries.
```{index} pair: index; ReST
```

Index a block with the directive, with ReST:

```
.. index:: commit; amend
```

Or ReST, multiple:

```
.. index::
commit
commit; message
pair: commit; amend
```
### Index a block with a directive

MyST:

````
````md
```{index} commit; amend
```

Expand All @@ -69,14 +56,24 @@ pair: commit; amend
```
````

Or index a single term with the role:
ReST:

```
This sentence has an index entry for :index:`commit`. If you want the
indexed term to be different, standard syntax applies such as
:index:`loop variables <pair: commit; amend>`.
.. index:: commit; amend
```

Or ReST, multiple:

```
.. index::
commit
commit; message
pair: commit; amend
```


### Index a single word with the role

```{index} pair: index; MyST
```

Expand All @@ -90,7 +87,16 @@ Pair entry: {index}`loop variables <pair: commit; amend>`
```{index} index; single index; pair index; see index; seealso
```

There are different styles:
ReST:

```
This sentence has an index entry for :index:`commit`. If you want the
indexed term to be different, standard syntax applies such as
:index:`loop variables <pair: commit; amend>`.
```


### Styles of indexes

- `TERM`, same as below
- `single: TERM` (the default): create just a single entry
Expand Down
31 changes: 15 additions & 16 deletions content/installation.md
Original file line number Diff line number Diff line change
Expand Up @@ -32,19 +32,18 @@ preview of it [as a branch on github-pages](https://coderefinery.github.io/sphin

## Under the hood

Adding `sphinx_lesson` as an extension adds these sub-extensions:

> - `sphinx_lesson.directives` - see {doc}`directives`.
> - `sphinx_lesson.md_transforms` - see {doc}`md-transforms`.
> - `sphinx_lesson.exerciselist` - see {doc}`exercise-list`.
> - `sphinx_lesson.term_role_formatting` - makes glossary term
> references bold
> - Enables the [myst_notebook extension](https://myst-nb.readthedocs.io/en/latest/), which also enables
> [myst_parser](https://myst-parser.readthedocs.io/en/latest/index.html)
> (included as a dependencies)
> - Enables the [sphinx-copybutton extension](https://github.com/executablebooks/sphinx-copybutton)
> (included as a dependency)
> - Same for [sphinx-tabs](https://sphinx-tabs.readthedocs.io/)
> - Same for [sphinx-togglebutton](https://pypi.org/project/sphinx-togglebutton/)

Any of these can be used independently to get the same effect.
Adding `sphinx_lesson` as an extension adds these sub-extensions, and
you could selectively enable only the parts you want:

- `sphinx_lesson.directives` - see {doc}`directives`.
- `sphinx_lesson.md_transforms` - see {doc}`md-transforms`.
- `sphinx_lesson.exerciselist` - see {doc}`exercise-list`.
- `sphinx_lesson.term_role_formatting` - makes glossary term
references bold
- Enables the [myst_notebook extension](https://myst-nb.readthedocs.io/en/latest/), which also enables
[myst_parser](https://myst-parser.readthedocs.io/en/latest/index.html)
(included as a dependencies)
- Enables the [sphinx-copybutton extension](https://github.com/executablebooks/sphinx-copybutton)
(included as a dependency)
- Same for [sphinx-tabs](https://sphinx-tabs.readthedocs.io/)
- Same for [sphinx-togglebutton](https://pypi.org/project/sphinx-togglebutton/)
Loading
Loading