-
Notifications
You must be signed in to change notification settings - Fork 263
Setting up a development environment
This page was created using OSX Catalina as an underlying system. the procedure should also work with other operating systems, but directories will be different. (on linux the Arduino dir is in $HOME/Arduino, on OSX it is $HOME/Documents/Arduino).
This page is for developers who want to go beyond using the Arduino IDE in order to do more complicated things. (If you are happy with the Arduino IDE, and you do not want to have the latest and greatest, maybe unstable development version of kaleidoscope running on your keyboard, then you can ignore this page.) You should be familiar with basic git commands. If that is totally new to you, you should consider having a look at some tutorials first.
If you want to make changes to the Kaleidoscope runtime or any of the bundled plugins and have previously installed Kaleidoscope or the Keyboardio hardware definitions using the Arduino Boards Manager, you will need to uninstall that prebuilt package and replace it with the GitHub version. This will make it easier to update to the latest versions of Kaleidoscope and Kaleidoscope plugins, and to propose changes to them with GitHub pull requests.
- If you installed the Keyboardio via the Arduino Boards Manager, you have to click “remove” there on the keyboardio hardware definitions. If you miss that step, your checked out keyboardio-bundle will always use the sources installed/downloaded in Arduino. You can see that when compiling from commandline: a different path for the includes is being used (~/Library/Arduino15/...)
- Follow the instructions in the Kaleidoscope readme. Please make sure, you checkout all submodules! The command would be
git submodules update --recursive --init
, if you miss that step, you will not have a firmware folder!
At this point, you should have a directory structure like this (OSX):
$HOME
\
|----Documents
\
|--- Arduino
\
|--- hardware
\
|--- keyboardio <--- this is the dir you checked out the code into
\
|--- build-tools
|--- tool-chain
|--- ... (some other files)
|--- avr
\
|--- libraries
\
|--- Model01-Firmware <--- this is where you customize your code, a git submodule!
- Try compiling the standard Firmware:
cd ~/Documents/Arduino/hardware/keyboardio/avr/libraries/Model01-Firmware
-
make
- this will just compile your code and not try to upload things. It will show a ton of output, which you can ignore in most cases. If it fails, check, if all prerequisites are met and the checkout worked properly. -
make flash
. When you get thePress ENTER to continue
prompt, hold down theProg
key on your keyboard, then press enter, and release the prog key as soon as it glows red. You should see red leds light up along the left half of your keyboard. When that command completes, the board should have flashed the standard layout. If you did any changes before using Arduino, you might want to copy that over and try it. The path for the Arduino sketches Model01 firmware example is usually ~/Documents/Arduino/Model01-Firmware.
I would recommend creating your own Firmware-Directory for developing purpose (or more than one?). This way, you can keep the original one always as a reference, and you can publish ours on github independently.
I did the following:
- create a new directory in the
libraries
folder: `mkdir ~/Documents/Arduino/hardware/keyboardio/avr/libraries/MyLayout´ - copy the contents of the
Model01-Firmware
directory over into that:cd ~/Documents/Arduino/hardware/keyboardio/avr/libraries/MyLayout; cp -r ../Model01-Firmware/* .
- in that directory, the
make
andmake flash
commands should work. - if you want to (also) use the Arduino IDE for this, you need to rename the ino-file to match the directory name (in our case
MyLayout.ino
and change the name in the filelibrary.properties
accordingly.
At this point, you've got a command-line workflow to install the default sketch. The next step is...
If you only want to develop locally, and don't want to share your setup or have public backups on github, you're done! You can make all the changes you want in the directories you cloned above or in your own firmware directory.
To modify the firmware and keep your own copy of it on GitHub, you can use two options:
- fork the
Model01-Firmware
repo on github and check that out locally:
$ cd ~/Documents/Arduino/hardware/keyboardio/avr/libraries/
$ git clone [email protected]:mygithubuname/Model01-Firmware.git mygithubuname-firmware
$ cd mygithubuname-firmware
$ make flash
edit edit edit edit
$ make flash
- use the directory created for your own developtment, where you copied the content from the default Firmware to. To use that, create a new repository on github and follow the instructions shown for adding existing projects. i the first option has the advantage that you could open pull requests for having your changes included into the official repository. The second one makes things more independent.
But in both cases: Modify your local copy to your heart's content, and push your changes to github whenever you want.
To make things accessible more convinient you can add a link to your Firmware-directory somewhere in the filesystem: cd ~/projects; ln -s ~/Documents/Arduino/hardware/keyboardio/avr/libraries/MyLayout
- this would create a link to your layout directory in our personal projects-folder. Compiling it should also work from that directory.
At some point, you'll probably want to update the version of Kaleidoscope-Bundle-Keyboardio
, too:
cd ~/Documents/Arduino/hardware/keyboardio/
git pull
git submodule update --recursive --remote --init
Just try some git frontends to help you find you way round in that directory and all those submodules.
Having the layout is one thing, but you maybe want to include some special functions using kaleidoscopes own plugin api. You can add your own plugins in your sketch directory in the src
folder. There you created the .cpp and .h files and those can be included in your sketch.
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