From bf134560673a4f6aef919e5d2a9c449bcd96f4ff Mon Sep 17 00:00:00 2001 From: Dominic Masters Date: Tue, 25 Jul 2023 18:58:35 -0700 Subject: [PATCH] Adding compiling docs. --- docs/compiling.md | 237 ++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 237 insertions(+) create mode 100644 docs/compiling.md diff --git a/docs/compiling.md b/docs/compiling.md new file mode 100644 index 00000000..8741e897 --- /dev/null +++ b/docs/compiling.md @@ -0,0 +1,237 @@ +# Compiling, Debugging and Running +This document's purpose is to explain how to compile, debug and run the project +on your machine. It is assumed that you have a basic understanding of the +fundamentals of your operating system and how to use a terminal. + +## Preamble +The Dawn project is written almost entirely in C and C++. This includes all of +the tooling used to generate the project and assets. The only non-C/C++ code is +used by CMake to generate the output compilation files. This provides the Dawn +project an extremely high level of portability not typically seen in other +projects. + +## TLDR; Version +This document is going to go over the installation and configuration of the +following items. If you are already familiar with these tools, you can skip to +the "Downloading the Source Code" section. +- C/C++ Compiler +- CMake +- Git +- IDE +You may also need *python*, since we depend on third-party libraries that may use +python scripts to generate their own build files. This is not required for the +Dawn project itself. + +## Pre-Configuration +In order to compile the Dawn project, you are required to have the following +tools installed on your machine. + +### 1. A C/C++ Compiler +The exact tool(s) will depend on your specific scenario. The compiler is used to +take the .cpp/.hpp files and generating binaries that execute on the target +machine. Typically you will use your own C/C++ compiler for the machine that you +are currently running, e.g. if you are running Windows, you will use the Visual +Studio compiler. If you are running Linux, you will use GCC or Clang. If you are +running macOS, you will use Clang, and so-on. + +If you are intending to compile on a different machine than the one you are +currently running, you will need to use a cross-compiler that is specific for +your use-case. You will also need to refer to the documentation for creating a +new Dawn engine target. + +Please follow the instructions for your specific operating system to install the +appropriate C/C++ compiler. + +**Windows** +You will need to download and install [Visual Studio](https://visualstudio.microsoft.com/downloads/). +Visual Studio (not to be confused with Visual Studio Code) is a full IDE that +bundles the official Microsoft C/C++ compiler. It is the recommended compiler +for building the Dawn project on Windows. + +Advanced used can also use [MinGW](http://www.mingw.org/) or another compiler if +they wish, however this is not officially supported. + +After installing Visual Studio, you will need to install the C++ development +tools. This can be done by opening the Visual Studio Installer and selecting +the "Desktop development with C++" workload. + +**Linux** +You will need to install the GCC and Clang compilers. The compilers are usually +installed either by default or by installing the necessary packages for your +Linux distribution. + +For example, on Ubuntu, you can install the GCC and Clang compilers by running +the following command: +```bash +sudo apt install build-essential clang +``` + +On Arch Linux, you can install the GCC and Clang compilers by running the +following command: +```bash +sudo pacman -S base-devel clang +``` + +And on Fedora, you can install the GCC and Clang compilers by running the +following command: +```bash +sudo dnf install @development-tools clang +``` + +For other distributions, please refer to your distribution's documentation. + +**macOS** +You will need to install the Xcode command line tools. This can be done by done +by running the following command in your terminal: +```bash +xcode-select --install +``` + +Afterwards you will need to install and enable [Brew](https://brew.sh/). This +can be done by running the following command in your terminal: +```bash +/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)" +``` + + +### 2. CMake +CMake is a tool that is used to generate the compilation files for the Dawn +project. In short this is used to create versions of the Dawn project that can +be compiled on all different sets of compilers, so if you are compiling on, for +example, Windows, you can use CMake to generate the compilation files for the +Visual Studio compiler, or if you are compiling on Linux, you can use CMake to +generate the compilation files for the GCC or Clang compilers, and so-on. + +To install CMake, please follow the instructions for your specific operating +system. All other operating systems can be found on the [CMake downloads page](https://cmake.org/download/). + +**Windows** +You will need to download and install [CMake](https://cmake.org/download/). The +installer will guide you through the installation process and will install the +CMake executable to your system. It is recommended that you add CMake to your +system PATH if requested by the installer. + +**Linux** +Like installing the C/C++ compilers, you will need to install CMake using your +specific Linux distribution's package manager, there is also a chance that CMake +can be installed using flatpak or snap. Please refer to your distribution's +documentation for more information. + +For Ubuntu and other Debian-based distributions, you can install CMake by using +the following command: +```bash +sudo apt install cmake +``` + +For Arch Linux, you can install CMake by using the following command: +```bash +sudo pacman -S cmake +``` + +And for Fedora, you can install CMake by using the following command: +```bash +sudo dnf install cmake +``` + +**macOS** +You will install CMake using brew. We detailed how to install brew in the C/C++ +compiler section. To install CMake, run the following command in your terminal: +```bash +brew install cmake +``` + +### 3. Git +Git is a version control system that is used to manage the Dawn project's source +code. It is used to download the source code, and to update the source code to +the latest version. It is also used to manage the project's dependencies. Git is +a standard tool in the programming industry and is used to manage complex +projects, especially those that are worked on by multiple people. + +Git, like all of the above tools, is installed slightly differently depending on +your operating system. Please follow the instructions for your specific +operating system. + +**Windows** +You will need to download and install [Git](https://git-scm.com/downloads). The +installer will guide you through the installation process and will install the +Git executable to your system. It is recommended that you add Git to your system +PATH if requested by the installer. You do not need to add the Context-menu +items to your system. + +**Linux** +Like installing the C/C++ compilers, you will need to install Git using your +specific Linux distribution's package manager. It is also likely that git would +have been installed by default. Please refer to your distribution's docs for +more information. + +For Ubuntu and other Debian-based distributions, you can install Git by using +the following command: +```bash +sudo apt install git +``` + +For Arch Linux, you can install Git by using the following command: +```bash +sudo pacman -S git +``` + +And for Fedora, you can install Git by using the following command: +```bash +sudo dnf install git +``` + +**macOS** +You will install Git using brew. We detailed how to install brew in the C/C++ +compiler section. To install Git, run the following command in your terminal: +```bash +brew install git +``` + +### 4. An IDE +An IDE (Integrated Development Environment) is a tool that is used to view and +edit code of projects. While it is not required to use an IDE, it is recommended +since it can make the process of editing and running the project much easier. + +There are many different IDEs available, and often people chose an IDE that will +suit their preferences and needs, however if you are unsure of which IDE you +should be using, the Dawn project recommends using [Visual Studio Code](https://code.visualstudio.com/), +not to be confused with Visual Studio. + +Visual Studio Code is a free and open-source IDE that is widely used in the +industry for its simple, modern and configurable interface. For example you can +configure VSCode to work on Web Projects, Game Projects, and more. It acts like +a text editor with a bunch of extra tools. + +In addition to installing the VSCode IDE, we will add several recommended +plugins that will make editing the Dawn project easier and more seamless. + +To install VSCode follow the instructions for your specific operating system on +the [VSCode downloads page](https://code.visualstudio.com/download), as it can +vary a lot between operating systems. + +After installing VSCode, you will need to install the following plugins, by +clicking on the "Extensions" icon on the left-hand side of the VSCode window, +and searching for the following plugins. You may also be able to click on the +following links to install the plugins directly, but it may not work. +- [C/C++](https://marketplace.visualstudio.com/items?itemName=ms-vscode.cpptools) +- [CMake](https://marketplace.visualstudio.com/items?itemName=twxs.cmake) +- [CMake Tools](https://marketplace.visualstudio.com/items?itemName=ms-vscode.cmake-tools) + +## Downloading the Source Code +Now that you have all of the necessary tools installed, you can download the +source code of the project and using it to build. The source code contains all +of the code of the project, as well as the assets and the build scripts. This is +confidential information and should not be shared with anyone. + +### 1. Cloning the Repository +We previously installed the git tool, which is used to download the source code +of the project, and some third-party libraries. To download the source code, you +will need to open a terminal and navigate to the directory where you want to +download the source code to. + +Afterwards, you will need to run the following command: +```bash +git clone https://git.wish.moe/YourWishes/Dawn.git +``` +This will download the source code of the project to a new subdirectory called +"Dawn" and put all of the projects' source code within there. \ No newline at end of file