No description
Find a file
Matthieu Gallien b5c083d1a3
Merge pull request #30 from nextcloud/bugfix/betterDocAboutRunSteps
fix: add missing doc about the QT_PLUGIN_PATH environment variable
2025-07-11 13:19:58 +02:00
.github add CI run on windows using craftmaster to test the blueprint 2024-11-28 09:30:55 +01:00
binary/_win fix dependency of inkscape after changes in Craft upstream 2023-08-31 10:05:25 +02:00
libs/libp11 fix(libs/libp11): switch to dev-utils/pkgconf 2025-05-05 15:19:51 +02:00
nextcloud-client clean separation between macOS specific build options and generic ones 2024-12-13 10:28:36 +01:00
.gitignore ignore some files 2021-05-18 15:07:30 +02:00
README.md fix: add missing doc about the QT_PLUGIN_PATH environment variable 2025-07-10 15:12:28 +02:00

🖥️ Nextcloud Desktop Client blueprints

📘 We decided to use KDE Craft to get all binary dependencies of the Nextcloud files desktop client.

System requirements

  • Windows 10 or Windows 11
  • The desktop client code
  • Python 3
  • PowerShell
  • KDE Craft
  • Microsoft Visual Studio 2022
  • Inkscape
  • A Nextcloud server

Tip

We highly recommend Nextcloud development environment on Docker Compose for testing/bug fixing/development.
▶️ https://juliushaertl.github.io/nextcloud-docker-dev/

Set up Windows 10 or Windows 11

Set up Microsoft Visual Studio

  1. Open the Visual Studio Installer.
  2. Click on Modify:

vs-studio-2022

  1. Select Desktop development with C++:

vs-studio-dev

Install Inkscape

  • Install the latest version of Inkscape.

Set up KDE Craft

  1. You will need to install Python 3: https://www.python.org/downloads/windows/
  2. Set up KDE Craft as instructed in Get Involved/development/Windows - KDE Community Wiki.
  3. Use the default options, including Qt6 (since desktop 3.14, we are using Qt 6).

Important

C:\CraftRoot is the path used by default by KDE Craft.
When you are setting it up you may choose a different folder: you will need to
⚠️ change from C:\CraftRoot to the path you picked ⚠️ in the next steps listed here.

How to use the desktop client blueprints

  1. After following the instructions in Get Involved/development/Windows - KDE Community Wiki.
  2. Open PowerShell.
  3. Run craftenv.ps1 as described in the instructions above:
C:\CraftRoot\craft\craftenv.ps1
  1. Add the blueprints from this repository:
craft --add-blueprint-repository https://github.com/nextcloud/desktop-client-blueprints.git
$ craft craft
  1. Install all desktop client dependencies:
craft --install-deps nextcloud-client

Compiling the desktop client

  1. Make sure your environment variable %PATH% has no conflicting information to the environment you will use to compile the client. For instance, if you have installed OpenSSL previously and have added it to %PATH%, the OpenSSL installed might be a different version than what was installed via KDE Craft.
  2. To use the tools installed with Visual Studio, you need the following in your %PATH%: path
  3. Open the Command Prompt (cmd.exe).

Important

The next steps has only been tested and proven to work when using Command Prompt.

  1. Run:
"C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Auxiliary\Build\vcvarsall.bat" x64

Tip

Alternatively you can use the tools installed with KDE Craft by adding them to %PATH% in your current session:

set "PATH=C:\CraftRoot\bin;C:\CraftRoot\dev-utils\bin;%PATH%"

You also need to set the Qt path for plugins via an environment variable

set "QT_PLUGIN_PATH=C:\CraftRoot\bin\plugins"

This will result in using the cmake version downloaded with KDE Craft.

  1. Clone the desktop client repository.
git clone https://github.com/nextcloud/desktop.git
  1. Create the build folder <build-folder>.
mkdir <build-folder>
  1. Go into the build folder.
cd <build-folder>
  1. Run cmake.
cmake ..\<desktop-cloned-repo> -G Ninja -DCMAKE_INSTALL_PREFIX=. -DCMAKE_PREFIX_PATH=C:\CraftRoot -DCMAKE_BUILD_TYPE=RelWithDebInfo
  1. Compile the desktop client
cmake --build .

Note

If you have questions about it, you may use the forums at https://help.nextcloud.com to ask them.
🐛 If you find bugs with these steps, you may open a GH issue at https://github.com/nextcloud/desktop/issues.