-
Notifications
You must be signed in to change notification settings - Fork 263
Season of Docs 2019
Kaleidoscope is applying to participate in Google's Season of Docs in 2019, this is the landing page for that. This page is a collection of information regarding the Season, including a link to ideas and any other useful information.
Kaleidoscope is a plugin- and Arduino-based firmware for computer input devices. The firmware tries to follow the Arduino tradition of making common tasks easy for the novice user. One of our goals is to allow one to get started fast, without little prior knowledge. Documentation is a key part of that.
Ideas listed below also have their corresponding issue on the main Kaleidoscope repository, all labeled with Season of Docs. If you have a new idea, please open an issue, and copy & fill out the template at the end of this page too.
- Organization name: Kaleidoscope
- Organization description: A plugin- and Arduino-based firmware for computer input devices.
- Organization repository: https://github.com/keyboardio/Kaleidoscope
- Organization website: https://kaleidoscope.keyboard.io/ (source)
- Organization admins and mentors: @obra, @algernon
-
Project name: Document
driver::mcu
-
Description: We recently introduced a
driver::mcu
namespace, the goal would be to take the in-code docs and algernon's blog post (see related material below), and write documentation for the namespace (including rationale) and the helper class in it. - Difficulty: Easy.
- Issue: #627
- Related material:
- Project name: HOWTO: Add a modifier to a key on the keymap
- Description: If there's one thing people often do with open-source firmware, making keys emit a key combo (a chord) is as close to one's "Hello World" as it can be. The goal of this project is to have a short, step-by-step howto that explains how to do this, and what limitations there are. The HOWTO should assume that the reader can already compile the unmodified factory firmware.
- Difficulty: Easy.
- Issue: #214
- Project name: HOWTO install third-party plugins?
- Description: While Kaleidoscope ships with a large number of plugins built-in, there are some that aren't part of the bundle. We'd need a step-by-step howto that explains how to install and use third-party plugins.
- Difficulty: Medium
- Issue: #235
- Related material:
- Project name: HOWTO work with the Focus protocol?
-
Description:
Focus
is the protocol we developed to allow the host and the keyboard to talk. It's a bi-directional communication protocol, upon which Chrysalis is built. While there is some documentation about the protocol, there is no guide to teach one how to work with it. The goal here is to have a guide that shows that, preferably with code examples in a popular language. Optionally, the documentation should have a list of Focus commands supported by the core firmware and plugins bundled with it, to make it easier to figure out what can be readily done with it. - Difficulty: Medium
- Issue: #412
- Related material
- Project name: Architecture documentation
- Description: We have a fair amount of in-code documentation, lots of examples, but no high-level overview of the Kaleidoscope architecture. We have helper classes, drivers, subsystems (think EEPROM-Settings or LEDControl), but no documentation of how the pieces of the puzzle fit together. the goal of this project is to create an overview that does just that.
- Difficulty: Difficult.
- Issue: #163
- Project name: Coding style guidelines
- Description: We started to develop our coding style guidelines, but to this day, the document has not been finished yet. The goal of this project would be to go over the existing documentation, remove parts which aren't applicable, update parts which we do differently, and add guidelines we use, which aren't part of the guide yet.
- Difficulty: Challenging. There's a lot of information to process, both because the coding style we based ours on is long, and because one needs to be aware of the intricacies of embedded development.
- Issue: #134
- Related material:
NOTE: Do not edit this template directly, copy it and fill that out instead, and add an entry to the Table of Contents at the top of the page!
- Project name: Choose a concise but descriptive title.
- Description: A longer description of the documentation work required. Describe your initial idea in detail. Offer opportunities for any interested technical writers to expand or refine the idea.
-
Related material:
- Link to the open source project that needs documentation. This should be a link to the matching issue on the Kaleidoscope repository.
- If you're proposing a technical writing project that involves updates to an existing documentation set, link to that documentation set.
- If you're proposing a tutorial or a set of how-to guides, describe the features or use cases that need documenting.
- If you're proposing a contributor's guide, link to any existing README file or other relevant material if present. If there's nothing available yet, it's fine to say that.
- Include links to similar documentation in other projects, if relevant.
Troubleshooting
Advanced Topics
Development and customization
Keyboardio Model 01 docs
- Keyboardio Model 01 Introduction
- Flashing a new bootloader
- Default Model 01 QWERTY Layout
- Common Alternate Layouts
- Hardware Test Mode
Community