# sinara-assembly Repository with instructions and remarks on assembling and testing Sinara hardware ## Build docs ```shell nix build ``` The output files are in `result/book` directory. ### Development shell ```shell nix develop mdbook build ``` The output files will be in `book` directory. ### Alternative way Since the docs builder depends only on mdBook, you may get it from anywhere you like - `nix-shell -p mdbook`, `snap install mdbook`, `cargo install mdbook` or any other from your OS. After that you will be able to do: ```shell mdbook build ``` The output files will be in `book` directory. ## Contributing If you found missing hardware or just want to add/enhance hints and instructions, feel free to push them. Tips for adding hardware instructions: 1. Compose a chapter in a new Markdown file in `src/hw` 2. Add pictures if needed, store them in `src/img`, assure them to be clear, informative and compressed (you can use `convert <INPUT IMAGE> -quality 80% -resize <width>x<height> <OUTPUT IMAGE>` for optimizing JPEG image or `convert <INPUT IMAGE> -quality 80% -resize <width>x<height> -background white -alpha remove -alpha off <OUTPUT IMAGE>` for images with transparent background) 3. Add link to the new chapter to the `src/SUMMARY.md` 4. Do not forget to tell about all hidden/non-obvious obstacles and pitfalls 5. Avoid using uncommon, complex, or hard-to-understand words, phrases, or grammar (e.g., ❌constituent -> ✔️component). Keep in mind that these guides may be used by people with different backgrounds and levels of English proficiency. 6. Add testing steps, even the "obvious" ones 7. Add JSON sample if needed 8. Add hardware setup (e.g. pins, switches) steps if needed 9. View changed and added pages with `mdbook build` (see building instructions above) 10. Check your contributions with linter: ```shell nix-shell -p nodejs npm install npx markdownlint-cli2 "src/**/*.md" --fix ```