Table of Contents
Developer
If you want to develop a feature or fix a bug for this project, you'll need to follow the following steps to ensure the project will compile.
Prerequisites
- Visual Studio (VS) 2022 Community Edition (or higher)
.NET desktop development
needs to be installed- As of v0.85.1, the following components are required
.NET 8.0 Runtime
Windows 10 SDK
and/orWindows 11 SDK
VS Solution Setup
To get this repo working with PowerToys:
- Clone or download PowerToys to your local disk
git clone https://github.com/microsoft/PowerToys.git
- Get submodules for PowerToys
cd .\PowerToys
git submodule update --init --recursive
- Fork this repo
- Clone or download the fork into your local PowerToys repo (PowerToys\src\modules\launcher\Plugins)
cd .\src\modules\launcher\Plugins
git clone https://github.com/lin-ycv/EverythingPowerToys.git --depth 1
cd ../../../../
- Target a PT release to develop for by creating a detached head at that tag
git log
find the commit you want to detach from, copy the commit hash and pressq
to exit log
git checkout ##########################################
- In VS, add local clone as an existing project to PowerToy's Plugins folder (modules\launcher\Plugins)
- Develop and compile as needed
To pull updates from PowerToys:
- discard changes to PT and exit detached head
git reset --hard
git checkout main
- pull updates
git pull
- add existing project (step 5)
Build
Use Ctrl+B
to build only EPT and its references, you do not need to build the whole PT solution.
The Post Build event includes commands that calls NSIS to build a exe installer. If you don't have NSIS installed, you can remove the folowing commands in the post build so you don't get any errors.
C:\Program Files (x86)\NSIS\makensis" /Dver=$(Version) /Ddirect=$(TargetDir) /Dplatform=$(Platform) .\NSIS\exeCreator.nsi
certUtil -hashfile .\bin\EverythingPT-$(Version)-$(Platform).zip SHA256 >> .\bin\$(Platform)_CHECKSUM.txt
certUtil -hashfile .\bin\EverythingPT-$(Version)-$(Platform).exe SHA256 >> .\bin\$(Platform)_CHECKSUM.txt
Contributor
Translator
With VS
This is the recommended method, as VS Resource Explorer makes it easy to cross-compare the value you are editing. However, it does require you to install VS.
- Clone just EPT repo
- Skip step 2 if you're editing a pre-existing translation
- Duplicate
Resources.resx
in Properties folder and rename toResource.(Locale code).resx
- ie:
Resources.zh-tw.resx
- Locale code is made up of 2 parts ISO 639-1 language code and ISO 3166-1 country code
- ie:
- Duplicate
- Open
Community.PowerToys.Run.Plugin.Everything.csproj
in VS - Navigate to Resource Explorer and edit the values as needed.
- Create a PR
Without VS
This method does not require you to install any additional software, as you can open resx files in notepad.
-
- If creating a new translation:
- Download the English Resource file and rename to
Resource.(Locale code).resx
- ie:
Resources.zh-tw.resx
- Locale code is made up of 2 parts ISO 639-1 language code and ISO 3166-1 country code
- ie:
- Download the English Resource file and rename to
- If editing a pre-existing translation:
- Download the respective Resource file
- If creating a new translation:
- Edit the
<value>
field- If you don't have a translation for a certain value, or if you wish to use the English text, you can simply delete the
data
tag for that value
- If you don't have a translation for a certain value, or if you wish to use the English text, you can simply delete the
- Create a PR
Documentation
If there's any issues with any documentations, please open a Discussion, or create a PR with the appropriate fixes