“The only game engine that tastes better slightly burned!”
marshmallow_h is an open-source game engine focused on 8-bit and 16-bit era 2D video games. This engine will act as the backbone and toolkit for the Marshmallow Entertainment System.
git clone --recursive git://github.com/gamaral/marshmallow_h.git
Notice the --recursive switch, it's needed so that submodules get checked out along with the main repository.
You may occasionally notice changes to the .gitsubmodules file, this usually means that it's time to update submodules, you can do so by running the following command:
git submodule update
I include many predefined cmake init-caches, please take a look at the "cmake" directory in the project base, filenames are pretty self-explanatory.
Run the following from project base:
cd build
cmake -C ../cmake/Cache-opengl-glx.cmake ..
make
Marshmallow's go-to compiler is Clang, the example above uses gcc since it's almost guaranteed to be on the system (unlike Clang).
CGL is currently unsupported (due to my laziness, so SDL and QT4 can be used for now).
Note: Marshmallow is still under heavy development and this platform could break at any time, if you wish to help keeping it up to date feel free to contact me.
Run the following from project base using Terminal:
cd build
cmake -G Xcode -C ../cmake/Cache-opengl-qt4.cmake ..
Now launch Xcode and open the project file in the build directory.
Run the following from project base using Terminal:
cd build
cmake -C ../cmake/Cache-opengl-qt4.cmake ..
make
Run the following from project base using the Command Line terminal:
cd build
cmake -C ..\cmake\Cache-opengl-wgl.cmake ..
Now open Visual Studio and open the MARSHMALLOW solution located in the build directory.
Tested on Win7 x86/x64 (VS2010)
Note: Marshmallow is still under heavy development and this platform could break at any time, if you wish to help keeping it up to date feel free to contact me.
If you wish to test out marshmallow_h on the Raspberry Pi, you have a few ways of building.
Run the following commands in your marshmallow_h base:
cd build
cmake -C ../cmake/Cache-raspberrypi.cmake ..
make
To start, you will need to clone my RPi toolchain:
git clone --depth 1 git://github.com/gamaral/rpi-toolchain.git
At this point you have the base of the toolchain but no actual submodules, you will now need to quick-clone the submodules:
cd rpi-toolchain
scripts/quick-clone
The rpi-toolchain requires some special environment variables to be exported in order to work with marshmallow_h, this is handled by the nifty env file in the toolchain base:
source rpi-toolchain/env
Keep in mind you might need to source that same environment file again if you plan to reconfigure at a later time.
We are now ready to configure marshmallow_h, change into the marshmallow's base directory and run the following commands:
cd build
cmake -DCMAKE_TOOLCHAIN_FILE=../cmake/Toolchain-raspberrypi.cmake -C ../cmake/Cache-raspberrypi.cmake ..
At this point you can configure manually using the following command (optional):
make edit_cache
Finally, we build and do the usual crossing of fingers:
make
My custom Raspberry Pi buildroot distro can be found here:
https://github.com/gamaral/rpi-buildroot
After you have configured and compiled buildroot to your liking, you will need to copy over the environment file supplied (or export the required environment variables by hand).
cp resources/buildroot-env <buildroot-base>/env
source <buildroot-base>/env
Alternatively, you could use the pre-compiled sdcard image and toolchain I made available for test driving the distro. It comes complete with the env file and can be downloaded here:
https://github.com/gamaral/rpi-buildroot/downloads
Keep in mind you might need to source that same environment file again if you plan to reconfigure at a later time.
We are now ready to configure marshmallow_h, change into the marshmallow's base directory and run the following commands:
cd build
cmake -DCMAKE_TOOLCHAIN_FILE=../cmake/Toolchain-buildroot.cmake -C ../cmake/Cache-raspberrypi.cmake ..
At this point you can configure manually using the following command (optional):
make edit_cache
Finally, we build and do the usual crossing of fingers:
make
Components:
demos: Demos and assets
deployment: Files required for game deployment
development: Headers and static libraries
runtime: Shared libraries
To create a demo package, you will need to run the following commands:
cd build
cmake -DCMAKE_INSTALL_PREFIX=marshmallow_demos -DCOMPONENT=runtime -P cmake_install.cmake
cmake -DCMAKE_INSTALL_PREFIX=marshmallow_demos -DCOMPONENT=deployment -P cmake_install.cmake
cmake -DCMAKE_INSTALL_PREFIX=marshmallow_demos -DCOMPONENT=demos -P cmake_install.cmake
To test out the package, you can run the following command:
marshmallow_demos/run platformer_demo0
vim:syn=markdown: