From 22c0bf85235489a3c48786684342f9abc84afe4f Mon Sep 17 00:00:00 2001 From: Valentin Gagarin Date: Mon, 11 Jul 2022 15:13:38 +0100 Subject: [PATCH] add a guide on writing tutorials including references to valuable resources, the authors of which know much better what they're doing. --- source/contributing/index.md | 1 + source/contributing/writing-a-tutorial.md | 84 +++++++++++++++++++++++ 2 files changed, 85 insertions(+) create mode 100644 source/contributing/writing-a-tutorial.md diff --git a/source/contributing/index.md b/source/contributing/index.md index 9ce0749..a48e612 100644 --- a/source/contributing/index.md +++ b/source/contributing/index.md @@ -4,6 +4,7 @@ :hidden: true documentation.md +writing-a-tutorial.md ``` This guide explains how you can contribute to Nix, Nix packages or diff --git a/source/contributing/writing-a-tutorial.md b/source/contributing/writing-a-tutorial.md new file mode 100644 index 0000000..7d7b099 --- /dev/null +++ b/source/contributing/writing-a-tutorial.md @@ -0,0 +1,84 @@ +# How to write a tutorial + +This is a guide to writing tutorials about Nix. + +By [tutorials](https://diataxis.fr/tutorials/) we mean *lessons* as described in the [Diátaxis framework for technical documentation](https://diataxis.fr), and recommend becoming familiar with Diátaxis before proceeding. +Especially note [the difference between tutorials and guides](https://diataxis.fr/tutorials-how-to/). + +We strongly recommend the book [How Learning Works (summary)](https://www.lesswrong.com/posts/mAdMkFqWzbJRB544m/book-review-how-learning-works) as a guide for designing learning materials. + +## Target audience + +The main target audience of Nix tutorials are software developers with at least basic experience on the Linux command line. + +Experts answering questions immediately, personalised instructions and training, and other forms of apprenticeship are known to be the most effective support for learning Nix. +**These tutorials are targeted at those who don't have access to any of that**, and should therefore be written to be suitable for self-directed learning. +This is achieved by following the structure outlined here, which is primarily characterised by aiming to avoid and close all information gaps for the learner. + +As a byproduct, a well-written tutorial will be useful as lecture notes for use in interactive training sessions. +Therefore, the secondary target audience are instructors teaching Nix. + +## Structure + +Each tutorial should have the following structure: + +### What will you learn? + +Describe the problem statement and learning goals. + +The learning goal of a tutorial is always a skill, which is distinguished by being applicable to a set of situations with recurrent patterns. + +### What do you need? + +State the prerequisite knowledge and skills. +The tutorial should always be written such that the stated prerequisites are sufficient to achieve learning goals. + +Examples: + +- links to previous chapters +- domain-specific skills or knowledge + +### How long does it take? + +Estimate the reading time. +This is important for learners to make sure they have the capacity to achieve the planned tasks and thus avoid amounts frustration that will prevent them from continuing on their journey into the Nix ecosystem. + +The estimate will depend on the learner's pre-existing knowledge and proficiency. +You can note how optional skills or knowledge may influence reading time. + +We recommend testing your tutorial with friends or coworkers. +This will both help with revealing implicit prerequisites as well as provide a realistic estimate of the reading time. + +### Tutorial + +Provide steps to achieve the learning goal. + +Depending on how well a use case is supported, these may be + +- instructions and examples +- links to known-good external resources, with summaries +- overview of available tools, and their state of maturity and maintenance +- overview of ideas, and state of community discussion. + +It is also worthwhile to add contextual explanations within `
` tags +This can help with understanding while keeping distractions minimal. + +### What did you learn? + +Provide exercises or worked examples, and offer means of self-assessment. + +This is also a good place to offer the readers ways to give feedback or ask the authors questions in order to continue improving the tutorial. + +### Next steps + +Depending on how well a use case is explored, point the reader to + +- reference manuals +- other chapters +- ongoing community discussion +- additional resources + +We recommend making an explicit separation of practical from theoretical learning resources, as then readers will be able to quickly decide to either get things done or learn more. + +External resources should have a summary to set expectations, ideally including reading time. +Blog posts should have their original title in the link, and `(, )`: give authors credit, give readers an idea of how up to date the information is.