An Extension of Almond-Core featuring plugin support with 2D graphical support for C++20 Cross-platform UX/UI. Like Almond Core it's also Part of the Almond Engine and is a Cross-platform OS Entry-Point System with Data-Oriented, Functional/OOP Hybrid, Task and Event Driven Component based Architecture with built-in Stateless Scene Management, ECS, WITH THE ADDITION OF plugin and 2D Graphical Support + Custom Minimal UX/UI Implimentation.
What Seperates Almond Core From Almond Shell is plugin and 2D Graphical Support + Custom Minimal UX/UI Implimentation.
Built with contemporary design principles and using C++20, it is designed for modularity, efficiency, and ease of use on current OS hardware for bleeding-edge software development and beyond. For 3D Graphics Rendering Capabilities or Game Engine see AlmondEngine. AlmondShell is a Modern Software Development Suite which aims to be as minimal as possible and also features a header only mostly functional programming design to reduce overhead.
- Cross-platform support for Windows, macOS, Linux, Android, iOS, WebAssembly, PS5, Xbox, and a No-op/Console mode.
- Game Creation and Management.
- Platform-specific implementation details hidden behind a common interface.
- Namespace 'almondengine' Prevents Global Code Leaks
- Modern C++20 and Efficient Pattern Design
- Platform-Specific Factories
- Custom Efficient Memory Management and Logging, and Error Handling
- Split-Screen and VR Features In AlmondEngine, Ensure that these features are appropriately implemented in the platform-specific classes where applicable.
- Tested in Windows 10/11, and Linux Kubuntu (Ubuntu Debian/KDE)
## Supported Platforms
- **Console** (Headless mode)
- **Windows** (Win32)
- **Linux** (XCB or XLib) (XCB planned, XLib Working!)
- **macOS** (Cocoa) (planned)
- **Android** (Android) (planned)
- **iOS** (UIKit) (planned)
- **WebAssembly** (Emscripten) (planned)
- **PlayStation 5** (PS5) (planned)
- **Xbox** (Xbox) (planned)
- vcpkg (Windows and Linux)
- MSVC with C++20 or later, or VSCode, VSCodium on XLib
- CMake 3.10 or later
- Clone the repository:
git clone https://github.com/Autodidac/AlmondShell.git
cd AlmondShell
Simply run the provided vs solution file AlmondShell.sln
in the main folder
Simply open the top project folder containing AlmondShell.sln
in VSCode or VSCodium on Linux
Run cmake to generate the build files, then compile:
Basic Build:
mkdir build
cd build
cmake ..
cmake --build .
@echo off
Example_ConsoleApplication.exe
pause
./Example_CMake_Project1
#include "AlmondShell.h"
int main() {
auto AlmondShell = almond::renderer::createAlmondShell();
if (AlmondShell->init()) {
AlmondShell->createWindow(L"Example Game", 800, 600);
// Main loop or additional logic here
AlmondShell->shutdown();
}
return 0;
}
almond::AlmondShell
static std::unique_ptr<AlmondShell> createAlmondShell()
bool init()
bool createWindow(const wchar_t* title, int width, int height)
void shutdown()
The platform-specific implementation files are organized into separate source files. Each implementation file contains the initialization, window creation, and shutdown code for a specific platform.
-Windows: AlmondShellWin32.cpp
and AlmondEngineWin32.h
-macOS: AlmondEngineMac.cpp
and AlmondEngineMac.h
-Linux: AlmondEngineLinux.cpp
and AlmondEngineLinux.h
-Android: AlmondEngineAndroid.cpp
and AlmondEngineAndroid.h
-iOS: AlmondEngineIOS.cpp
and AlmondEngineIOS.h
-WebAssembly: AlmondEngineWebAssembly.cpp
and AlmondEngineWebAssembly.h
-PlayStation 5: AlmondEnginePS5.cpp
and AlmondEnginePS5.h
-Xbox: AlmondEngineXbox.cpp
and AlmondEngineXbox.h
-No-op mode: AlmondEngineConsole.cpp
and AlmondEngineConsole.h
Almond Shell is licensed under the MIT License. See the LICENSE file for details.
Contributions are welcome! Please see the CONTRIBUTING.md file for guidelines.
This project was developed with the support of OpenAI's GPT-4, which provided valuable assistance in generating code and design ideas.
I appreciate the power and capabilities of GPT-4 in aiding the creation of this project and others.
Almond Shell - A GPT-4 Cross-platform Library For All! Almost Entirely Built and Designed by AI - Even much of this readme and the CMakeLists.txt are written by GPT-4.. what a wonderful tool Thank You Again!