diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..b5cc70b21acfb320bcf2dc625843bb31d43900d0 --- /dev/null +++ b/.gitignore @@ -0,0 +1,132 @@ +# Byte-compiled / optimized / DLL files +__pycache__/ +*.py[cod] +*$py.class + +# C extensions +*.so + +# Distribution / packaging +.Python +build/ +develop-eggs/ +dist/ +downloads/ +eggs/ +.eggs/ +lib/ +lib64/ +parts/ +sdist/ +var/ +wheels/ +pip-wheel-metadata/ +share/python-wheels/ +*.egg-info/ +.installed.cfg +*.egg +MANIFEST + +# PyInstaller +# Usually these files are written by a python script from a template +# before PyInstaller builds the exe, so as to inject date/other infos into it. +*.manifest +*.spec + +# Installer logs +pip-log.txt +pip-delete-this-directory.txt + +# Unit test / coverage reports +htmlcov/ +.tox/ +.nox/ +.coverage +.coverage.* +.cache +nosetests.xml +coverage.xml +*.cover +*.py,cover +.hypothesis/ +.pytest_cache/ + +# Translations +*.mo +*.pot + +# Django stuff: +*.log +local_settings.py +db.sqlite3 +db.sqlite3-journal + +# Flask stuff: +instance/ +.webassets-cache + +# Scrapy stuff: +.scrapy + +# Sphinx documentation +docs/_build/ + +# PyBuilder +target/ + +# Jupyter Notebook +.ipynb_checkpoints + +# IPython +profile_default/ +ipython_config.py + +# pyenv +.python-version + +# pipenv +# According to pypa/pipenv#598, it is recommended to include Pipfile.lock in version control. +# However, in case of collaboration, if having platform-specific dependencies or dependencies +# having no cross-platform support, pipenv may install dependencies that don't work, or not +# install all needed dependencies. +#Pipfile.lock + +# PEP 582; used by e.g. github.com/David-OConnor/pyflow +__pypackages__/ + +# Celery stuff +celerybeat-schedule +celerybeat.pid + +# SageMath parsed files +*.sage.py + +# Environments +.env +.venv +env/ +venv/ +ENV/ +env.bak/ +venv.bak/ + +# Spyder project settings +.spyderproject +.spyproject + +# Rope project settings +.ropeproject + +# mkdocs documentation +/site + +# mypy +.mypy_cache/ +.dmypy.json +dmypy.json + +# Pyre type checker +.pyre/ + +# Jupyter Book +_build/ \ No newline at end of file diff --git a/README.md b/README.md index 843cc4259bd5909b85896d87dff03136f509b358..a1ce0851fd22cbb25e5255f851757d9566e73925 100644 --- a/README.md +++ b/README.md @@ -1 +1,45 @@ # MUDE Jupyter Book 2023/2024 + +This book is for the technical contents of MUDE and will most likely also be used to display (and in part deliver) assignments to MUDE students, post solutions, etc. + +There will be a separate repo for the module website, which will give the (annual) course overview, planning, etc. + +For reference in editing content, see the [Jupyter Book website](https://jupyterbook.org/en/stable/) and our own CEG guidelines, which are online [here](https://interactivetextbooks.citg.tudelft.nl/manual/intro.html) and stored in the repository [here](https://gitlab.tudelft.nl/interactivetextbooks-citg/jupyter-book-manual). This repository is within the Group [`interactivetextbooks-citg`](https://gitlab.tudelft.nl/interactivetextbooks-citg). If you do not have access to these projects yet, please go [here](https://gitlab.tudelft.nl/interactivetextbooks-citg) and request it (you will probably get Developer access to the Group, and Maintainer access to the Project). + +Conventions and protocols specific to MUDE will be written in this README. + +## Where to put your content + +For now, there are 3 parts: +1. **New material:** this will slowly be the place for the new stuff, but until the ToC is well-defined, let's leave it alone for now. I leave it at the top to remind ourselves of the work that's needed still :grin: +2. **Sandbox:** do whatever you want here! Maybe start by making a chapter for yourself. Can also organize yourselves around topics, especially once you know how it may look in the "final" book. +3. **Cookbook:** this will *illustrate* examples specifically for MUDE. The idea is that the book shows what it should look like and allows you to test that it works, wherease repo/code is what you copy/paste when creating content. This should be especially to define conventions like internal references, links, figure storage, etc. Generic things can go here temporarily, but should eventually be moved over to [Jupyter Book Manual](https://gitlab.tudelft.nl/interactivetextbooks-citg/jupyter-book-manual) in the other GL Group. +4. **Old material:** collect old MUDE material here from the archive. Think of it like a staging ground: you can make the copy/paste/reference/testing side of thing easier. Try not to include large files like slides, etc...these materials should be converted to JB format for inclusion in the book, or hosted elsewhere and rendered via a link. + +## How to store your content + +Someday we will probably add chapter numbers, determine conventions for figures, code, notebooks, etc, etc, etc. For now, just put content in folders, get comfortable working with Jupyter Books and we will re-assess end of June. + +## MUDE Working Method + +**Important:** `main` is the working draft for our entire MUDE teaching team. It's the version of the document that we will use to review each others work. We will give each other feedback through a comination of GitLab Issues and in-person meetings. At some point we will also get set up on Discord or Mattermost (depending on what we use next year in class). + +**Keeep this in mind:** until we share the book with the students it will be in development mode, which means we can add all sorts of notes, tags, flags, etc.. Wherever, however, whoever. Just have fun. By July, however, the Table of Contents should close to final and by mid-August the old, draft and temporary material should be removed. + +Your typical workflow is: +- create your own branch via GitLab +- pull and checkout on your laptop +- add your content +- push to GL +- when ready to share with the MUDE team, merge into main +- if you have a problem or question, or need someone to check something, you can: + - create an Issue and tag someone. Use labels to designate the type of Issue (e.g., `@user: can you show me the right way to make this link? i could not find it in the manual`) + - tag someone in a merge request (e.g., "hey i am adding content to main, it's ready for you to add your coding example to illustrate exercise 3") + - if you think something should be added to the manual, add it as an Issue in the manual repo (try to leave MUDE Issues for MUDE-specific problems) +In the future, additional branches will be set up to publish the website, but we don't need this yet as long as everyone can build the book on their own (locally) + +For now, the only strict rule is: **Never push directly to `main`.** Now that there are many of us working together, the potential for messy merge conflicts is higher, so please try to update the "working draft" on `main` via a merge request. + +## + +**The book build is currently set up to run notebooks automatically!!!** This may be different than past books that you have worked on. It means all the code in a notebook whenever the file has been updated. This smay add build time, but is going to be an extremely useful tool for checking and enforcing our coding standards, packages, etc. It also means that if you add a new package to your notebook you need to list it in `requirements.txt`. Learn to love it. \ No newline at end of file diff --git a/book/_config.yml b/book/_config.yml new file mode 100644 index 0000000000000000000000000000000000000000..0b1d39719fc7243d51cf0bd315a2cc8e3c68b40e --- /dev/null +++ b/book/_config.yml @@ -0,0 +1,10 @@ +title: MUDE +author: MUDE Teachers and the Student Army +logo: figures/MUDE Logo.png + +execute: + execute_notebooks: auto + +sphinx: + extra_extensions: + - sphinx_inline_tabs diff --git a/book/_toc.yml b/book/_toc.yml new file mode 100644 index 0000000000000000000000000000000000000000..29b80bffd83b7961752d20978f00671a717e064b --- /dev/null +++ b/book/_toc.yml @@ -0,0 +1,17 @@ +format: jb-book +root: intro + +parts: + - caption: New Material + chapters: + - file: new/blank + - caption: Sandbox + chapters: + - file: sandbox/blank + - file: sandbox/robert + - caption: MUDE Cookbook + chapters: + - file: cookbook/blank + - caption: Old Material + chapters: + - file: old/blank \ No newline at end of file diff --git a/book/cookbook/blank.md b/book/cookbook/blank.md new file mode 100644 index 0000000000000000000000000000000000000000..53d3da816dfd1b422ba7cbbe27c0a901fb6a9a0c --- /dev/null +++ b/book/cookbook/blank.md @@ -0,0 +1,3 @@ +# Cookbook + +Examples. Don't forget to check our [other book](https://interactivetextbooks.citg.tudelft.nl/manual/intro.html), the [repo for the other book](https://gitlab.tudelft.nl/interactivetextbooks-citg/jupyter-book-manual)and the [Jupyter Book website](https://jupyterbook.org/en/stable/). \ No newline at end of file diff --git a/book/figures/MUDE Logo.png b/book/figures/MUDE Logo.png new file mode 100644 index 0000000000000000000000000000000000000000..04329e3d6cdeda5d0b2111d95ad41d99de7d03a5 Binary files /dev/null and b/book/figures/MUDE Logo.png differ diff --git a/book/figures/MUDE LogoLrg.png b/book/figures/MUDE LogoLrg.png new file mode 100644 index 0000000000000000000000000000000000000000..61c45f33216c7b4194e4dca6a0e827b34bbd89a6 Binary files /dev/null and b/book/figures/MUDE LogoLrg.png differ diff --git a/book/intro.md b/book/intro.md new file mode 100644 index 0000000000000000000000000000000000000000..6f1e1b8429cf4f3140d24624e6f042a11fb54406 --- /dev/null +++ b/book/intro.md @@ -0,0 +1,8 @@ +# Home + +```{note} +Right now, the home page of the book simply displays `README.md`. +``` + +```{include} ../README.md +``` diff --git a/book/new/blank.md b/book/new/blank.md new file mode 100644 index 0000000000000000000000000000000000000000..4d1ad70be7fbffae86605c64a544874fcfed8423 --- /dev/null +++ b/book/new/blank.md @@ -0,0 +1,3 @@ +# blank chapter + +There is no content here yet. This file is a chapter. \ No newline at end of file diff --git a/book/old/blank.md b/book/old/blank.md new file mode 100644 index 0000000000000000000000000000000000000000..4d1ad70be7fbffae86605c64a544874fcfed8423 --- /dev/null +++ b/book/old/blank.md @@ -0,0 +1,3 @@ +# blank chapter + +There is no content here yet. This file is a chapter. \ No newline at end of file diff --git a/book/sandbox/blank.md b/book/sandbox/blank.md new file mode 100644 index 0000000000000000000000000000000000000000..4d1ad70be7fbffae86605c64a544874fcfed8423 --- /dev/null +++ b/book/sandbox/blank.md @@ -0,0 +1,3 @@ +# blank chapter + +There is no content here yet. This file is a chapter. \ No newline at end of file diff --git a/book/sandbox/robert.md b/book/sandbox/robert.md new file mode 100644 index 0000000000000000000000000000000000000000..d06c9385dc5e40bd5496e1d8e7888814e479c9f4 --- /dev/null +++ b/book/sandbox/robert.md @@ -0,0 +1,3 @@ +# Robert's Chapter + +He will start adding stuff here when he has time. Which will be...never? \ No newline at end of file diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 0000000000000000000000000000000000000000..501ce694487da607f22fdb68012f46463fa3ae71 --- /dev/null +++ b/requirements.txt @@ -0,0 +1,2 @@ +jupyter-book +sphinx-inline-tabs \ No newline at end of file