All Projects → ChariotEngine → Chariot

ChariotEngine / Chariot

Licence: other
A cross-platform open-source reimplementation of the Age of Empires (1997) engine

Programming Languages

rust
11053 projects

Labels

Projects that are alternatives of or similar to Chariot

Nancy
Lightweight, low-ceremony, framework for building HTTP based services on .Net and Mono
Stars: ✭ 7,170 (+2424.65%)
Mutual labels:  mit
zork
Full C++-17 port of the 616-point version of Zork from MIT circa 1978-1981
Stars: ✭ 16 (-94.37%)
Mutual labels:  mit
summaly
🔍 Get a summary of any web page
Stars: ✭ 18 (-93.66%)
Mutual labels:  mit
MIT6.824-2021
4 labs + 2 challenges + 4 docs
Stars: ✭ 594 (+109.15%)
Mutual labels:  mit
loopback-component-migrate
Migration framework for loopback
Stars: ✭ 43 (-84.86%)
Mutual labels:  mit
lectures and talks
Collection of lectures and talks I've given on Computer Vision and Deep Learning
Stars: ✭ 29 (-89.79%)
Mutual labels:  mit
My.Jdownloader-API-Python-Library
My.Jdownloader API Python Library
Stars: ✭ 65 (-77.11%)
Mutual labels:  mit
React Native Wechat
🚀 WeChat login, share, favorite and payment for React-Native on iOS and Android platforms (QQ: 336021910)
Stars: ✭ 2,842 (+900.7%)
Mutual labels:  mit
LAB
MIT IT Lab Repository
Stars: ✭ 23 (-91.9%)
Mutual labels:  mit
svelte-credit-card
A svelte component to render a credit card 💳
Stars: ✭ 30 (-89.44%)
Mutual labels:  mit
magento-ngrok
Magento 2 module for ngrok.io service support
Stars: ✭ 45 (-84.15%)
Mutual labels:  mit
documentation
Pterodactyl's documentation is open source! This repository contains the documentation for installing and updating both the panel and the daemon.
Stars: ✭ 99 (-65.14%)
Mutual labels:  mit
uuix
A tiny (<1KB) and fast UUID (v4) generator for Crystal
Stars: ✭ 17 (-94.01%)
Mutual labels:  mit
dashy
🚀 A self-hostable personal dashboard built for you. Includes status-checking, widgets, themes, icon packs, a UI editor and tons more!
Stars: ✭ 7,103 (+2401.06%)
Mutual labels:  mit
flutter vertical marquee
flutter vertical marquee
Stars: ✭ 15 (-94.72%)
Mutual labels:  mit
MusicTransformer-Pytorch
MusicTransformer written for MaestroV2 using the Pytorch framework for music generation
Stars: ✭ 106 (-62.68%)
Mutual labels:  mit
mit-phd-thesis
MIT Ph.D. Thesis in LaTeX
Stars: ✭ 52 (-81.69%)
Mutual labels:  mit
Mit6.828 os
MIT 6.828 Lab https://pdos.csail.mit.edu/6.828/2018/schedule.html
Stars: ✭ 265 (-6.69%)
Mutual labels:  mit
Node Rsync
Rsync wrapper for Node.js
Stars: ✭ 256 (-9.86%)
Mutual labels:  mit
edX-6.00.2x-Introduction-to-Computational-Thinking-and-Data-Science
MIT edX 6.00.2x Introduction to Computational Thinking and Data Science problem sets code
Stars: ✭ 62 (-78.17%)
Mutual labels:  mit

Chariot Build Status

The Chariot project is an attempt to re-implement the original Age of Empires (1997) engine in an open-source manner so that:

  • The game may be ported to any desired platform.
  • Useful features from the sequel, such as build queuing, can be added to bring the original game closer to modern day RTS standards.
  • Enhancements, such as larger screen resolution support, can be made.

The project will strive to be as close to the original as possible.

For legal reasons, you'll need an original Age of Empires CD to be able to play it. No game data files will be committed to the repository.

Note: This is a work in progress. As of 2016-07-08, there is no game to be played. Just a demonstration of the original game assets being loaded and other proof of concepts. It will be a while before it is playable.

WIP Screenshot

Work in Progress Screenshot

Building and Running

Overview

OS-specific instructions will follow. This section just gives a high level idea of what is required to build Chariot. You'll need the following:

  1. A Rust Compiler
  2. GCC (via MINGW if on Windows), or Microsoft Visual C++
  3. LibSDL2

Rust's Cargo program should download and compile all of the other necessary dependencies.

Building on Linux

  1. Install Rust. Documentation for manual install here.
  2. Install SDL2. If you're on Ubuntu, you can use this command: sudo apt-get install libsdl2-dev.
  3. Install GCC. For Ubuntu / Debian use the 'build-essential' package. For Arch linux use 'base-devel'
  4. Build the game with: cargo build --release

Building on Windows

MSVC

  1. Install the Visual C++ 2015 Build Tools (make sure to choose the default installation, as custom installation has been known to cause problems).
  2. Install Rust via rustup.
  3. Follow the Windows (MSVC) instructions for Rust SDL2 bindings.
  4. Build the game with: cargo build --release.

MinGW/MSYS2

  1. Install Rust via rustup.
  2. Install MinGW/MSYS2
  3. Install SDL2: pacman -S mingw-w64-x86_64-SDL2
  4. Export the library folder: echo "export LIBRARY_PATH=/usr/local/lib/:/lib/" >> /etc/profile"
  5. Use the GNU ABI (i686-pc-windows-gnu or x86_64-windows-pc-gnu)
  6. Build the game with: cargo build --release

Building on macOS

  1. Install Homebrew
  2. Install Rust. curl https://sh.rustup.rs -sSf | sh && rustup install toolchain stable-x86_64-apple-darwin
  3. Install SDL2. brew install sdl2
  4. Build the game with: make build (which invokes cargo build --release)

Running

On the game CD you will find a GAME directory with a LANGUAGE.DLL, EMPIRES.EXE, and a bunch of directories such as AVI, CAMPAIGN, and DATA.

Substitute /media/AOE/GAME in the following commands with the absolute path to the GAME directory mentioned above.

The following commands must be executed from the root of this project (the same directory that contains Makefile).

$ make run GAME_DIR=/media/AOE/GAME SCENARIO=MUF7E5_1

# Or you can run cargo directly:
$ cargo run --release -- /media/AOE/GAME/SCENARIO/MUF7E5_1.SCN --game-data-dir /media/AOE/GAME

Note that in these early versions, you may need to specify additional command line arguments, such as a path to a scenario file to load up. These may change over time, but the game should tell you what arguments are required and what to provide.

Contributing

Chariot is MIT licensed.

Any contribution submitted for inclusion in the work by you shall also be licensed as MIT, without any additional terms or conditions.

IRC

We have an IRC channel setup at #openaoe (I'd like to move this but there are some idle lurkers) on Freenode. Most collaborative discussions take place there, so it's a good place to ask where you can help out, or how something should be approached.

Before submitting a pull request

  1. Make sure you've run the tests: ./all-crates-do test
  2. Format any source files you modified with Rustfmt.
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].