/VSCodePortable

A launcher for (Windows, 64-bit) Visual Studio Code in portable mode that checks for (and optionally installs) updates at startup. It installs Visual Studio Code in portable mode on the first run.

Primary LanguageAutoHotkeyGNU Lesser General Public License v2.1LGPL-2.1

VSCodePortable

A launcher for (Windows, 64-bit) Visual Studio Code in portable mode that checks for (and optionally installs) updates at startup. It installs Visual Studio Code in portable mode on the first run.

Visual Studio Code is a trademark of Microsoft Corporation. See License Stuff, below, for more information.

Installation

Snag the zip from the latest release and extract it where you want it.

Migrating an existing install to VSCodePortable

  1. Read all the steps here before following any links
  2. Run this once to install it (see Usage)
  3. Follow Microsoft's guide on migration to portable version
    • Skip the first few steps about installation and creating data folder.
    • The data folder you need to copy to is App\VSCode\data
    • You can overwrite anything in the data folder, since it was just auto-generated after you launched the program in step 2

Updating VSCodePortable

It's in the plans to give this script/"application" the functionality to update itself, but for now, you need to check github for a new release, go get the zip from the latest release, and extract it over your existing install.

Usage

Just double click the VSCode.bat file.

It will:

  1. Check for updates
  2. Alert you of any updates, allowing you to choose to update
  3. Install any updates that you have chosen to install (preserving your settings)
  4. Launch Visual Studio Code

How it works

The bat file launches an AutoHotkey script which parses a page from Visual Studio's website and extracts the latest version. It then compares that to the version of the local copy of Visual Studio Code. If you choose to update, it downloads the new version and updates your local copy. The bat file then launches the local copy.

Issues/Requests/Source

Please report issues or submit feature requests in the Issues section of this project on GitHub.

The source is obviously on GitHub, but you can also find the bulk of the code in the ahk file in the App/Bin directory.

Also, the programs used by VSCodePortable (AutoHotkey and 7-zip) are both open source. See License Stuff, below, for more information.

To-Do's

  • Check into Visual Studio Code licensing and provide any necessary license files [2019-09-30]
  • Check licensing for 7-zip and AutoHotkey and add any license files necessary [2019-09-30]
  • Instead of: backing up data folder, deleting VSCode, re-installing VSCode, and restoring data folder; I should just delete everything in VSCode except the data folder, and then exract over it... [2019-09-27]
  • Clean up code (currently just chunks of an old script I had, that I copied and pasted into a working order) [2019-09-27]
  • Add versioning somewhere [2019-09-27]
  • Update script to use latest AutoHotkey standards (probably need to look at documentation of all used commands, because the script I pulled code from is ~7 years old) [2019-09-27]
  • Prioritize my To-Do's [2019-09-27]
  • Use Progress bar instead of TrayTips to indicate progress [2019-09-27]
  • Check how Visual Studio Code checks for updates and see if that's a better way to do it here.
  • Introduce a way to update VSCodePortable itself
  • Do more error checking
  • Add Options
    • choose whether to store VSCode temp files in data directory instead of %AppData%
    • choose whether to delete temp files on update (to save time on backup and restore of settings) [2019-09-27] Now Irrelevant
    • choose whether to delete the settings backup after an update (to save disk space) [2019-09-27] Now Irrelevant
  • Write script that automates generating a release
  • Package bat as an exe
    • check licensing for VSCode's logo, and see if I can use it for exe [2019-09-30] I'm pretty confident that I can't since it's trademarked. I'll just draw a terrible rendition in paint and use that.
    • create a rough, but not trademark-violating version of the logo to use... [2019-09-30]
    • Make the icon less hideous, but still not at risk of being confused with being associated with Microsoft
  • Add "build" instructions to readme
  • Add GUI back (my old script that I pulled most of this from had a GUI for settings and whatnot)
  • Maybe move the To-Do's out of the readme
  • Maybe package it with PortableApps.com installation tool
  • Add instructions/support for using Git for Windows Portable
    • This would include info for letting VSCode know where git is (and ssh for using the remote development SSH extension)
    • Support may look like allowing a config which would modify the path variable prior to launch or checking a parent folder for Git for Windows Portable
  • Write a script that detects if the website version detection or download link breaks
  • Maybe write a script that maintains latest versions at a dedicated uri
    • This script would no longer be responsible for the website scraping (except as a fallback)
    • Could also use another uri for the version of this script itself
    • Wouldn't necessarily have to make people update this "app" if the structure of the website changes
    • Downside is that update detection would be dependent on the uptime of my server and that the server would likely only scrape once or twice a day, adding somewhat of a lag to updates
  • Look into submitting a pull to Visual Studio Code to allow the data folder to be outside the program directory, but still be in portable mode. (maybe still have the data directory, but put a text file with the relative path to the data directory?)
    • This would make updating a lot simpler
    • Data could just stay in the Data folder
  • Maybe just convert to a PowerShell script to remove executable dependencies (may make it not work as well on random computers due to PowerShell permissions) Not going to do

License Stuff

7-zip

Per the requirements listed in the FAQ of the readme distributed with the 7-zip extras:

  1. I am using 7-zip in this application. (It extracts the setup files to install updates.)
  2. 7-zip is provided under the GNU LGPL license
  3. You can get the 7-zip source code from https://www.7-zip.org.

The license file provided with the download I used is available in the Data\Other_Licenses directory.

AutoHotkey

Per the requirements of the AutoHotkey license, I am opting to provide a link to the source code of AutoHotkey rather than including the source code explicitly: link to AutoHotkey source. If for any reason this does not fully fulfill the requirements of the license, I will provide a copy of the source in a valid medium if you contact me at the email listed on my GitHub profile.

The license file provided with the download I used is available in the Data\Other_Licenses directory.

Visual Studio Code

You can find the Visual Studio Code license information somewhere in the App\VSCode folder (App\VSCode\resources\app at the time of writing).

It looks like I'm safe license-wise, as I am not breaking this bit that seems relevant:

You may not

  • [...]
  • share, publish, rent or lease the software, or provide the software as a stand-alone offering for others to use

Since I am not distributing any files, and I'm only using their public services to acquire the software and check for updates, I believe I'm not breaking the terms of the license. If anyone with more legal experience has any important insights for me related to this, please reach out to me on the email listed on my GitHub profile.

Important Clarifications

Visual Studio Code is a trademark of Microsoft Corporation. While this repo and application are named "VSCodePortable", the name "VSCode" technically applies only to the open source portion of Visual Studio Code which is hosted on their GitHub page. So, despite the fact that this application downloads and updates Visual Studio Code, it is named VSCode (as is the local folder it is installed to) to avoid trademark violations. This is also the reason why I can't use the Visual Studio Code logo anywhere (and why the one I made is intentionally bad, to prevent anyone from thinking that Microsoft was associated with this project).