Custom Minecraft Classic / ClassiCube client written in C from scratch (formerly ClassicalSharp in C#)
Find a file
2024-01-06 11:07:55 +11:00
.github Windows: Use custom http client instead of WinINet for http backend, hopefully this doesn't break anything 2023-12-26 12:26:17 +11:00
android BlockEdit: Also allow changing whether a block emits and/or stops light 2023-12-14 19:32:29 +11:00
doc Change console links in readme to classicube.net pages 2023-11-30 07:20:30 +11:00
ios iOS: Update the XCode project so it compiles again 2023-10-20 19:10:37 +11:00
misc Windows: Use custom http client instead of WinINet for http backend, hopefully this doesn't break anything 2023-12-26 12:26:17 +11:00
src N64: Try to avoid crash when although width * height * pixel size of a texture fits within 4096 bytes, after aligning each row to 8 bytes, row pitch * height does not fit within 4096 bytes 2024-01-06 11:07:55 +11:00
third_party Wii/GameCube: Switch to cooperative threading for map generator 2023-11-24 08:48:31 +11:00
.gitattributes rm autp crlf 2018-07-18 13:42:55 +10:00
.gitignore Bump android build gradle versions, also provide delta to Window_ProcessEvents for windowing backends that require knowing how much time has elapsed 2023-07-06 22:57:09 +10:00
credits.txt fix last commit and get border around chat (when drawn) to properly DPI scale 2020-09-28 22:05:04 +10:00
license.txt WIP on adding BearSSL SSL backend 2023-09-13 21:52:35 +10:00
Makefile PS2: 3D renders something now 2023-11-22 20:56:11 +11:00
readme.md Webclient: Fix L/R and ZL/ZR being swapped 2023-12-21 20:47:32 +11:00

ClassiCube is a custom Minecraft Classic compatible client written in C from scratch.
It is not affiliated with (or supported by) Mojang AB, Minecraft, or Microsoft in any way.

screenshot_n

Information

ClassiCube aims to replicate the 2009 Minecraft Classic client while also:

  • offering optional additions to improve gameplay
  • providing much better performance for a large range of hardware
  • running on many different systems (desktop, web, mobile, consoles)

ClassiCube is not trying to replicate modern Minecraft versions - and therefore it doesn't (and won't) support:

  • survival mode
  • logging in with Microsoft or Mojang accounts
  • connecting to Minecraft Java Edition or Bedrock Edition servers

You can download ClassiCube from here and the very latest builds from here.

We need your help

ClassiCube strives to replicate the original Minecraft Classic experience by strictly following a clean room reverse engineering approach.

If you're interested in documenting or verifying the behaviour of the original Minecraft Classic, please get in contact with me. (unknownshadow200 on Discord)

What ClassiCube is

  • A complete re-implementation of Minecraft Classic 0.30, with optional additions
  • Partially supports some features of Minecraft Classic versions before 0.30
  • Lightweight, minimal memory usage compared to original Minecraft Classic
  • Much better performance than original Minecraft Classic
  • Works with effectively all graphics cards that support OpenGL or Direct3D 9
  • Runs on Windows, macOS, Linux, Android, iOS, and in a web browser
  • Also runs on OpenBSD, FreeBSD, NetBSD, Solaris, Haiku, IRIX, SerenityOS
  • Although in various stages of early development, also runs on various consoles

Instructions

Initially, you will need to run ClassiCube.exe to download the required assets from minecraft.net and classicube.net.
Just click 'OK' to the dialog menu that appears when you start the launcher.

Singleplayer Run ClassiCube.exe, then click Singleplayer at the main menu.

Multiplayer Run ClassiCube.exe. You can connect to LAN/locally hosted servers, and classicube.net servers if you have a ClassiCube account.


Note: When running from within VirtualBox, disable Mouse Integration, otherwise the camera will not work properly

Stuck on OpenGL 1.1?

The most common reason for being stuck on OpenGL 1.1 is non-working GPU drivers - so if possible, you should try either installing or updating the drivers for your GPU.

Otherwise:

  • On Windows, you can still run the OpenGL build of ClassiCube anyways. (You can try downloading and using the MESA software renderer from here for slightly better performance though)
  • On other operating systems, you will have to compile the game yourself. Don't forget to add -DCC_BUILD_GL11 to the compilation command line so that the compiled game supports OpenGL 1.1.

Supported systems

ClassiCube runs on:

  • Windows - 95 and later
  • macOS - 10.5 or later (but can be compiled to work with 10.3/10.4 though)
  • Linux - needs libcurl and libopenal
  • Android - 2.3 or later
  • iOS - 10.3 or later
  • Most web browsers (even runs on IE11)

And also runs on:

  • Raspberry Pi - needs libcurl and libopenal
  • FreeBSD - needs libexecinfo, curl and openal-soft packages
  • NetBSD - needs libexecinfo, curl and openal-soft packages
  • OpenBSD - needs libexecinfo, curl and openal packages
  • Solaris - needs curl and openal packages
  • Haiku - needs openal package (if you have a GitHub account, can download from here)
  • BeOS - untested on actual hardware
  • IRIX - needs curl and openal packages
  • SerenityOS - needs SDL2
  • 3DS - unfinished, but usable (can download from here)
  • Wii - unfinished, but usable (can download from here)
  • GameCube - unfinished, but usable (can download from here)
  • Dreamcast - unfinished, but renders (can download from here)
  • PSP - unfinished, rendering issues (can download from here, untested on real hardware)
  • PS Vita - unfinished, rendering issues (can download from here, untested on real hardware)
  • Xbox - unfinished, major rendering issues (can download from here, untested on real hardware)
  • PS3 - unfinished, rendering issues (can download from here, untested on real hardware)
  • Nintendo 64 - unfinished, moderate rendering issues
  • PS2 - unfinished, major rendering and stability issues

Compiling

Note: The various instructions below automatically compile ClassiCube with the recommended defaults for the platform.
If you (not recommended) want to override the defaults (e.g. to compile OpenGL build on Windows), see here for details.

Compiling - Windows

Using Visual Studio

Open ClassiCube.sln (File -> Open -> Project/Solution) and compile it (Build -> Build Solution).

If you get a The Windows SDK version 5.1 was not found compilation error, see here for how to fix

Using Visual Studio (command line)
  1. Use 'Developer Tools for Visual Studio' from Start Menu
  2. Navigate to the directory with ClassiCube's source code
  3. Enter cl.exe *.c /link user32.lib gdi32.lib winmm.lib dbghelp.lib shell32.lib comdlg32.lib /out:ClassiCube.exe
Using MinGW-w64

I am assuming you used the installer from https://sourceforge.net/projects/mingw-w64/

  1. Install MinGW-W64
  2. Use either Run Terminal from Start Menu or run mingw-w64.bat in the installation folder
  3. Navigate to the directory with ClassiCube's source code
  4. Enter gcc -fno-math-errno *.c -o ClassiCube.exe -mwindows -lwinmm -limagehlp
Using MinGW

I am assuming you used the installer from https://osdn.net/projects/mingw/

  1. Install MinGW. You need mingw32-base-bin and msys-base-bin packages.
  2. Run msys.bat in the C:\MinGW\msys\1.0 folder.
  3. Navigate to the directory with ClassiCube's source code
  4. Enter gcc -fno-math-errno *.c -o ClassiCube.exe -mwindows -lwinmm -limagehlp
Using TCC (Tiny C Compiler)

I am assuming you used tcc-0.9.27-win64-bin.zip from https://bellard.org/tcc/

  1. Extract the .zip file
  2. In TCC's lib/kernel32.def, add missing RtlCaptureContext at line 554 (In between RtlAddFunctionTable and RtlDeleteFunctionTable)
  3. Copy winapi folder and _mingw_dxhelper.h from winapi-full-for-0.9.27.zip into TCC's include folder
  4. Navigate to the directory with ClassiCube's source code
  5. In ExtMath.c, change fabsf to fabs and sqrtf to sqrtf
  6. Enter tcc.exe -o ClassiCube.exe *.c -lwinmm -limagehlp -lgdi32 -luser32 -lcomdlg32 -lshell32

Compiling - Linux

Using gcc/clang

Install appropriate libs as required. For ubuntu these are: libx11-dev, libxi-dev and libgl1-mesa-dev

gcc -fno-math-errno *.c -o ClassiCube -rdynamic -lpthread -lX11 -lXi -lGL -ldl

Cross compiling for Windows (32 bit):

i686-w64-mingw32-gcc -fno-math-errno *.c -o ClassiCube.exe -mwindows -lwinmm -limagehlp

Cross compiling for Windows (64 bit):

x86_64-w64-mingw32-gcc -fno-math-errno *.c -o ClassiCube.exe -mwindows -lwinmm -limagehlp

Raspberry Pi

Although the regular linux compiliation flags will work fine, to take full advantage of the hardware:

gcc -fno-math-errno *.c -o ClassiCube -DCC_BUILD_RPI -rdynamic -lpthread -lX11 -lXi -lEGL -lGLESv2 -ldl

Compiling - macOS

Using gcc/clang (32 bit)

cc -fno-math-errno *.c -o ClassiCube -framework Carbon -framework AGL -framework OpenGL -framework IOKit

Using gcc/clang (64 bit)

cc -fno-math-errno *.c interop_cocoa.m -o ClassiCube -framework Cocoa -framework OpenGL -framework IOKit -lobjc

Compiling - for Android

NOTE: If you are distributing a modified version, please change the package ID from com.classicube.android.client to something else - otherwise Android users won't be able to have both ClassiCube and your modified version installed at the same time on their Android device

Using Android Studio GUI

Open android folder in Android Studio (TODO explain more detailed)

Using command line (gradle)

Run gradlew in android folder (TODO explain more detailed)

Compiling - for iOS

iOS version will have issues as it's incomplete and only tested in iOS Simulator

NOTE: If you are distributing a modified version, please change the bundle ID from com.classicube.ios.client to something else - otherwise iOS users won't be able to have both ClassiCube and your modified version installed at the same time on their iOS device

Using Xcode GUI

Import ios/CCIOS.xcodeproj project into Xcode (TODO explain more detailed)

Using command line (Xcode)

xcodebuild -sdk iphoneos -configuration Debug (TODO explain more detailed)

Compiling - other desktop OSes

FreeBSD

Install libxi, libexecinfo, curl and openal-soft package if needed

cc *.c -o ClassiCube -I /usr/local/include -L /usr/local/lib -lm -lpthread -lX11 -lXi -lGL -lexecinfo

OpenBSD

Install libexecinfo, curl and openal package if needed

cc *.c -o ClassiCube -I /usr/X11R6/include -I /usr/local/include -L /usr/X11R6/lib -L /usr/local/lib -lm -lpthread -lX11 -lXi -lGL -lexecinfo

NetBSD

Install libexecinfo, curl and openal-soft package if needed

cc *.c -o ClassiCube -I /usr/X11R7/include -I /usr/pkg/include -L /usr/X11R7/lib -L /usr/pkg/lib -lpthread -lX11 -lXi -lGL -lexecinfo

DragonflyBSD

cc *.c -o ClassiCube -I /usr/local/include -L /usr/local/lib -lm -lpthread -lX11 -lXi -lGL -lexecinfo

Solaris

gcc -fno-math-errno *.c -o ClassiCube -lsocket -lX11 -lXi -lGL

Haiku

Install openal_devel package if needed

cc -fno-math-errno *.c interop_BeOS.cpp -o ClassiCube -lGL -lnetwork -lstdc++ -lbe -lgame -ltracker

BeOS

cc -fno-math-errno *.c interop_BeOS.cpp -o ClassiCube -lGL -lbe -lgame -ltracker

IRIX

gcc -fno-math-errno -lGL -lX11 -lXi -lpthread -ldl

SerenityOS

Install SDL2 port if needed

cc *.c -o ClassiCube -lgl -lSDL2

Compiling - other

Web

emcc *.c -s ALLOW_MEMORY_GROWTH=1 --js-library interop_web.js

The generated javascript file has some issues. See here for how to fix

3DS

Run make 3ds. You'll need libctru

NOTE: It is highly recommended that you install the precompiled devkitpro packages from here - you need the 3ds-dev group)

The 3DS port needs assistance from someone experienced with 3DS homebrew development - if you're interested, please get in contact with me. (unknownshadow200 on Discord)

Wii

Run make wii. You'll need libogc

NOTE: It is highly recommended that you install the precompiled devkitpro packages from here - you need the wii-dev group)

The Wii port needs assistance from someone experienced with Wii homebrew development - if you're interested, please get in contact with me. (unknownshadow200 on Discord)

GameCube

Run make gamecube. You'll need libogc

NOTE: It is highly recommended that you install the precompiled devkitpro packages from here - you need the gamecube-dev group)

The GC port needs assistance from someone experienced with GameCube homebrew development - if you're interested, please get in contact with me. (unknownshadow200 on Discord)

PlayStation Portable

Run make psp. You'll need pspsdk

NOTE: It is recommended that you install the precompiled pspsdk version from here

The PSP port needs assistance from someone experienced with PSP homebrew development - if you're interested, please get in contact with me. (unknownshadow200 on Discord)

PlayStation Vita

Run make vita. You'll need vitasdk

The Vita port needs assistance from someone experienced with Vita homebrew development - if you're interested, please get in contact with me. (unknownshadow200 on Discord)

PlayStation 3

Run make ps3. You'll need PSL1GHT

The PS3 port needs assistance from someone experienced with PS3 homebrew development - if you're interested, please get in contact with me. (unknownshadow200 on Discord)

Xbox

Run make xbox. You'll need nxdk

The Xbox port needs assistance from someone experienced with Xbox homebrew development - if you're interested, please get in contact with me. (unknownshadow200 on Discord)

Dreamcast

Run make dreamcast. You'll need KallistiOS

The Dreamcast port needs assistance from someone experienced with Dreamcast homebrew development - if you're interested, please get in contact with me. (unknownshadow200 on Discord)

Nintendo 64

Run make n64. You'll need the opengl branch of libdragon

The Nintendo 64 port needs assistance from someone experienced with Nintendo 64 homebrew development - if you're interested, please get in contact with me. (unknownshadow200 on Discord)

You'll also need to stub out WorkerLoop function in Http_Worker.c for now

Other

You'll have to write the necessary code. You should read portability.md in doc folder.

Documentation

Functions and variables in .h files are mostly documented.

Further information (e.g. style) for ClassiCube's source code can be found in the doc and misc folders.

Known compilation errors

Fixes for compilation errors when using musl or old glibc for C standard library

Tips

  • Press escape (after joining a world) or pause to switch to the pause menu.

  • Pause menu -> Options -> Controls lists all of the key combinations used by the client.

  • Note that toggling 'vsync' to on will minimise CPU usage, while off will maximimise chunk loading speed.

  • Press F to cycle view distance. A smaller number of visible chunks can improve performance.

  • If the server has disabled hacks, key combinations such as fly and speed will not do anything.

  • To see the list of built in commands, type /client.

  • To see help for a given built in command, type /client help <command name>.

Open source technologies

  • curl - HTTP/HTTPS for linux and macOS
  • FreeType - Font handling for all platforms
  • GCC - Compiles client for linux
  • MinGW-w64 - Compiles client for windows
  • Clang - Compiles client for macOS
  • Emscripten - Compiles client for web
  • RenderDoc - Graphics debugging
  • BearSSL - SSL/TLS support on consoles
  • libctru - Backend for 3DS
  • citro3D - Rendering backend for 3DS
  • Citra - Emulator used to test 3DS port
  • pspsdk - Backend for PSP
  • PPSSPP - Emulator used to test PSP port
  • vitasdk - Backend for PS Vita
  • Vita3K - Emulator used to test Vita port
  • PSL1GHT - Backend for PS3
  • RPCS3 - Emulator used to test PS3 port
  • libogc - Backend for Wii and GameCube
  • libfat - Filesystem backend for Wii/GC
  • Dolphin - Emulator used to test Wii/GC port
  • KallistiOS - Backend for Dreamcast
  • GLdc - Basis of rendering backend for Dreamcast
  • nullDC - Emulator used to test Dreamcast port
  • flycast - Emulator used to test Dreamcast port
  • nxdk - Backend for Xbox
  • xemu - Emulator used to test Xbox port
  • cxbx-reloaded - Emulator used to test Xbox port
  • libdragon - Backend for Nintendo 64
  • cen64 - Emulator used to test Nintendo 64 port
  • ares - Emulator used to test Nintendo 64 port
  • ps2sdk - Backend for PS2
  • PCSX2 - Emulator used to test PS2 port

Sound Credits

ClassiCube uses sounds from Freesound.org
Full credits are listed in doc/sound-credits.md