Compare commits

...

20 Commits

Author SHA1 Message Date
Neale Pickett 195c02748b Clean up publish script
Mockband / build (push) Successful in 26s Details
2024-01-08 13:13:42 -07:00
Neale Pickett 13825855d3 twiddling things trying to get drums working on CH
Mockband / build (push) Failing after 16s Details
2024-01-06 15:08:12 -07:00
Neale Pickett e54595e630 Merge branch 'main' into builder 2024-01-05 18:18:18 -07:00
Neale Pickett 63bd067250 More idiomatic (to me) Makefile
Mockband / build (push) Failing after 11s Details
2024-01-05 09:29:16 -07:00
Neale Pickett 9f0c0711a8 fancypants flash target
Mockband / build (push) Failing after 9s Details
2024-01-05 09:10:28 -07:00
Neale Pickett efc67e9fe5 Also publish zip file
Mockband / build (push) Failing after 10s Details
2024-01-05 09:06:59 -07:00
Neale Pickett ce7d6107cf stop using removed `make publish`
Mockband / build (push) Successful in 15s Details
2024-01-05 09:04:51 -07:00
Neale Pickett 48d2450514 make dist
Mockband / build (push) Failing after 12s Details
2024-01-05 09:02:53 -07:00
Neale Pickett 5f44832151 move to Makefile
Mockband / build (push) Successful in 33s Details
2024-01-05 08:50:10 -07:00
Neale Pickett da45584955 Makefile
Mockband / build (push) Successful in 26s Details
2024-01-05 08:37:03 -07:00
Neale Pickett 50ce7c245a Fix quoting
Mockband / build (push) Successful in 22s Details
2024-01-04 23:16:08 -07:00
Neale Pickett f767eb6e23 Build log formatting
Mockband / build (push) Failing after 4s Details
2024-01-04 23:15:05 -07:00
Neale Pickett 7495bfd20f Try preserving package versions
Mockband / build (push) Successful in 21s Details
2024-01-04 23:12:51 -07:00
Neale Pickett 5fa607d6b0 build and code cleanup
Mockband / build (push) Successful in 25s Details
2024-01-04 22:59:14 -07:00
Neale Pickett 855ad3ba60 fix: change quoting?
Mockband / build (push) Successful in 21s Details
2024-01-04 22:48:20 -07:00
Neale Pickett 25a917dc81 directly specify gcc flags
Mockband / build (push) Failing after 5s Details
2024-01-04 22:42:11 -07:00
Neale Pickett a8d4918e05 variables expand again
Mockband / build (push) Failing after 3s Details
2024-01-04 22:23:03 -07:00
Neale Pickett 544ffa8ced quote stuff
Mockband / build (push) Failing after 3s Details
2024-01-04 22:21:25 -07:00
Neale Pickett a3d8262e01 fix build on non-default branch
Mockband / build (push) Failing after 6s Details
2024-01-04 22:19:58 -07:00
Neale Pickett 0ba9c0957a Clever vid/pid settings?
Mockband / build (push) Successful in 19s Details
2024-01-04 22:16:36 -07:00
7 changed files with 80 additions and 61 deletions

View File

@ -1,46 +0,0 @@
#! /bin/sh
set -e
log () {
echo "=== $*"
}
# Make sure we're in the project directory
cd $(dirname $0)/..
mkdir -p out/
while read variant vid pid flags; do
log
log "Building $variant ($vid:$pid)"
log
# We can overload build.extra_flags from boards.txt,
# so just specify the -D flags to gcc
flags="$flags -DUSB_VID=$vid -DUSB_PID=$pid"
flags="$flags -DUSB_MANUFACTURER=\"woozle.org\""
flags="$flags \"-DUSB_PRODUCT=\"Mockband $variant\"\"" # wtf quoting
flags="$flags -DCDC_DISABLED"
# Arduino gets cranky when it tries to use its own cache
rm -rf build/
mkdir -p build/cache/
arduino-builder \
-build-path $(pwd)/build/ \
-build-cache $(pwd)/build/cache/ \
-fqbn arduino:avr:leonardo \
-hardware /usr/share/arduino/hardware \
-tools /usr/share/arduino/tools \
-prefs="build.extra_flags=$flags" \
-compile MockBand.ino
mv build/MockBand.ino.hex out/MockBand.$variant.hex
done << EOD
guitar 0x1bad 0x0004
guitar-wammy 0x1bad 0x0004 -DWAMMY
drums 0x1bad 0x3110
EOD
ls -l out/

View File

@ -7,17 +7,21 @@ VERSION=$GITHUB_REF_NAME
BASE=$GITHUB_SERVER_URL/api/packages/$GITHUB_ACTOR/generic/$PACKAGE/$VERSION
for path in "$@"; do
fn=$(basename "$path")
echo "=== Upload $VERSION/$fn"
echo "=== Delete $VERSION"
curl \
--user "$GITHUB_ACTOR:$PACKAGE_API_TOKEN" \
--request DELETE \
$BASE/$fn
$BASE
echo
for path in "$@"; do
fn=$(basename "$path")
echo "=== Upload $VERSION/$fn"
curl \
--fail \
--user "$GITHUB_ACTOR:$PACKAGE_API_TOKEN" \
--upload-file "$path" \
$BASE/$fn
echo
done

View File

@ -9,9 +9,11 @@ jobs:
steps:
- name: check out repository
run: git clone -b $GITHUB_REF_NAME $GITHUB_SERVER_URL/$GITHUB_REPOSITORY .
- name: build
run: .gitea/build.sh
- name: build firmwares
run: make
- name: build zip file
run: make dist
- name: publish
env:
PACKAGE_API_TOKEN: ${{ secrets.PACKAGE_API_TOKEN }}
run: .gitea/publish.sh out/*
run: .gitea/publish.sh build/*.zip build/*.hex

1
.gitignore vendored
View File

@ -1,2 +1,3 @@
*.zip
*.hex
build/

49
Makefile Normal file
View File

@ -0,0 +1,49 @@
DEVICE=/dev/ttyACM0
all: firmwares
firmwares: build/MockBand.guitar-wammy.hex
build/MockBand.guitar-wammy.hex: VID=0x1bad
build/MockBand.guitar-wammy.hex: PID=0x0004
build/MockBand.guitar-wammy.hex: FLAGS=-DWAMMY
firmwares: build/MockBand.guitar.hex
build/MockBand.guitar.hex: VID=0x1bad
build/MockBand.guitar.hex: PID=0x0004
firmwares: build/MockBand.drums.hex
build/MockBand.drums.hex: VID=0x1bad
build/MockBand.drums.hex: PID=0x3110
firmwares: build/MockBand.drums1.hex
build/MockBand.drums1.hex: VID=0x1bad
build/MockBand.drums1.hex: PID=00005
build/MockBand.%.hex: MockBand.ino
mkdir -p build/cache
rm -f build/build.options.json
arduino-builder \
-build-path $(abspath build/) \
-build-cache $(abspath build/cache/) \
-fqbn arduino:avr:leonardo \
-hardware /usr/share/arduino/hardware/ \
-tools /usr/share/arduino/tools/ \
-prefs="build.extra_flags=-DUSB_VID=$(VID) -DUSB_PID=$(PID) '-DUSB_PRODUCT=\"Mockband $*\"' -DUSB_MANUFACTURER=\"woozle.org\" -DCDC_DISABLED $(FLAGS)" \
-compile $<
mv build/MockBand.ino.hex $@
flash-%: build/MockBand.%.hex
echo -n "Waiting for $(DEVICE)..."; while [ ! -e $(DEVICE) ]; do echo -n .; sleep 1; done
avrdude -v -patmega32u4 -cavr109 -P$(DEVICE) -b57600 -D -Uflash:w:$<:i
dist: build/MockBand.zip
build/MockBand.zip: firmwares
rm -f $@
zip -r $@ README.md build/*.hex docs/
clean:
rm -rf build

View File

@ -142,8 +142,8 @@ void loop() {
}
#else // DRUMS
buttonState.buttons |= (buttons >> 10) & 0b01011; // Cymbals
bitWrite(buttonState.buttons, 10, buttons & (0b01111 << 0)); // Drum pad modifier
bitWrite(buttonState.buttons, 11, buttons & (0b01011 << 10)); // Cymbals modifier
bitWrite(buttonState.buttons, 10, (buttons >> 0) & 0b01111); // Drum pad modifier
bitWrite(buttonState.buttons, 11, (buttons >> 10) & 0b01011); // Cymbals modifier
buttonState.axis[3] = bitRead(buttons, 12)?255:0; // High hat
// rbdrum2midi wants these set
@ -151,6 +151,9 @@ void loop() {
buttonState.velocity[1] = bitRead(buttonState.buttons, 2)?127:0; // R
buttonState.velocity[2] = bitRead(buttonState.buttons, 1)?127:0; // G
buttonState.velocity[3] = bitRead(buttonState.buttons, 0)?127:0; // B
// Say the D-pad is centered
buttonState.hatAndConstant = 8;
#endif
#ifdef DPAD

View File

@ -70,13 +70,19 @@ Here's what each bit means:
hatAndConstant
--------------
Here's what the values mean:
The HAT switch reports its position like a clock.
* 2: right
* 6: left
* 0: up
* 4: down
* 8: nothing
7 0 1
6 8 2
5 4 3
0 is up,
2 is right,
4 is down,
6 is left,
and 8 is centered.
velocity