2022-11-08 21:08:58 +00:00
# YimMenu
2022-10-27 23:46:16 +03:00
![](https://img.shields.io/badge/dynamic/json?color=ffab00& label=Online%20Version& query=%24.game.online& url=https%3A%2F%2Fraw.githubusercontent.com%2FYimMenu%2FYimMenu%2Fmaster%2Fmetadata.json& style=flat-square& labelColor=000000) ![](https://img.shields.io/badge/dynamic/json?color=ffab00& label=Game%20Build& query=%24.game.build& url=https%3A%2F%2Fraw.githubusercontent.com%2FYimMenu%2FYimMenu%2Fmaster%2Fmetadata.json& style=flat-square& labelColor=000000)
2019-06-23 22:00:18 +02:00
A mod menu base for Grand Theft Auto V.
Strictly for educational purposes.
2022-11-08 21:08:58 +00:00
YimMenu is originally based of off [BigBaseV2 ](https://github.com/Pocakking/BigBaseV2 ) which was an amazing base at the time but nowadays is a bit dated.
2022-11-18 17:43:55 +01:00
So here I am with an up-to-date menu focusing on protecting the user from toxic modders.
2022-11-08 21:08:58 +00:00
2022-01-04 12:47:04 +01:00
## Table of contents
2019-06-23 22:00:18 +02:00
2022-01-04 12:47:04 +01:00
* [How to build ](#how-to-build )
2023-01-05 21:43:00 +02:00
* [Curl ](#curl )
2022-01-04 12:47:04 +01:00
* [Git ](#git )
2022-11-18 18:29:29 +01:00
* [CMake ](#CMake )
2022-01-04 12:47:04 +01:00
* [Cloning and generating project files ](#cloning-and-generating-project-files )
2022-02-01 18:45:44 +01:00
* [Staying Up To Date ](#staying-up-to-date )
2022-01-04 12:47:04 +01:00
* [Project Structure ](#project-structure )
* [Features ](#features )
* [Contributing ](#contributing )
2023-01-02 09:38:10 -05:00
2022-01-04 12:47:04 +01:00
## How to build
Requirements:
2023-01-05 21:43:00 +02:00
* [Git ](#git )
* [CMake ](#cmake )
2022-01-04 12:47:04 +01:00
If you have both of the above requirements you can skip to [cloning the git repo and generating the project files ](#cloning-and-generating-project-files ).
2023-01-02 09:38:10 -05:00
### Curl
Curl should be already installed on your computer, but if you are having issues with building the project, you will need to download and install
2023-01-05 21:43:00 +02:00
it.
2023-01-02 09:38:10 -05:00
[Download Link ](https://curl.se/download.html )
2022-01-04 12:47:04 +01:00
### Git
2023-01-05 21:43:00 +02:00
If you haven't installed git on your system go and do so as it is **REQUIRED** for setting up a working build environment.
2022-01-04 12:47:04 +01:00
[Download Link ](https://git-scm.com/download/win )
2022-11-08 21:08:58 +00:00
### CMake
2022-01-04 12:47:04 +01:00
2023-01-02 09:38:10 -05:00
CMake is used to generate our project files, if you haven't used it before you will need to download and install it.
2022-01-04 12:47:04 +01:00
2022-11-08 21:08:58 +00:00
[Download Link ](https://cmake.org/download/ )
2022-01-04 12:47:04 +01:00
### Cloning and generating project files
2022-11-18 17:23:58 +01:00
- Make sure that you have installed Git and CMake.
2022-02-01 18:45:44 +01:00
2022-11-18 17:23:58 +01:00
- Clone the repository:
```bash
git clone https://github.com/YimMenu/YimMenu.git
```
2022-02-01 18:45:44 +01:00
2022-11-18 17:23:58 +01:00
- Go into the directory you just cloned:
```bash
cd YimMenu
```
2022-11-08 21:08:58 +00:00
2023-01-02 09:38:10 -05:00
#### Generate project files
2022-11-18 17:23:58 +01:00
2023-01-05 21:43:00 +02:00
> **Note**
> You will have cd build and cmake again if you add any files or you will get an error when building.
2023-01-02 09:38:10 -05:00
- Windows Only
2022-11-18 17:23:58 +01:00
- Visual Studio
If you only use Visual Studio and don't want to mess with command lines, Visual Studio has a CMake extension that does all the work.
Make sure it is [installed ](https://learn.microsoft.com/en-us/cpp/build/cmake-projects-in-visual-studio?view=msvc-170#installation ).
Then, just open Visual Studio, open a local folder, and select the `YimMenu` folder that the `git clone` command just created.
Let the CMake extension generate the needed files for building, you can follow the progress in the Output tab of Visual Studio.
Then, you can just build by using the Build menu at the top and clicking Build All.
2023-01-02 09:38:10 -05:00
2022-11-18 17:23:58 +01:00
- Other OSs / IDEs
2023-01-02 09:38:10 -05:00
If you use something else or prefer using the console on Windows, just follow this:
2022-11-18 17:23:58 +01:00
```bash
mkdir build
cd build
cmake ..
```
Now, you will be able to open the solution, and build it.
2023-01-02 09:38:10 -05:00
2022-02-01 18:45:44 +01:00
## Staying Up To Date
2022-11-18 17:23:58 +01:00
Pull the latest changes from this repository.
With a command line it is as easy as:
2022-02-01 18:45:44 +01:00
```bash
2022-11-18 17:23:58 +01:00
git pull
2022-02-01 18:45:44 +01:00
```
2022-11-18 17:23:58 +01:00
CMake should be handling removed / added files automatically without any user input.
2023-01-05 21:43:00 +02:00
If this is not the case for some reason you'll have to redo the steps in the [Generate project files ](#generate-project-files ) section above.
2022-11-18 17:23:58 +01:00
If you are doing custom modifications to the codebase and have a fork you are on your own for staying up to date with upstream (this repository), google stuff like "merge from upstream" and learn how to use Git.
2022-01-04 12:47:04 +01:00
## Project Structure
2021-05-19 00:55:13 +02:00
2021-11-09 01:43:19 +01:00
- `backend/` all features that should be ran in a loop are in here sorted by category
- `gui/` includes everything related to UI elements
- `hooks/` function hooks
2022-10-30 10:21:12 -04:00
- `native_hooks/` hooks to natives
2021-11-09 01:43:19 +01:00
- `services/` service files to interact and maintain stuff
- `util/` general utility functions to keep code as compact and as much in one place as possible
2021-05-19 00:55:13 +02:00
2021-11-09 01:43:19 +01:00
## Features
2022-01-04 12:47:04 +01:00
Below is an incomplete list of feature that I believe are notable to this "base" or menu.
2021-11-09 01:43:19 +01:00
- Return Native spoofing
2023-01-05 21:43:00 +02:00
- Custom [settings ](src/core/globals.hpp ) with deep compare if changes were made, including auto saving
2021-11-09 01:43:19 +01:00
- Clear and well structured source code
- Includes a thread pool to queue tasks that shouldn't block the game thread, very similar to fiber pool
2022-10-30 10:21:12 -04:00
- Updated natives.hpp from https://nativedb.spyral.dev
2021-11-09 01:43:19 +01:00
- ReClass.NET structures implemented, accessible from a global called g_local_player defined in `common.hpp`
2019-06-23 22:00:18 +02:00
2022-01-04 12:47:04 +01:00
## Contributing
2023-01-05 21:43:00 +02:00
You're free to contribute to YimMenu as long as the features are useful, not overly toxic and do not contain anything money related that might get the menu targeted by Take2.
2022-01-04 12:47:04 +01:00
2022-01-11 17:50:58 +01:00
Make sure to read the [CONTRIBUTING.md ](CONTRIBUTING.md ) file.