* delet chatterino.pro * Update documentation * Update Github Actions config * Update Cirrus CI config * Attempt to fix Cirrus CI * Add changelog entry * Delete tools/update_filelist.py It was a QMake-only script? Maybe will need revert + change to CMake or something? * fix? * Fuck this linter * Attempt to clean up build.yml a little * Add cmaake to install list, remove step for qmake PATH * Change list entries to always use 1. Sneaky unrelated change * These are no longer tests! * FUCK YOU PRETTIER * Make BUILDING_ON_LINUX.md simpler * Get rid of Jenkins * Get rid of travis * Remove dupes * Remove appveyor * Remove qmake from conanfile * Try removing explicit qmake path * Nothing uses the qt style plugins installer anymore * Update manual linux building instructions * Update freebsd compilation instructions with a copy paste from the linux instructions * Remove unused docker files * Remove linux breakpad build script as it's unused * Update changelog entry phrasing * Lint build markdown files * Change top changelog entry to not be confused as a link * Skip QtCreator conan setup if conan is disabled This reduces the amount of warnings & errors Windows users get with QtCreator * lint building on linux file Co-authored-by: Rasmus Karlsson <rasmus.karlsson@pajlada.com>
10 KiB
Building on Windows
Note that installing all of the development prerequisites and libraries will require about 30 GB of free disk space. Please ensure this space is available on your C:
drive before proceeding.
This guide assumes you are on a 64-bit system. You might need to manually search out alternate download links should you desire to build Chatterino on a 32-bit system.
Visual Studio 2022
Download and install Visual Studio 2022 Community. In the installer, select "Desktop development with C++" and "Universal Windows Platform development".
Notes:
- This installation will take about 17 GB of disk space
- You do not need to sign in with a Microsoft account after setup completes. You may simply exit the login dialog.
Boost
-
First, download a boost installer appropriate for your version of Visual Studio.
-
Visit the downloads list on SourceForge.
-
Select the latest version from the list.
-
Download the
.exe
file appropriate to your Visual Studio installation version and system bitness (choose-64
for 64-bit systems). Visual Studio versions map as follows:14.3
in the filename corresponds to MSVC 2022,14.2
to 2019,14.1
to 2017,14.0
to 2015. Anything prior to Visual Studio 2015 is unsupported. Please upgrade should you have an older installation.Convenience link for Visual Studio 2022: boost_1_79_0-msvc-14.3-64.exe
-
-
When prompted where to install Boost, set the location to
C:\local\boost
. -
After the installation finishes, rename the
C:\local\boost\lib64-msvc-14.3
(or similar) directory to simplylib
(C:\local\boost\lib
).
Note: This installation will take about 2.1 GB of disk space.
OpenSSL
For our websocket library, we need OpenSSL 1.1
- Download OpenSSL for windows, version
1.1.1q
: Download - When prompted, install OpenSSL to
C:\local\openssl
- When prompted, copy the OpenSSL DLLs to "The OpenSSL binaries (/bin) directory".
For Qt SSL, we need OpenSSL 1.0
- Download OpenSSL for Windows, version
1.0.2u
: Download - When prompted, install it to any arbitrary empty directory.
- When prompted, copy the OpenSSL DLLs to "The OpenSSL binaries (/bin) directory".
- Copy the OpenSSL 1.0 files from its
\bin
folder toC:\local\bin
(You will need to create the folder) - Then copy the OpenSSL 1.1 files from its
\bin
folder toC:\local\bin
(Overwrite any duplicate files) - Add
C:\local\bin
to your path folder (Follow the guide here if you don't know how to do it)
If the 1.1.x download link above does not work, try downloading the similar 1.1.x version found here. Note: Don't download the "light" installer, it does not have the required files.
Note: This installation will take about 200 MB of disk space.
Qt
- Visit the Qt Open Source Page.
- Scroll down to the bottom
- Then select "Download the Qt Online Installer"
Notes:
- Installing the latest stable Qt version is advised for new installations, but if you want to use your existing installation please ensure you are running Qt 5.12 or later.
When prompted which components to install:
- Unfold the tree element that says "Qt"
- Unfold the top most tree element (latest stable Qt version, e.g.
Qt 5.15.2
) - Under this version, select the following entries:
MSVC 2019 64-bit
(or alternative version if you are using that)Qt WebEngine
(optional)
- Under the "Tools" tree element (at the bottom), ensure that
Qt Creator X.X.X
andDebugging Tools for Windows
are selected. (they should be checked by default) - Continue through the installer and let the installer finish installing Qt.
Note: This installation will take about 2 GB of disk space.
Compile with Breakpad support (Optional)
Compiling with Breakpad support enables crash reports that can be of use for developing/beta versions of Chatterino. If you have no interest in reporting crashes anyways, this optional dependency will probably be of no use to you.
- Open up
lib/qBreakpad/handler/handler.pro
in Qt Creator - Build it in whichever mode you want to build Chatterino in (Debug/Profile/Release)
- Copy the newly built
qBreakpad.lib
to the following directory:lib/qBreakpad/build/handler
(You will have to manually create this directory)
Run the build in Qt Creator
- Open the
CMakeLists.txt
file by double-clicking it, or by opening it via Qt Creator. - You will be presented with a screen that is titled "Configure Project". In this screen, you should have at least one option present ready to be configured, like this:
- Select the profile(s) you want to build with and click "Configure Project".
How to run and produce builds
- In the main screen, click the green "play symbol" on the bottom left to run the project directly.
- Click the hammer on the bottom left to generate a build (does not run the build though).
Build results will be placed in a folder at the same level as the "chatterino2" project folder (e.g. if your sources are at C:\Users\example\src\chatterino2
, then the build will be placed in an automatically generated folder under C:\Users\example\src
, e.g. C:\Users\example\src\build-chatterino-Desktop_Qt_5_15_2_MSVC2019_64bit-Release
.)
- Note that if you are building chatterino purely for usage, not for development, it is recommended that you click the "PC" icon above the play icon and select "Release" instead of "Debug".
- Output and error messages produced by the compiler can be seen under the "4 Compile Output" tab in Qt Creator.
Producing standalone builds
If you build chatterino, the result directories will contain a chatterino.exe
file in the $OUTPUTDIR\release\
directory. This .exe
file will not directly run on any given target system, because it will be lacking various Qt runtimes.
To produce a standalone package, you need to generate all required files using the tool windeployqt
. This tool can be found in the bin
directory of your Qt installation, e.g. at C:\Qt\5.15.2\msvc2019_64\bin\windeployqt.exe
.
To produce all supplement files for a standalone build, follow these steps (adjust paths as required):
-
Navigate to your build output directory with Windows Explorer, e.g.
C:\Users\example\src\build-chatterino-Desktop_Qt_5_15_2_MSVC2019_64bit-Release
-
Enter the
release
directory -
Delete all files except the
chatterino.exe
file. You should be left with a directory only containingchatterino.exe
. -
Open a command prompt and execute:
cd C:\Users\example\src\build-chatterino-Desktop_Qt_5_15_2_MSVC2019_64bit-Release\release C:\Qt\5.15.2\msvc2019_64\bin\windeployqt.exe chatterino.exe
-
Go to
C:\local\bin\
and copy these dll's into yourrelease folder
.libssl-1_1-x64.dll libcrypto-1_1-x64.dll ssleay32.dll libeay32.dll
-
The
releases
directory will now be populated with all the required files to make the chatterino build standalone.
You can now create a zip archive of all the contents in releases
and distribute the program as is, without requiring any development tools to be present on the target system. (However, the vcredist package must be present, as usual - see the README).
Using CMake
Open up your terminal with the Visual Studio environment variables, then enter the following commands:
mkdir build
cd build
cmake -G"NMake Makefiles" -DCMAKE_BUILD_TYPE=Release -DUSE_CONAN=ON ..
nmake
Building/Running in CLion
Note: We're using build
instead of the CLion default cmake-build-debug
folder.
Install conan and make sure it's in your PATH
(default setting).
Clone the repository as described in the readme. Open a terminal in the cloned folder and enter the following commands:
mkdir build && cd build
conan install .. -s build_type=Debug
Now open the project in CLion. You will be greeted with the Open Project Wizard. Set the CMake Options to
-DCMAKE_PREFIX_PATH=C:\Qt\5.15.2\msvc2019_64\lib\cmake\Qt5
-DUSE_CONAN=ON
-DCMAKE_CXX_FLAGS=/bigobj
and the Build Directory to build
.
After the CMake project is loaded, open the Run/Debug Configurations.
Select the CMake Applications > chatterino
configuration and add a new Run External tool task to Before launch.
- Set the Program to
C:\Qt\5.15.2\msvc2019_64\bin\windeployqt.exe
- Set the Arguments
to
$CMakeCurrentProductFile$ --debug --no-compiler-runtime --no-translations --no-opengl-sw --dir bin/
- Set the Working directory to
$ProjectFileDir$\build
Now you can run the chatterino | Debug
configuration.
If you want to run the portable version of Chatterino, create a file called modes
inside of build/bin
and
write portable
into it.