Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 4 additions & 0 deletions .github/workflows/ci-all.yml
Original file line number Diff line number Diff line change
Expand Up @@ -76,6 +76,10 @@ jobs:
needs_chromedriver: false
needs_audio: true
extra_requirements: ''
- emulator: DocBoy
needs_chromedriver: false
needs_audio: true
extra_requirements: ''
uses: ./.github/workflows/emulator-runner.yml
with:
emulator: ${{ matrix.emulator }}
Expand Down
18 changes: 18 additions & 0 deletions .github/workflows/ci-docboy.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,18 @@
name: CI - DocBoy

on:
workflow_dispatch:

permissions:
contents: write

jobs:
run:
uses: ./.github/workflows/emulator-runner.yml
with:
emulator: DocBoy
needs_audio: true

deploy-pages:
needs: run
uses: ./.github/workflows/deploy-pages.yml
1 change: 1 addition & 0 deletions emulators/docboy.ini
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
dmg_palette=FFFF,AD55,52AA,0000,FFFF
24 changes: 24 additions & 0 deletions emulators/docboy.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
from util import *
from emulator import Emulator
from test import *
import os
import shutil


class DocBoy(Emulator):
def __init__(self):
super().__init__("DocBoy", "https://github.com/Docheinstein/docboy", startup_time=1, features=(PCM,))

def setup(self):
for model in ["dmg", "cgb"]:
downloadGithubRelease(f"Docheinstein/docboy", f"downloads/docboy-{model}.zip", filter=lambda n: model in n and "win" in n)
extract(f"downloads/docboy-{model}.zip", f"emu/docboy-{model}")
setDPIScaling(f"emu/docboy-{model}/docboy-sdl.exe")
shutil.copyfile(os.path.join(os.path.dirname(__file__), "docboy.ini"), f"emu/docboy-{model}/docboy.ini")

def startProcess(self, rom, *, model, required_features):
model = {DMG: "dmg", CGB: "cgb"}.get(model)
if model is None:
return None
return subprocess.Popen([f"emu/docboy-{model}/docboy-sdl.exe", os.path.abspath(rom), "-c", "docboy.ini", "-z", "1"],
cwd=f"emu/docboy-{model}")
6 changes: 6 additions & 0 deletions main.py
Original file line number Diff line number Diff line change
Expand Up @@ -150,6 +150,12 @@ def _new_instance(module_name, class_name):
'name': "gameroy",
'url': "https://github.com/Rodrigodd/gameroy",
},
{
'factory': lambda: _new_instance("emulators.docboy", "DocBoy"),
'keywords': ["DocBoy", "docboy"],
'name': "docboy",
'url': "https://github.com/Docheinstein/docboy",
},
]


Expand Down