# OpenMiner [![Build Status](https://travis-ci.com/Unarelith/OpenMiner.svg?branch=master)](https://travis-ci.com/Unarelith/OpenMiner) [![Documentation](https://codedocs.xyz/Quent42340/OpenMiner.svg)](https://codedocs.xyz/Quent42340/OpenMiner/) [![License](https://img.shields.io/badge/license-LGPLv2.1%2B-blue.svg)](https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html) [![Discord](https://img.shields.io/discord/527527086756200458.svg?style=popout)](https://discord.gg/eN8k8wt) [![Donate](https://img.shields.io/badge/donate-paypal-brightgreen.svg)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=66DH462V7TA6N&source=url) - [Project goal](#project-goal) - [Keys](#keys) - [Wiki](#wiki) - [How to compile](#how-to-compile) - [Discussion](#discussion) - [Project status](#project-status) - [Screenshots](#screenshots) - [Previous attempts](#previous-attempts) - [Credits](#credits) ## Project goal The long-term goal of this project is to provide a viable alternative to Minecraft modding. ## Keys - Movement: WASD - Inventory: E - Jump: Space - Sprint: Ctrl - Jetpack: X - Exit: Escape - Debug: F3 ## Wiki - [Lua API Overview](https://github.com/Unarelith/OpenMiner/wiki/Lua-API-Overview) ## How to compile ### Using Linux - Dependencies: - A compiler with C++14 support - [CMake](http://www.cmake.org/download/) - [GameKit](http://github.com/Unarelith/GameKit) (requires `SDL2` + `tinyxml2`, will switch to `SFML` starting from 2.6) - [SFML](https://www.sfml-dev.org/) (only used for network) - [Lua](http://www.lua.org) - _Linux users: Check your distribution repositories for packages._ - Run `cmake . && make -j8` - Run the server with `./server/openminer_server` - Run the client with `./client/openminer` ### Using Windows - [Wiki: Compiling on Windows using CMake and MinGW-w64](https://github.com/Unarelith/OpenMiner/wiki/Compiling-on-Windows-with-MinGW-w64) - [Wiki: Compiling on Windows using CMake and Visual Studio 2017](https://github.com/Unarelith/OpenMiner/wiki/Compiling-on-Windows-with-Visual-Studio-2017) ## Discussion - Discord: [join server](https://discord.gg/eN8k8wt) ## Project status This list is non exhaustive. ### Implemented features - Menus (title screen, server selection, pause menu, settings menu) - Basic worldgen (lakes, trees, flowers, pseudo-caves) - Infinite world in X/Y/Z axis - Lighting system with smooth lighting - Networking - Lua API - Block/item/recipe definition - Custom GUI creation - Special blocks (workbench, furnace) ### Missing features - Texture pack system - World loading/saving - Advanced block metadata - Particle system - Fluid propagation - Player model display (currently displaying an ugly box) - Day/night cycle with sun/moon display - Real worldgen (seed-based, biomes, cave tunnels) - Entities (block drops, mobs, etc...) - Clouds ## Screenshots ![](screenshot1.png?raw=true) ![](screenshot2.png?raw=true) ![](screenshot3.png?raw=true) ![](screenshot4.png?raw=true) ## Previous attempts - Here is the [commit](https://github.com/Unarelith/OpenMiner/tree/8eba845421efff6ce941f8550ff79e6364970fd5) matching the end of the first attempt made in 2013. - And here is the [commit](https://github.com/Unarelith/OpenMiner/tree/58c23a7e66404dab94e51998a179dc370c89ea06) matching the end of the second attempt made in 2014. You can find an history of the project [here](https://github.com/Unarelith/OpenMiner/wiki/History-of-OpenMiner). ## Credits - MadPixel (Minecrafter font) [CC BY-ND] - xMrVizzy ([Faithful 32x](https://www.curseforge.com/minecraft/texture-packs/faithful-32x) texture pack, will completely replace Vanilla textures)