██████╗ ██████╗  █████╗  ██████╗████████╗██╗ ██████╗ █████╗ ██╗     ██╗     ██╗
██╔══██╗██╔══██╗██╔══██╗██╔════╝╚══██╔══╝██║██╔════╝██╔══██╗██║     ██║     ██║
██████╔╝██████╔╝███████║██║        ██║   ██║██║     ███████║██║     ██║     ██║
██╔═══╝ ██╔══██╗██╔══██║██║        ██║   ██║██║     ██╔══██║██║     ██║     ██║
██║     ██║  ██║██║  ██║╚██████╗   ██║   ██║╚██████╗██║  ██║███████╗███████╗██║
╚═╝     ╚═╝  ╚═╝╚═╝  ╚═╝ ╚═════╝   ╚═╝   ╚═╝ ╚═════╝╚═╝  ╚═╝╚══════╝╚══════╝╚═╝
███████╗██████╗  █████╗  ██████╗███████╗███╗   ███╗ █████╗  ██████╗███████╗
██╔════╝██╔══██╗██╔══██╗██╔════╝██╔════╝████╗ ████║██╔══██╗██╔════╝██╔════╝
███████╗██████╔╝███████║██║     █████╗  ██╔████╔██║███████║██║     ███████╗
╚════██║██╔═══╝ ██╔══██║██║     ██╔══╝  ██║╚██╔╝██║██╔══██║██║     ╚════██║
███████║██║     ██║  ██║╚██████╗███████╗██║ ╚═╝ ██║██║  ██║╚██████╗███████║
╚══════╝╚═╝     ╚═╝  ╚═╝ ╚═════╝╚══════╝╚═╝     ╚═╝╚═╝  ╚═╝ ╚═════╝╚══════╝
NOTE: Ascii Art Generator: https://patorjk.com/software/taag/#p=display&f=ANSI%20Shadow&t=Astro%205
Software enginering with Emacs and Spacemacs community configuration, with a focus on the Clojure programming language, using the Clojure REPL driven development workflow.
The aim is to help you be productive with software engineering tools as quickly as possible.
Spacemacs is a community-driven project that provides a simple way to add lots of extra functionality to Emacs, without having to manage packages yourself or spend time writing common configuration code.
Discuss this guide on #practicalli channel of the Clojurians Slack community.
Create a free Clojurians Slack community account.
This workshop will cover the following topics:
- Emacs basics, common commands and tools
- Powerful editing and refactor tools (iedit, narrowing, helm-ag, multiple cursors, visual undo)
- Adding and enhancing the Clojure layer
- Running the REPL, evaluating code, inspecting data, debug, reloaded workflow
- Running tests & test reports
- Structural editing (smartparens/evil-cleverparens)
- Clojure docs, auto-completion, snippets
- Clojurescript development, figwheel-main and reagent
- Org-mode for project documentation, literate programming & presentations
 This work is licensed under a Creative Commons Attribution 4.0 ShareAlike License (including images & stylesheets).
  This work is licensed under a Creative Commons Attribution 4.0 ShareAlike License (including images & stylesheets).
Issues and pull requests are most welcome although it is the maintainers discression as to if they are applicable. Please detail issues as much as you can. Pull requests are simpler to work with when they are specific to a page or at most a section. The smaller the change the quicker it is to review and merge.
Please read the detailed Practicalli contributing page before raising an issue or pull request to avoid disapointment.
By submitting content ideas and corrections you are agreeing they can be used in any work by Practicalli under the Creative Commons Attribution ShareAlike 4.0 International license. Attribution will be detailed via GitHub contributors.
All sponsorship funds are used to support the continued development of Practicalli series of books and videos, although most work is done at personal cost and time.
Thanks to Cognitect, Nubank and a wide range of other sponsors for your continued support
The megalinter GitHub actions will run when a pull request is created,checking basic markdown syntax.
A review of the change will be carried out by the Practicalli team and the PR merged if the change is acceptable.
The Publish Book GitHub action will run when PR's are merged into main (or the Practicalli team pushes changes to the default branch).
Publish book workflow installs Material for MkDocs version 9
Install mkdocs version 9 using the Python pip package manager
pip install mkdocs-material=="9.5"Install the plugins used by the Practicalli site using Pip (these are also installed in the GitHub Action workflow)
pip3 install mkdocs-material mkdocs-callouts mkdocs-glightbox mkdocs-git-revision-date-localized-plugin mkdocs-redirects pillow cairosvgpillow and cairosvg python packages are required for Social Cards
Fork the GitHub repository and clone that fork to your computer,
git clone https://github.com/<your-github-account>/<repository>.gitRun a local server from the root of the cloned project
make docsThe website will open at http://localhost:8000
If making smaller changes, then only rebuild the content that changes, speeding up the local development process
make docs-changedNOTE: navigation changes may not be correctly reflected without reloading the page in the web browser or carrying out a full
make docsbuild

