Paltry creates and updates a portable development environment for recent Windows installs. You might want this if your account doesn't have admin permissions, to avoid interfering with any software installed on the system, or to apply the best practices of DevOps to your development environment. Setup a new machine in minutes instead of hours and keep it up-to-date just as easily. Configurable and scriptable to accommodate your needs.
The following tools are available:
- 7-Zip
- Anaconda for Python development (using the minimal Miniconda version)
- Chromium
- Eclipse IDE for Java EE Developers (with workspace enhancements included)
- Git (able to setup SSH keys, auto clone repos, and update Paltry itself)
- Java OpenJDK 11
- Lazygit
- Apache Maven (encrypted server passwords support included)
- MSYS2 (enables installing Ruby gems with native extensions)
- Node.js
- npm
- OpenSSL
- Ruby
- SmartGit
- Visual Studio Code
- WizTree
- Windows 10 (or upgrade to PowerShell 5.1)
- No applications need be preloaded
- No special permissions outside of being able to write to a user folder
- Create a local folder for your portable environment (
~\Developer
recommended) - Download the latest Paltry ZIP archive
- Unblock the downloaded ZIP archive
- See here for instructions
- Open the downloaded archive
- Drag the
paltry-master
folder in the archive to the portable environment folder you created above and rename it topaltry
- Open the extracted
paltry
folder
- Unblock the downloaded ZIP archive
- Configure your environment
- If you have an existing
config.json
already prepared, overwrite the one in the extracted Paltry - Otherwise consider editing the default
config.json
to make it your own at this point- You can always customize this later and rerun the build
- The default config comes with all the tools but some features require additional configuration
- If you have an existing
- Double click on
build.cmd
in yourpaltry
folder- Paltry will now build
- The first time this will take anywhere from 1-15+ minutes depending on your selected plugins and network speed
- By default - when the build completes - an explorer window will pop up with various shortcuts
- Feel free to launch any of the tools from here
- For bonus points add these as a toolbar
- Right click on your taskbar
- Toolbars
- New toolbar...
- Select the same path as the window launched after the build
- Protip: you can copy the full path from the address bar of each
The only file users should modify is config.json
. It is intended to encompass all user-configurable behavior. The following is a definition of the supported configuration options.
cwd (string)
- The current working directory to use when launching the console.env ({string: string})
- Environment variables to set for the portable environment. Note thatPath
is special since it is appended to by Paltry and so should be extended with thepath
option below.disabled ([string])
- A blacklist of the plugins not to run. Note that nonexistant plugins are ignored. The default config takes advantage of this to list available plugins "commented out" by prefixing them with//
. Removing the "comment" in this list will actually disable that plugin. If you don't ever intend to disable a plugin feel free to remove it from this list entirely.versions ({string: string})
- Most tools support installing the latest available version except for 7zip, which must have a version set. Themaven
,node
,npm
, andruby
tools support specifying an exact version here. An empty string value or omitting a key entirely defaults to the latest version.path ([string])
- An array of additional locations to add to your path. Usefully for adding other tools not supported by Paltry that you manually downloaded.scripts ({string: [string]})
- Custom scripts are defined with the name as the key (this becomes the filename/command used to call them) and an array of the lines in the script as the value. Note these will create batch files that are run with the command prompt.eclipse (object)
skipIntro (boolean)
- Bypass displaying maximized welcome screen that blocks immediate use.unlimitedConsoleOutput (boolean)
- Don't discard console output after a limited number of characters.gitIconDecorations (boolean)
- Use icons to label Git modified resources instead of text.cleanInstallMavenLaunchConfig (boolean)
- Add a launch configuration for Maven to perform aclean install
build on the current project.
git (object)
ssh (boolean)
- Enabling this will make sure you have SSH keys setup, generating them if needed. When keys are generated, the public key will be printed to the console. Please make sure to add this public key to any git remotes you intend to communicate with using SSH.repos ({string: string})
- Git repositories you want Paltry to clone automatically on your behalf. The local folder to use is the key with the remote URL as the value.
maven (object)
cleanup (boolean)
- Optionally cleanup remote repo data from your m2 repo. This will resolve some issues with not finding certain artifacts at the cost of a longer next build.servers ([string])
- If you use private Maven repos (such as a Nexus server) then add their ids in an array to this property. The build will prompt for your credentials and will save encrypted versions of them tosettings.xml
. Different credentials per server are not supported at this time.
vscode (object)
extensions ([string])
- Array of extensions to ensure are installed. Make sure to use the fully qualifiedpublisher.extension
name.settings (object)
- User settings for VS Code. Note that these will override any existing settings on a per-property basis. Apologies in advance for the ugly formatting on the JSON output.
Paltry is MIT licensed. See LICENSE.