Skip to content

Latest commit

 

History

History
56 lines (50 loc) · 2.88 KB

README.md

File metadata and controls

56 lines (50 loc) · 2.88 KB


Mineboy

Mineboy is an open source gameboy emulator designed for ComputerCraft. It uses a streaming server and client because the lua runtime in CC is slow.

Screenshots
1 2

MineBoy showcase video

Install guide

Server

  1. Install either docker and docker compose or NodeJS
  2. Clone this repository.
  3. Copy .env.example to .env and edit with proper config vars.
    • If you are running Mineboy on a public server, you may want to secure the server with a password or prevent abuse from other players. Mineboy has a built-in security policy feature which can limit the number of connections. To use this feature, you must set the SECURITY environment variable or fill the security.json file with the following information:
      [
        {
          "name": "TestPolicy",
          "password": "testpassword",
          "connections": 2
        }
      ]
      This will ensure that only two connections are allowed using that password/policy at any given time. Additionally, if you set a password, only users who know the password will be able to connect to the server. If the security policy configuration is nonexistant or [] it will be unsecured.
  4. Create roms folder with all GB/GBC roms.
  5. Run the script
    • For Node
      • Run npm install && npm build to install dependencies.
      • Run node dist/index.js to run.
    • For Docker (proffered for headless)
      • Run docker-compose up -d
  6. Edit all clients mineboy_config.lua files with proper httpUrl and wsUrl settings.

Client

  1. Run pastebin run JubutEmL and select the number with a client.
  2. Edit mineboy_config.lua with proper config options.
  3. Run mineboy.lua (rename to startup if you want to run this on startup).

Controller

  1. Make sure the computer you are installing this on has a wireless modem and rednet is enabled in mineboy_config.lua
  2. Run pastebin run JubutEmL and select the number with controller.
  3. Type the rednet ID in the controller (this will be printed on the client).