- Python 3.5+
- Visual Studio 2017 or Visual Studio Build Tools 2017 with the Windows 10 SDK
- nsis (for installer creation)
- msys2 (for using makefile method)
When installing Visual Studio or the Visual Studio Build Tools with the Windows 10 SDK on versions of Windows below 10 be sure to make sure that the Universal CRT is installed before installing Visual studio as noted in the Windows 10 SDK Notes and found at KB2999226.
After installing python it is recommended to update setuptools before compiling packages. To update run (example is for python launcher and 3.7):
$ py -3.7 -m pip install --upgrade setuptools
More details on setting up python for compiling packages on windows can be found on the python wiki
To build with a different python version 3.5 vs 3.7 or 32 bit vs 64 bit specify that version instead of -3.7 to the py
command below. If you want to build additional versions while keeping all virtual environments setup use a different location for each vritual environment.
$ cd <dupeGuru directory>
$ py -3.7 -m venv .\env
$ .\env\Scripts\activate
$ pip install -r requirements.txt -r requirements-windows.txt
$ python build.py
$ python run.py
It is possible to build dupeGuru with the makefile on windows using a compatable POSIX environment. The following steps have been tested using msys2. Before running make:
- Install msys2 or other POSIX environment
- Install PyQt5 globally via pip
- Use the respective console for msys2 it is
msys2 msys
Then the following execution of the makefile should work. Pass the correct value for PYTHON to the makefile if not on the path as python3.
$ cd <dupeGuru directory>
$ make PYTHON='py -3.7'
$ make run
NOTE: Install PyQt5 & cx-Freeze with requirements-windows.txt into the venv before running the packaging scripts in the section below.
You need to use the respective x86 or x64 version of python to build the 32 bit and 64 bit versions. The build scripts will automatically detect the python architecture for you. When using build.py make sure the resulting python works before continuing to package.py. NOTE: package.py looks for the 'makensis' executable in the default location for a 64 bit windows system. Run the following in the respective virtual environment.
$ python package.py
The complete test suite can be run with tox just like on linux.