Portable single-threaded C client for early RS2, the last update before a new cache format and ondemand protocol.
Compatible with 2004Scape, the most accurate runescape remake
Features:
- should work on any 32 bit system with 64 MB of RAM on lowmem, networking and a (read-only) filesystem.
- webassembly build to avoid javascript code being optimized out by the browser.
- WIP ports for most game consoles from 1998 until 2013! See docs for images.
- optional config.ini file to change client behaviour. Create an empty config.ini to avoid passing cli args.
All you need to build for 32 bit windows is included:
- tinycc (C compiler, built with
TCC_C=..\tcc.c
env var and removed bcheck lib) - all 32 bit SDL dlls, only SDL1 works prior to windows XP and is always 32 bit unlike the others
To build simply run build.bat
in cmd to get the client.exe, optionally set SDL ver -v 1|2|3
and C compiler -c tcc|gcc|emcc
.
SDL1 is default for tcc and old mingw-gcc to target windows 9x, but only SDL2/3 have sfx right now. This (unofficial) release doesn't require msys install: https://github.com/fsb4000/gcc-for-Windows98/releases. mingw-gcc 11 optimizations seem to only be slightly faster than tcc though.
If the client fails to start you either aren't passing cli args and don't have a config.ini OR you are using a SDL dll for the wrong architecture. Delete it and it'll be copied during next build
To move the executable you have to take the correct SDL.dll
, config.ini
, and the rom/
directory along with it. The consoles will load it from sdcard if they don't embed the files already.
type ::perf
command ingame to see fps and lrucache size
all home consoles (wii, dreamcast, xbox) should be able to run the game at higher res or even full res on PAL TVs so you don't have to pan, but this isn't set up and emulators don't support many video modes.
When adding a new platform also add system ttf font closest to helvetica in gameshell_draw_string when available to avoid Roboto dependency.
To be able to run some emulators on WSL2 you may need to prefix MESA_GL_VERSION_OVERRIDE=4.6 MESA_GLSL_VERSION_OVERRIDE=460
.
If tcc from your package manager isn't working you should build latest tcc from source
v86 is a x86 PC emulator running in the browser, including older windows.
build.bat(32 bit): tcc (included), mingw-gcc, emcc
run.ps1: cl, clang, tcc, mingw-gcc, emcc
You might want the updated PowerShell for run.ps1
TODO: add wav sfx to complete SDL1 platform for win9x
TODO: make win9x compatible batch file (no delayed expansion?) right now needs to build from more modern system
TODO: clean up ps1 script so it doesn't need to be modified
NOTE: on v86 PC emulator the cursor flickers on win95, and colours on win9x are wrong? win2k is fine
Makefile: gcc, clang, tcc, mingw-gcc, emcc
arm+musl platforms like postmarketOS can use tcc but it requires some small tweaks:
- comment out wchar_t in include/stddef.h
- build with: https://lists.gnu.org/archive/html/tinycc-devel/2022-02/msg00038.html TODO SDL3 fails to init?
Install sdl1/sdl2 or sdl3+pkgconf and run gmake SDL=1/2/3
TODO
Install clang and get wasmlite (you need the libc and generated index.html)
then run make -f wasm.mk run DEBUG=0
with correct sysroot path.
You must add ?client
to the URL and optionally append &arg 1&arg 2&arg 3&arg 4
.
You can configure ip and port in config.ini.
The only needed files are the index.html + client.wasm and optionally the soundfont/config.ini relative to it.
enable cors in server web.ts with res.setHeader('Access-Control-Allow-Origin', '*');
TODO fwrite maps like emscripten
TODO add to build.bat/ps1 to replace emscripten
Install emsdk
run emmake make
/make CC=emcc
or build.bat -c emcc
for windows
For make you can append run
to start a http server and DEBUG=0
to optimize. Then go to ip:port/client.html
(or another entrypoint)
Pass 4 args in shell.html to use the ip + port from URL instead of config, otherwise set http_port to 8888 in config for linux servers.
The only needed files are the index.html,js,wasm
and optionally the soundfont/config.ini relative to it.
enable cors in server web.ts with res.setHeader('Access-Control-Allow-Origin', '*');
TODO: audio stream is pushed to on same thread causing scape_main stutters, and lowmem w/o audio speeds up (typescript client uses absolute time for idlecycles)
TODO: use indexeddb (add cacheload and cachesave), and maybe add [web worker clientstream](https://emscripten.org/docs/api_reference/wasm_workers.html)
TODO: mobile controls: touch on release + touch to rotate + osk + mouse+kbd, PWA manifest
NOTE: could replace sdl3 audio with https://emscripten.org/docs/api_reference/wasm_audio_worklets.html and decodeAudioData for wavs
NOTE: JSPI decreases output size a lot, but asyncify can be used for older browser compatibility. Windows and Linux output size might differ and sigint on Windows will cause terminate batch job message if using emrun.
NOTE: unused old worldlist code: [shell.html](https://github.com/lesleyrs/Client3/commit/5da924b9f766005e82163d899e52a5df2f771584#diff-c878553ed816480a5e85ff602ff3c5d38788ca1d21095cd8f8ebc36a4dbc07ee)
mkdir ~/android && cd ~/android
and download android command line tools to it + accept licenses whenever it asks- enable developer options by tapping build number, then you can pair and connect to the device through wifi:
$HOME/android/platform-tools/adb pair IP:PORT
$HOME/android/platform-tools/adb connect IP:PORT
- In Client3/android-project run
ANDROID_HOME="$HOME/android/" ./gradlew installDebug
- The APK will be in android-project/app/build/outputs/apk/debug/ and installed on the device
- you can also start it remotely:
$HOME/android/platform-tools/adb shell am start -n org.libsdl.app/.SDLActivity
- show error/fatal logging with:
$HOME/android/platform-tools/adb logcat *:E | grep 'org.libsdl.app'
- in Client3/android-project/app/jni run
mkdir SDL
- git clone SDL, git checkout SDL2 branch and run
cp -r Android.mk include src SDL
- symlink src and rom directories:
cd android-project/app/jni/src && ln -s ../../../../src src
cd android-project/app/src/main && ln -s ../../../../rom assets
- set Client LOCAL_CFLAGS and LOCAL_SRC_FILES app/jni/src/Android.mk
- enable networking in app/src/main/AndroidManifest.xml
<uses-permission android:name="android.permission.INTERNET" />
https://github.com/libsdl-org/SDL/blob/SDL2/docs/README-android.md - from "For more complex projects"
https://github.com/libsdl-org/SDL/blob/SDL2/docs/README-touch.md
TODO: long press right click? click on touch release? hold in viewport to rotate? share code with postmarketos
TODO: osk by adding using custom.c funcs (move them to gameshell?)
Install devkitpro with (nds/wii/3ds/wiiu/switch)-dev package and run make -f (nds/wii/3ds/wiiu/switch).mk -j$(nproc) -B
.
Wii U and Switch also need the (wiiu/switch)-sdl2 package.
in dolphin emulator you can find the sdcard path in options>configuration>wii>sd card
settings and after moving the files there you have to click Convert Folder to File Now
to format it.
Controls: wiimote IR pointer works as mouse, A for left click, B for right click, Dpad works as arrow keys, minus for control, plus to pan by moving your wiimote to a side of the screen, 1 to center screen, home button to exit. The nunchuck joystick can also be used as arrow keys.
TODO: support usb keyboard (dolphin doesn't emulate it yet)
TODO: add game offset expected for real hardware?
The NDS target only works on a 2DS/3DS using TWiLight Menu++
as it exposes the additional 16 MB of RAM.
melonDS doesn't yet emulate 3ds/debugger ram.
TODO: make nds playable by manually writing to 0x0D000000-0x0E000000 on client_load https://blocksds.skylyrac.net/docs/technical/memory_map/#4-main-ram
in citra emulator click file>open citra folder
for sdmc dir https://citra-emulator.com/wiki/user-directory/
on real hardware move the contents of the rom/ dir next to the 3dsx file.
Controls:
- Touch to left click + hold A to right click
- Circle/Dpad for arrow keys + hold L/R to pan top/bot screens
- B for control (run)
- Start to align bottom screen, Select to toggle ::perf stats
TODO: fix crashing sometimes on home button exit
TODO: enable audio in lowmem, swkbd to type, backlight toggle? pica gpu hw accel
TODO: possible to toggle top screen console? right now requires 2 loc changes
TODO: see new 2ds/3ds performance with higher cpu clock, old 2ds runs at ~10-20
in cemu emulator click file>open mlc folder
, go 1 directory up to see sdcard dir
TODO: Touch input not working yet, might be fixed by last wiiu-sdl2 commit.
NOTE: libtom encryption fails when it works on old wii? (tiny-bignum is ok)
NOTE: highmem doesn't start due to tinysoundfont not working on powerpc
in suyu emulator (yuzu fork) click file->open suyu folder
for sdmc dir
Install pspdev and run make -f psp.mk -j$(nproc) -B
.
ppsspp emulator loads relative dir as memstick, so the filesystem works automatically. Also you should probably enable printf logging with settings>tools>developer tools>logging channels>printf
to EG verbose
Controls: move cursor with analog stick, O for left click, X for right click, /\ for control, Dpad as arrow keys, Rtrigger + analog stick to pan, Ltrigger to reset screen position
Works on real hardware but requires at least model 2000 due to only 24MB (28MB with kernel mode not sure if safe to use?) being accessible on model 1000, only lowmem fits in memory so we force lowmem in custom.c
NOTE: Could add sfx and/or midi in lowmem, since it's the most important highmem feature
Install vitasdk and run make -f vita.mk -j$(nproc) -B
.
can test with Vita3K, instead of decompressing the vpk you can copy just the eboot.bin after changes (pass -r VSDK20225
to run directly)
Controls: touch as mouse, X for right click, /\ for control, Dpad as arrow keys
TODO: vitagl, update sce_sys assets, backside touch input, osk input
TODO: add sdl3 to makefile or remove sdl altogether, it annoyingly saves sdl logs
Install kallistios and mkdcdisc and run make -f dreamcast.mk -j$(nproc) -B
. Necessary files are built into the cdi.
To try on real hardware you'd need networking support and the 32 MB ram expansion mod, which seems involved and maybe less compatible with some other games. Flycast seems to be the best emulator and supports both.
See defines.h for inauthentic changes to get below 32MB RAM usage. The city of Ardougne isn't accessible as it uses up to 12MB ram in allocator.
Controls: joystick = move cursor, Dpad = arrow keys, B = left click, A = right click, Y = control, Ltrig = center screen, Rtrig+joystick = pan screen
There's currently no way to type. But it's not required to play the game and you can set your login details in rom/config.ini
TODO: try to make use of dreamcast vram or aram
TODO: support mouse/keyboard for dreamcast. For mouse and keyboard in flycast you have to set the physical device ports to dreamcast device port, but mouse is not very useful in emu until they hide the system cursor.
NOTE: if the cdi doesn't load you might have to remove --no-padding in Makefile? untested on hardware
NOTE: local servers don't work on emulator? only remote servers work
NOTE: fopen path was changed due to the mkdcdisc tool adding dots to files without extension https://gitlab.com/simulant/mkdcdisc/-/issues/14
Install nxdk and run make -f xbox.mk -j$(nproc) -B
. Necessary files are built into the iso.
To run with xemu use -dvd_path client.iso
as args.
Controls: right analog stick to move the mouse, dpad to rotate camera, B = left click, A = right click, Y = control, X = toggle fps, back = logout, start = login, white = center screen pan, black = pan with right analog stick
TODO: audio on highmem (for 128mb ram expansion?)
NOTE: local servers don't work on emulator? only remote servers work
NOTE: default.xbe stays around in rom dir when it's junk for other consoles that embed that directory. Can remove it after building.
NOTE: fopen had to be separated due to the need for backwards slashes, also there's no chdir equivalent?
The 2004 jar is stored for comparisons, run with EG: java -cp bin/runescape.jar client 10 0 highmem members
but:
- there is no audio, it saves audio files for the browser to play which is no longer applicable
- right clicking breaks past java 8
- window insets on modern systems are causing the sides of the game to be cut off slightly
- outside of windows it saves the cache to
/tmp
so every reboot you may have to redownload it - it only connects to localhost if it's not running as applet
- server http port needs to be set to 80 (2004scape on linux defaults to 8888 right now to avoid sudo)
- TODO confirm: to connect to local java servers on WSL from Windows you might need to add
-Djava.net.preferIPv6Addresses=true
when running client
- micro-bunzip | https://landley.net/code/bunzip-4.1.c
- isaac | https://burtleburtle.net/bob/c/readable.c
- TinySoundFont - with fix for attack1.mid by skipping RIFF header and android support
- tiny-bignum-c - prefer libtom/openssl/bigint, but works fine with smaller exponent
- LibTomMath | mpi.c is from gen.pl script in releases. with added ifdefs to fix non-gcc builds.
- ini
- stb_image and stb_truetype
Using prebuilt SDL but removed tests, SDL1 mingw dotfiles + SDL1 tcc fixes in VC (fixed upstream but no new releases since 2012)