Skip to content

AjayKMehta/setup-machine

Repository files navigation

Setup machine

Overview

Important

This document assumes that your C: drive has limited space (e.g. SSD) and you have another hard drive (D:) which you can use to install apps on instead. If that is not the case, you can omit custom location (-l) in winget install invocation or specify a directory on your C drive instead.

Setting up a new Windows machine for development is painful.

This document hopefully alleviates the pain.

Note

🚧 Look into using winget configure to replace script to install apps.
👉 Need to learn how to specify custom install path.

winget

Install winget from Microsoft Store if it is not already installed.

Firefox

  • Install: winget install Mozilla.Firefox.
  • Use Firefox account to sync various items.

Fonts

Notepad++

  • Download from web and install or use winget:

    winget install -e Notepad++.Notepad++
  • Enable support for fonts with ligatures: Preferences ➡️MISC. Make sure Use DirectWrite (May improve rendering special characters, need to restart Notepad++) is ✅.

Plugins

  • Compare
  • EditorConfig
  • JSTool
  • Location Navigate
  • XML Tools

See here.

- Install: winget install Microsoft.OpenSSH.Beta

- Add install folder (C:\Program Files\OpenSSH) to $Path.

KeePassXC

  • Install KeePassXC:

    winget install KeePassXCTeam.KeePassXC
  • See here for information on getting started.

  • Add installation folder to $Path if needed:

    $path = [System.Environment]::GetEnvironmentVariable('Path', 'Machine')
    $path += ';C:\Program Files\KeePassXC'
    [System.Environment]::SetEnvironmentVariable('Path', $path, 'Machine')

PowerShell

  • Install:

    winget install -e --id Microsoft.PowerShell
  • Install Oh My Posh as theme engine:

    Invoke-RestMethod https://ohmyposh.dev/install.ps1 | Invoke-Expression

    This will add install path to $Path.

    In a new shell:

    oh-my-posh completion powershell | Out-File -encoding utf8 ~\Documents\PowerShell\Scripts\ArgumentCompleters\oh-my-posh.ps1
  • Disable telemetry:

    [System.Environment]::SetEnvironmentVariable('POWERSHELL_TELEMETRY_OPTOUT', 1, 'User')
  • See here for info on how to resolve the issue Enabling PowerShell remoting fails due to Public network connection type

Modules

See ModulesToInstall.txt for list of modules to install.

Secrets Management

  • Install modules if necessary:

    Install-Module -Name Microsoft.PowerShell.SecretManagement -Repository PSGallery
    Install-Module -Name Microsoft.PowerShell.SecretStore -Repository PSGallery
    Install-Module SecretManagement.KeePass
  • Configure secret store:

    Set-SecretstoreConfiguration -Scope CurrentUser -Authentication Password -PasswordTimeout 3600
    Set-SecretStorePassword
  • Register vaults:

    Register-SecretVault -Name SecretStore -ModuleName Microsoft.PowerShell.SecretStore -DefaultVault
    # Assuming you created a Keepass DB with path below
    Register-SecretVault -Name 'Keepass' -ModuleName 'SecretManagement.Keepass' -VaultParameters @{
    Path = "D:\keepass\Passwords.kdbx"
    UseMasterPassword = $true
    }
  • Test that it works:

    Get-SecretInfo
    Test-SecretVault -Name 'Keepass'

GPG

  • Install required apps:

    winget install --id GnuPG.GnuPG -l 'D:\Apps\GnuPG'
    winget install --id GnuPG.Gpg4win -l 'D:\Apps\Gpg4win'
  • Add to $Path if needed:

    $path = [System.Environment]::GetEnvironmentVariable('Path', 'Machine')
    $path += ';D:\Apps\Gpg4win\bin;D:\Apps\GnuPG\bin'
    [System.Environment]::SetEnvironmentVariable('Path', $path, 'Machine')

Managing keys

List keys:

$secretKeys = (gpg --list-secret-keys --with-colons | sls -Pattern '^sec:').Line | % { $parts = $_ -split ':'; $parts[4] }
$secretKeys

$keys = (gpg --list-keys --with-colons | sls -Pattern '^pub:').Line | % { $parts = $_ -split ':'; $parts[4] }
$keys

Export keys:

$keys | % { gpg --export -a $_ | Out-File ${_}_.asc }
$secretKeys | % { gpg --export-secret-keys -a $_ | Out-File ${_}_sec.asc }

Import keys:

ls *.asc -Name | % { gpg --import $_ }

Useful Links

WinMerge

WinMerge is a diff/merge tool.

  • Install:

    winget install --id WinMerge.WinMerge -l 'D:\Apps\WinMerge'
  • Add to $Path:

    $path = [System.Environment]::GetEnvironmentVariable('Path', 'Machine')
    $path += ';D:\Apps\WinMerge'
    [System.Environment]::SetEnvironmentVariable('Path', $path, 'Machine')

SlickRun

SlickRun is a free-floating utility for Windows that can launch programs. Download it from here.

git

💡 git comes bundled with Git Credential Manager on Windows. If you keep getting prompted to login when pushing to or pulling from a remote, you may have more than one account set up. To fix, see these instructions.

git-related platforms

GitHub

GitHub CLI

  • Download GitHub CLI. See Releases for latest version.

    $version = '2.39.0'
    Invoke-RestMethod "https://github.com/cli/cli/releases/download/v${version}/gh_${version}_windows_amd64.zip" -OutFile ~/Downloads/gh_${version}_windows_amd64.zip
  • Copy binary to desired location.

    [string] $folder = 'D:\Apps'
    7z e C:\Users\Ajay\Downloads\gh_2.39.0_windows_amd64.zip bin\gh.exe -o"$($folder)"
  • Add shell completion script (that you can dot-source in PowerShell profile):

    gh completion -s powershell | Out-File -Encoding utf8 ~\Documents\PowerShell\Scripts\ArgumentCompleters\gh.ps1
GitHub PAT
Extensions

Install extensions:

gh extension install actions/gh-actions-cache
gh extension install securesauce/gh-alerts
gh extension install mislav/gh-branch
gh extension install chelnak/gh-changelog
gh extension install vilmibm/gh-contribute
gh extension install mislav/gh-cp
gh extension install dlvhdr/gh-dash
gh extension install yuler/gh-download
gh extension install owenvoke/gh-gpg-key
gh extension install k1LoW/gh-grep
gh extension install redraw/gh-install
gh extension install heaths/gh-label
gh extension install meiji163/gh-notify
gh extension install seachicken/gh-poi
gh extension install samcoe/gh-repo-explore
gh extension install samcoe/gh-triage
gh extension install vilmibm/gh-user-status

act

act lets you run your GitHub Actions locally!

Install: winget install nektos.act.

actionlint

actionlint is a linter for GitHub Actions workflow files.

Install: winget install rhysd.actionlint.

To create a config in a repo: actionlint --init-config.

GitLab

GitLab CLI

  • Install:

    winget install Glab.Glab
  • Get a GitLab PAT with at least api and write_repository scopes.

  • Setup: glab auth login.

  • Shell completion: glab completion -s powershell | Out-File ~\Documents\PowerShell\Scripts\ArgumentCompleters\glab.ps1 -Encoding utf8

Authentication

  1. Create a PAT.
  2. Follow prompts for glab auth login. Or, create $GITLAB_TOKEN with value set to PAT.

GitExtensions

Install: winget install GitExtensionsTeam.GitExtensions.

git absorb

git absorb eliminates tedious manual work of creating fixup commits (and rebasing if you specify --and-rebase). It can automatically identify which commits are safe to modify, and which staged changes belong to each of those commits. It will then write fixup! commits for each of those changes.

git add . # fixed files
git absorb --and-rebase

Install: winget install tummychow.git-absorb -l D:\Apps\CLI.

Grab latest release from repo and add install folder to $Path.

Java

  • Install:

    winget install Oracle.JDK.17
  • Set $JAVA_HOME:

    [System.Environment]::SetEnvironmentVariable('JAVA_HOME', 'C:\Program Files\Java\jdk-17.0.5', 'Machine')
  • Add bin folder (C:\Program Files\Java\jdk-17.0.5\bin) to $Path.

  • Install maven from https://maven.apache.org/download.cgi and add installation folder to $Path.

CLI Apps

💡 Install CLI apps in a common directory and add common directory to $Path.

clink

FROM README.md:

Clink combines the native Windows shell cmd.exe with the powerful command line editing features of the GNU Readline library, which provides rich completion, history, and line-editing capabilities.

Install: winget install --id chrisant996.Clink. Update: clink update List settings: clink set -i

For 📄, see here.

Follow instructions to set up completion.

parallel-disk-usage

From Github repo:

Highly parallelized, blazing fast directory tree analyzer

Grab latest binary and shell completion script from Releases page.

typos

typos is a CLI tool to check spelling. It has less false positives compared to the alternatives. Get the latest binaries from here.

less

less is a pager.

  • Install:

    winget install jftuga.less
  • Set environment variables:

    [System.Environment]::SetEnvironmentVariable('LESS', '-RX', 'Machine')
    [System.Environment]::SetEnvironmentVariable('LESSCHARSET', 'UTF8', 'Machine')

fzf

fzf is a command-line fuzzy finder.

  1. Get latest binaries from here. If you have already installed GitHub CLI and 7zip:

    $downloadFolder = (Resolve-Path ~\Downloads).Path
    $pattern = 'fzf*windows*amd64.zip'
    gh release download --repo junegunn/fzf --pattern $pattern -D $downloadFolder
    $zipFile = Get-ChildItem $downloadFolder -Filter $pattern | Select-Object -First 1
    $destination = 'D:\Apps\CLI'
    & 'C:\Program Files\7-Zip\7z.exe' e -o"$destination" $zipFile 'fzf.exe'
    $zipFile | Remove-Item -Force
  2. Override default command: set $FZF_DEFAULT_COMMAND to rg --files . 2> nul.

  3. Override default options:

    $opts = @'
    --color=fg:-1,bg:-1,hl:#5fff87,fg+:-1,bg+:-1,hl+:#ffaf5f
    --color=info:#af87ff,prompt:#5fff87,pointer:#ff87d7,marker:#ff87d7,spinner:#ff87d7
    --bind alt-up:preview-page-up,alt-down:preview-page-down,alt-e:preview-top,alt-f:preview-bottom,ctrl-e:half-page-up,ctrl-f:half-page-down
    '@
    [System.Environment]::SetEnvironmentVariable('FZF_DEFAULT_OPTS', $opts, 'User')

ripgrep

ripgrep is a powerful search tool.

  • Get it from here.
  • Add installation path to $Path.

delta

delta is a syntax-highlighting pager for git, diff, and grep output. In order to use it with git, you need to modify .gitconfig or you can import dot files.

  • Installation notes

  • Add to PowerShell profile: $env:DELTA_PAGER = 'less -rFX'

  • Generate shell completion: delta --generate-completion powershell | Out-File -Encoding utf8 ~\Documents\PowerShell\Scripts\ArgumentCompleters\delta.ps1

yq

yq is a portable command-line YAML, JSON, XML, CSV and properties processor.

Install: winget install MikeFarah.yq.

jq

jq is a command-line JSON processor.

Install: winget install jqlang.jq.

bat

  • Install bat: winget install sharkdp.bat.

  • Create folder if it does not exist: $env:AppData\Local\bat\cache

  • Add following environment variables: BAT_PAGER = less -RF.

  • A default configuration file can be created with the --generate-config-file option.

    bat --generate-config-file

Gum provides highly configurable, ready-to-use utilities to help you write useful shell scripts and dotfiles aliases with just a few lines of code.

winget install charmbracelet.gum

duf

duf is a Disk Usage/Free Utility.

winget install muesli.duf

procs

A modern replacement for ps written in Rust.

winget install dalance.procs

duckdb

winget install DuckDB.cli

Upgrading

Before installing new version of CLI, you may need to export any databases from old CLI and re-import in new CLI 😦

For example, let's say you have a database D:/duck_db/nyc-taxi.duckdb.

  1. In CLI for old version, execute: .open D:/duck_db/nyc-taxi.duckdb

  2. In CLI for old version: EXPORT DATABASE 'D:/duckdb_export/nyc-taxi';

  3. Delete old file D:/duck_db/nyc-taxi.duckdb.

  4. In R using latest version of duckdb package:

    con <- dbConnect(duckdb::duckdb(), dbdir = "D:/duckdb/nyc-taxi.duckdb", read_only = FALSE)
    dbExecute(con, "IMPORT DATABASE 'D:/duckdb_export/nyc-taxi'")

wget2

winget install GNU.wget2

difftastic

Difftastic is a structural diff tool that compares files based on their syntax.

winget install Wilfred.difftastic -l D:\Apps\CLI

ast-grep

ast-grep is a CLI tool for code structural search, lint, and rewriting.

ATAC

ATAC is a CLI app like Postman. Download latest release from https://github.com/Julien-cpsn/ATAC/releases.

Set $ATAC_MAIN_DIR to %HOME%/.atac.

Hurl

Hurl is a command line tool that runs HTTP requests defined in a simple plain text format.

Grab latest binary from GitHub and copy to install folder.

Dot files

  • Install chezmoi:

    winget install twpayne.chezmoi
  • Run chezmoi init to create an initial chezmoi.toml using template in repo:

    chezmoi init AjayKMehta

Tip

You can supply --apply in the above command to generate dot files at same time.

VS Code

  • Install:

    winget install --id Microsoft.VisualStudioCode -l 'D:\Apps\VSCode'
  • Add installation folder (e.g. D:\Apps\VSCode\bin) to $Path.

  • Use settings sync to get settings.

Tip

If you run into the error Another instance of Code is running as administrator, you can resolve this by setting VS Code to always run as admin.

Node

Hugo

Hugo is an open-source static site generator.

  • Install:

    winget install Hugo.Hugo -l D:\apps\Hugo
  • Add installation folder to $Path.

WSL

See wsl.md.

winget install Docker.DockerDesktop

Where are Docker images located?

When using WSL2 with Docker Desktop, a new distro called docker-desktop-data is created, which is also where all your image layers are stored.

  1. Go to the Releases page and download the binary (docker-credential-wincred) that works for you. Put that binary in your $PATH, so Docker can find it. This is already installed with Docker Desktop and should be in your $PATH.

  2. Set the credsStore option in your ~/.docker/config.json file with the suffix of the program you want to use (wincred).

    {
        "credsStore": "wincred"
    }

Change images and containers directory

Create a function based on instructions here:

function Move-WslDistro {
    [CmdletBinding()]
    param (
        [Parameter(Mandatory = $true)]
        [ValidateScript(
            { $_ -in $(wsl --list -q | Where-Object { $_.Trim() -ne '' }) },
            ErrorMessage = 'Please specify the name of a WSL distro.'
        )]
        [string] $Distro,
        [string] $ExportPath
    )
    $tarFile = "D:/temp/$Distro.tar"
    wsl --export $Distro $tarFile
    wsl --unregister $Distro
    wsl --import $Distro $ExportPath $tarFile --version 2
}

Now, shut down WSL and call this function to move distros for docker-desktop and docker-desktop-data:

wsl --shutdown
Move-WslDistro -Distro docker-desktop-data -ExportPath D:/wsl/Docker/data
Move-WslDistro -Distro docker-desktop -ExportPath D:/wsl/Docker/distro

When you are satisfied that this is working, you can delete tar files.

Getting a Shell in Docker for Windows Moby VM

docker run -it --rm --privileged --pid=host justincormack/nsenter1

Source

Optimize-VHD -Path D:\wsl\Docker\data\ext4.vhdx -Mode Full

For more tips, see https://learn.microsoft.com/en-us/windows/wsl/disk-space.

docker scout

Docker Scout is a set of software supply chain features integrated into Docker's user interfaces and command line interface (CLI).

It comes bundled with Docker Desktop but if you wish to use a different version, please follow these instructions.

Utilities

winget install wagoodman.dive
winget install JesseDuffield.Lazydocker

WezTerm is a powerful cross-platform terminal emulator and multiplexer.

  • Install:

    winget install wez.wezterm -l D:\Apps\WezTerm
  • (Optional) Add installation folder to $Path.

Links

Hadoop

See here for more details. As of the time this was written, the version of interest for Hadoop was 3.3.6.

  1. Install Hadoop and create $HADOOP_HOME:

    pushd ~/Downloads
    $version = '3.3.6'
    Invoke-WebRequest "https://dlcdn.apache.org/hadoop/common/hadoop-$version/hadoop-$version.tar.gz" -OutFile "hadoop-$version.tar.gz" -Verbose
    # https://stackoverflow.com/a/2903532
    7z e "hadoop-$version.tar.gz" && 7z x "hadoop-$version.tar" -o"D:/Apps"
    Remove-Item "hadoop-$version.tar*"
    
    # Download Hadoop native IO binary
    gh download "https://github.com/cdarlint/winutils/tree/master/hadoop-$version/bin" 
    
    # Copy files to bin folder. Add -L to do dry-run
    robocopy ".\hadoop-$version\bin" "D:\Apps\hadoop-$version\bin"
    Remove-Item ".\hadoop-$version\bin" -Recurse 
    popd
    
    [System.Environment]::SetEnvironmentVariable('HADOOP_HOME', "D:\Apps\hadoop-$version", 'User')
  2. Add %HADOOP_HOME%\bin to $Path.

AI

NVIDIA CUDA Toolkit

Download and install from https://developer.nvidia.com/cuda-downloads. It is over 3 GB so if you don't have enough disk space on C:, install on a different drive.

You should see an environment variable $CUDA_PATH created whose value is the install path.

CUDNN

Download installer from https://developer.nvidia.com/cudnn-downloads.

AIShell

AI Shell is an interactive shell that provides a chat interface with language models.

  1. Install: winget install Microsoft.AIShell.

  2. Install PowerShell module: Install-PSResource -Name AIShell -scope CurrentUser -Prerelease.

  3. To use this with OpenAI, you need to update the configuration file.

Keybindings for commands: https://learn.microsoft.com/en-us/powershell/utility-modules/aishell/get-started/aishell-powershell?view=ps-modules#key-bindings-for-commands.

Ollama

Install: winget install Ollama.Ollama -l D:\Apps\Ollama --interactive.

If you want to change the download directory for models, then set $OLLAMA_MODELS (source).

aichat

Download latest release from here. To override settings used by the app through environment variables, refer here.

You can put all your secret environment variables in $APPDATA\aichat\.env (location can be overriden by $AICHAT_ENV_FILE).

Grab shell completion:

gh download https://github.com/sigoden/aichat/blob/main/scripts/completions/aichat.ps1

aider-chat

Install:

uv tool install aider-chat
  • Use --vim for vim keybindings.
  • To work with Ollama, set $OLLAMA_API_BASE to http://127.0.0.1:11434.

Tip

To send long, multi-line messages in the chat:

  • Use Esc + Enter to enter a new line without sending the message.
  • Use /editor to edit message in your editor.

HuggingFace Model Downloader

The HuggingFace Model Downloader is a utility tool for downloading models and datasets from the HuggingFace website. Grab latest release from repo.

RAG Crawler

Crawl a website to generate knowledge file for RAG.

Install: npm i -g rag-crawler

Python

  • To use UTF-8 mode on Windows, set environment variable $PYTHONUTF8 to 1.
  • To prevent installing using base python, set $PIP_REQUIRE_VIRTUALENV to true1.

Build Tools

In order to build certain sdist packages, you need to install latest version of VS Build Tools (source).

uv

  • Before installing, set environment variables if you don't want to use default locations:

    [Environment]::SetEnvironmentVariable('UV_INSTALL_DIR', 'D:\Apps\uv', 'User')
    [Environment]::SetEnvironmentVariable('UV_CACHE_DIR', 'D:\.cache\uv', 'User')
    [Environment]::SetEnvironmentVariable('UV_TOOL_BIN_DIR', 'D:\Apps\uv\tools', 'User')
  • Also, set $UV_LINK_MODE to copy to avoid annoying warnings:

    warning: Failed to hardlink files; falling back to full copy. This may lead to degraded performance.
         If the cache and target directories are on different filesystems, hardlinking may not be supported.
         If this is intentional, set `export UV_LINK_MODE=copy` or use `--link-mode=copy` to suppress this warning.
  • (Optional) Set $UV_FROZEN to 1 or true to avoid uv run updating lock file. ⚠️ Doing so, causes uv lock -U --dry-run to fail.

  • Install uv and set up shell completion:

    irm https://astral.sh/uv/install.ps1 | iex
    
    uv generate-shell-completion powershell | Out-File ~\Documents\PowerShell\Scripts\ArgumentCompleters\uv.ps1
    uvx --generate-shell-completion powershell | Out-File ~\Documents\PowerShell\Scripts\ArgumentCompleters\uvx.ps1
    
    # Ensure that the tool executable directory is on the `PATH`
    uv tool update-shell
  • Use uv self update to update uv

uv Tools

  • Install tools:

    uv tool install cookiecutter
    uv tool install ipython
    uv tool install markitdown
    uv tool install pipdeptree
    uv tool install pre-commit
    uv tool install radian # For R
    uv tool install ruff
    uv tool install scalene
    uv tool install tox
    uv tool install visidata
    uv tool install virtualenv
    uv tool install yamllint
    
    # <https://pypi.org/project/tox-uv/>
    
    uv tool install tox --with tox-uv
    
    # <https://pypi.org/project/pre-commit-uv/>
    
    uv tool install pre-commit --with pre-commit-uv --force-reinstall
    
    uv tool 
  • Use uv tool upgrade --all to upgrade tools.

  • Use uv tool dir to list directory where tools are installed.

  • Use uv tool dir --bin to list directory where tools' executables are installed.

Run tool using uv tool run <tool> or uvx <tool>.

Working with projects

  1. Create a project in current directory (pass --lib if library else --app):

    uv init -p 3.12.7 --author-from none --name $project --no-workspace --build-backend setuptools --python-preference managed --app

    This will create a virtual environment, pyproject.toml and other files.

    Alternatively, you can use cookiecutter to create from a template.

  2. Add dependencies: Add dependency foo (adds to .venv and pyproject.toml):

    uv add foo

    Specify optional dependencies just as like you do for pip install:

    uv add 'httpx[zstd]' 

    You can add constraints for version, etc. with dependency specifiers, formerly know as PEP 508:

    uv add 'starlette<0.41.1' # Need quotes with '>' or '<'
    uv add numpy==2.0.2
    uv add foo~=1.0.1

    Add dev dependency mypy (adds to .venv and to tool.uv section in pyproject.toml):

    uv add mypy --dev

    Add optional dependency (adds to .venv and to project.optional-dependencies section in pyproject.toml):

    uv add httpx --optional network

    ☝️ This is mostly useful for libraries.

  3. Sync .venv with lockfile: uv sync. Pass --frozen to avoid updating the lockfile.

  4. Update package: uv lock --upgrade-package <pkg>. To upgrade a single package to a specific version: uv lock --upgrade-package <package>==<version>.

  5. To see what packages would change without updating lockfile: uv lock -U --dry-run.

  6. Update all packages: uv lock --upgrade.

  7. Export package info to requirements.txt: uv pip compile --annotation-style line pyproject.toml | Out-File requirements.txt. 💡 If you don't specify --annotation-style line, it uses split which may produce multiple lines per package showing its dependents.

  8. Verify installed packages have compatible dependencies: uv pip check.

  9. Use uv run to run commands in the project environment: uv run python -m spacy info.

    1. To run a script: uv run example.py.
    2. Specify .env file to use: --env-file .env.

⚠️ Be careful not to use uvx to run a command corresponding to a tool with same name, e.g. mypy or you will be running in the wrong virtual environment!

spacy

Please do the following to install models, e.g. for en_core_web_sm-3.8.0:

uv add "https://github.com/explosion/spacy-models/releases/download/en_core_web_sm-3.8.0/en_core_web_sm-3.8.0-py3-none-any.whl"

For more information, see here.

faiss

No GPU version on Windows. See instructions.

PyTorch

See here for instructions on installing PyTorch.

To get CUDA version installed on your machine, inspect the output of the following command:

nvidia-smi

To install CUDA-enabled version, see here.

JupyterLab

Install (in uv project):

uv add --group dev jupyterlab

Install following extensions:

  • plotlywidget
  • @jupyterlab/latex
  • @ryantam626/jupyterlab_code_formatter
uv add --group dev jupyterlab-latex
uv run jupyter labextension install plotlywidget jupyterlab_code_formatter

View extensions:

uv run jupyter labextension list

nbQA

nbQA lets you run mypy and other linters and formatters on Jupyter Notebooks.

uv add --group dev nbqa

Usage: uv run nbqa <tool> <args>, e.g. uv run nbqa mypy ./src/foo.

GenAI

Make sure that you configure environment variables for API keys.

Cohere

Replicate

Weights & Biases

To override the directory used to store prompt templates, etc., set $LLM_USER_PATH (source):

[System.Environment]::SetEnvironmentVariable('LLM_USER_PATH', 'D:\llm', 'User')

Add plugins:

uv run llm install gpt4 llm-claude-3

OpenAI

HuggingFace

Get access token from https://huggingface.co/settings/tokens.

Set following environment variables:

  1. Set $HF_HOME to configure where huggingface_hub will locally store data. In particular, your token and the cache will be stored in this folder.

  2. Set $HF_TOKEN to configure the User Access Token to authenticate. If set, this value will overwrite the token stored on the machine (in $HF_HOME/token).

  3. Set $HF_HUB_DOWNLOAD_TIMEOUT to define the number of seconds to wait for server response when downloading a file. If the request times out, a TimeoutError is raised.

Faster downloads

To enable faster downloads:

uv add hf_transfer
$env:HF_HUB_ENABLE_HF_TRANSFER = 1

Once installed, check that huggingface_hub works properly by running the following command:

uv run python -c "from huggingface_hub import model_info; print(model_info('gpt2'))"

This command will fetch information from the Hub about the gpt2 model. Output should look like this:

ModelInfo(id='openai-community/gpt2', author='openai-community', sha='607a30d783dfa663caf39e06633721c8d4cfcd7e', created_at=datetime.datetime(2022, 3, 2, 23, 29, 4, tzinfo=datetime.timezone.utc), last_modified=datetime.datetime(2024, 2, 19, 10, 57, 45, tzinfo=datetime.timezone.utc), private=False, disabled=False, downloads=12735669, downloads_all_time=None, gated=False, gguf=None, inference=None, likes=2327, library_name='transformers', tags=['transformers', 'pytorch', 'tf', 'jax', 'tflite', 'rust', 'onnx', 'safetensors', 'gpt2', 'text-generation', 'exbert', 'en', 'doi:10.57967/hf/0039', 'license:mit', 'autotrain_compatible', 'text-generation-inference', 'endpoints_compatible', 'region:us'], pipeline_tag='text-generation', mask_token=None, card_data={'base_model': None, 'datasets': None, 'eval_results': None, 'language': 'en', 'library_name': None, 'license': 'mit', 'license_name': None, 'license_link': None, 'metrics': None, 'model_name': None, 'pipeline_tag': None, 'tags': ['exbert']}, widget_data=[{'text': 'My name is Julien and I like to'}, {'text': 'My name is Thomas and my main'}, {'text': 'My name is Mariama, my favorite'}, {'text': 'My name is Clara and I am'}, {'text': 'My name is Lewis and I like to'}, {'text': 'My name is Merve and my favorite'}, {'text': 'My name is Teven and I am'}, {'text': 'Once upon a time,'}], model_index=None, config={'architectures': ['GPT2LMHeadModel'], 'model_type': 'gpt2', 'tokenizer_config': {}}, transformers_info=TransformersInfo(auto_model='AutoModelForCausalLM', custom_class=None, pipeline_tag='text-generation', processor='AutoTokenizer'), trending_score=None, siblings=[RepoSibling(rfilename='.gitattributes', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='64-8bits.tflite', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='64-fp16.tflite', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='64.tflite', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='README.md', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='config.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='flax_model.msgpack', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='generation_config.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='merges.txt', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='model.safetensors', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/config.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/decoder_model.onnx', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/decoder_model_merged.onnx', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/decoder_with_past_model.onnx', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/generation_config.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/merges.txt', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/special_tokens_map.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/tokenizer.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/tokenizer_config.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='onnx/vocab.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='pytorch_model.bin', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='rust_model.ot', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='tf_model.h5', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='tokenizer.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='tokenizer_config.json', size=None, blob_id=None, lfs=None), RepoSibling(rfilename='vocab.json', size=None, blob_id=None, lfs=None)], spaces=['open-llm-leaderboard/open_llm_leaderboard', 'microsoft/HuggingGPT', 'Gustavosta/MagicPrompt-Stable-Diffusion', 'shi-labs/Versatile-Diffusion', 'optimum/llm-perf-leaderboard', 'yizhangliu/Grounded-Segment-Anything', 'microsoft/Promptist', 'h2oai/h2ogpt-chatbot', 'aliabid94/AutoGPT', 'Manmay/tortoise-tts', 'Yntec/ToyWorld', 'jadechoghari/OpenMusic', 'h2oai/h2ogpt-chatbot2', 'wangrongsheng/ChatPaper', 'OFA-Sys/OFA-Image_Caption', 'Intel/low_bit_open_llm_leaderboard', 'eduagarcia/open_pt_llm_leaderboard', 'm-ric/beam_search_visualizer', 'exbert-project/exbert', 'OpenMotionLab/MotionGPT', 'ShiwenNi/ChatReviewer', 'Yntec/HuggingfaceDiffusion', 'doevent/Stable-Diffusion-prompt-generator', 'open-llm-leaderboard/blog', 'flax-community/image-captioning', 'BAAI/open_cn_llm_leaderboard', 'Yntec/PrintingPress', 'treadon/prompt-fungineer-355M', 'nateraw/lavila', 'yizhangliu/Text-to-Image', 'BadToBest/EchoMimic', 'fffiloni/EchoMimic', 'gsaivinay/open_llm_leaderboard', 'TMElyralab/MuseTalk', 'deepklarity/poster2plot', 'FrankZxShen/so-vits-svc-models-ba', 'maxmax20160403/sovits5.0', 'Nymbo/Compare-6', 'EleutherAI/magma', 'akhaliq/CLIP_prefix_captioning', 'OFA-Sys/OFA-Visual_Grounding', 'phenomenon1981/MagicPrompt-Stable-Diffusion', 'Yntec/ToyWorldXL', 'OFA-Sys/OFA-vqa', 'aubmindlab/Arabic-NLP', 'Gustavosta/MagicPrompt-Dalle', 'OFA-Sys/OFA-Generic_Interface', 'johko/capdec-image-captioning', 'ShiwenNi/ChatResponse', 'hkunlp/Binder', 'SeaLLMs/SeaLLM-Chat', 'bipin/image2story', 'Omnibus/Chatbot-Compare', 'LilyF/Generate_Text_and_Audio', 'Yntec/blitz_diffusion', 'society-ethics/model-card-regulatory-check', 'Nick088/Audio-SR', 'CISCai/gguf-editor', 'Catmeow/AI_story_writing', 'hahahafofo/image2text_prompt_generator', 'ethanchern/Anole', 'ICML2022/OFA', 'thirdai/BOLT2.5B', 'FrankZxShen/so-vits-svc-models-pcr', 'mshukor/UnIVAL', 'sohaibcs1/Image-to-Text-Summary', 'aliabid94/GPT-Golf', 'Hello-SimpleAI/chatgpt-detector-ling', 'llizhx/TinyGPT-V', 'lfoppiano/document-qa', 'fireredteam/FireRedTTS', 'TencentARC/ImageConductor', 'RitaParadaRamos/SmallCapDemo', 'liyucheng/selective_context', 'sasha/BiasDetection', 'phenixrhyder/NSFW-ToyWorld', 'gsarti/pecore', 'BoomerangGirl/MagicPrompt-Stable-Diffusion', 'architext/Architext_deployed', 'kmacdermid/RpgRoomGenerator', 'SeViLA/SeViLA', 'AnimaLab/bias-test-gpt-pairs', 'optimum/auto-benchmark', 'GTBench/GTBench', 'sonalkum/GAMA', 'John6666/Diffusion80XX4sg', 'stanfordnlp/Backpack-Demo', 'shangdatalab-ucsd/LDB', 'abdullahmeda/detect-ai-text', 'oceansweep/tldw', 'zeno-ml/chatbot-report', 'luis112/text-generation-webui', 'Kaludi/Stable-Diffusion-Prompt-Generator_App', 'freQuensy23/LLMhistory', 'Vikhrmodels/small-shlepa-lb', 'prometheus-eval/BiGGen-Bench-Leaderboard', 'dromerosm/gpt-info-extraction', 'hahahafofo/prompt_generator', 'ccolas/TastyPiano', 'sasha/WinoBiasCheck'], safetensors=SafeTensorsInfo(parameters={'F32': 137022720}, total=137022720))

LangSmith

To create an API key head to the setting pages. Then click Create API Key.

R

  1. Download and install R from CRAN website. Alternatively, winget install RProject.R.

  2. Add <InstallPath>\bin\x64 to $PATH.

  3. Default folder of .RProfile and .REnviron is ~\Documents which leads to issues if OneDrive moves this folder to ~\OneDrive\Documents 😦. So, best to set environment variables:

    [System.Environment]::SetEnvironmentVariable('R_ENVIRON_USER', '~\.Renviron', 'User')
    [System.Environment]::SetEnvironmentVariable('R_PROFILE_USER', '~\.Rprofile', 'User')
  4. To avoid the issue of C: running out of disk space, set $R_LIBS to a different path, e.g.D:\packages.

  5. Set $GITHUB_PAT to GitHub PAT obtained. This is necessary for avoiding rate-limit issues when installing packages from GitHub using the remotes package.

Updating packages for version upgrade

  1. Check output of .libPaths() and if there is a folder with old R version number, copy its contents to new folder with correct R version number.

  2. Update packages for new R version:

    update.packages(ask=FALSE, checkBuilt=TRUE)
  3. Delete package install location with old R version number if any.

(Source)

RStudio

winget install Posit.RStudio

RTools

💡 Install location is usually C:\RTools but if you have limited disk space, change folder during installation. Installer will set $RTOOLS<VER>_HOME automatically, e.g. if you set install path for RTools 4.4 to D:\rtools44, then this path will be value for $RTOOLS44_HOME.

  • Download and run R Build tools.
  • Add bin folder in install path to $PATH -- this can be done by editing .Renviron: PATH="${RTOOLS44_HOME}\usr\bin;${PATH}".

Usage notes

Perform a bunch of checks:

Sys.getenv('PATH')
system('g++ -v')
system('where make')

Or, install pkgbuild from CRAN and use it:

# install.packages("pkgbuild")
pkgbuild::check_build_tools(debug = TRUE)
pkgbuild::find_rtools(debug = TRUE)

Packages

  • To install packages from r-universe:

    install.packages("universe")
    # For dev version:
    # install.packages("universe", repos = "https://ropensci.r-universe.dev")
  • Use universe::add() to opt-in to a package repository (this will modify your options('repos') list).

    universe::add("ropensci")
  • Install packages in Packages.csv.

Spark

  1. In .RProfile, set options(spark.install.dir = "D:/Apps/Spark")

  2. Install sparklyr:

    install.packages("sparklyr")
  3. Check available versions:

    library(sparklyr)
    spark_versions()
  4. Install required version:

    spark_install("3.5.0", "3")
  5. Set $SPARK_HOME to bin folder, i.e. D:\Apps\Spark\spark-3.3.2-bin-hadoop3\bin.

Stan

cmdstanr

install.packages("cmdstanr")
cmdstanr::check_cmdstan_toolchain(fix = TRUE)
cmdstanr::install_cmdstan(dir = "D:/Apps", overwrite = TRUE, cores = 6)
cmdstanr::set_cmdstan_path() # D:/Apps/cmdstan-2.24.1

radian

From the project's README.md:

radian is an alternative console for the R program with multiline editing and rich syntax highlight.

Installation steps:

  1. Install radian: uv tool install radian.
  2. Set $R_BINARY to <InstallPath>\bin\x64\R.exe. This is needed for radian to work properly.

Setup for VS Code

  1. Install languageserver and httpgd in R: install.packages(c("languageserver", "httpgd")).
  2. Install the R extension for Visual Studio Code.
  3. Set up radian as R console in VS Code.
  4. Install VSCode-R-Debugger package: remotes::install_github(ref = "v0.5.2", "ManuelHentschel/vscDebugger").

See here for more details.

Setup for Jupyter

  1. Install R package IRKernel: install.packages("IRkernel").
  2. Activate venv environment for a uv project with Jupyter installed: . .\.venv\Scripts\Activate.ps1 if in root directory. 💡 VS Code automatically executes this if you open a PowerShell terminal AFAICT.
  3. Use jupyter kernelspec list to get location of existing kernels. If you see a path corresponding to $Appdata\jupyter\kernels\ir, then R kernel is already installed.
  4. Launch radian in environment's shell: radian or uv run radian (use project's version).
  5. In radian: IRkernel::installspec().

Alternatively, you can copy files from IRKernel package installation directory's kernelspec subfolder to $Appdata\jupyter\kernels\ir.

Now if you launch jupyterlab (uv run jupyter lab), you should see a R kernel and be able to select it for your notebook.

catboost

This is available from GitHub.

  1. Download latest release from https://github.com/catboost/catboost/releases.
  2. Install: install.packages(repo = NULL, type = "source", r"{C:\Users\Ajay\Downloads\catboost-R-windows-x86_64-1.2.2.tgz}").

INLA

See here.

Quarto

Quarto is a replacement for RMarkdown that also works with Python.

To install:

  1. Download installer from https://github.com/quarto-dev/quarto-cli/releases and run.

  2. Add installation path (D:\Apps\Quarto\bin) to $PATH if not already available.

  3. RStudio ships with its owb version of Quarto + Pandoc. To use Quarto and its bundled version of Pandoc, add the following to your .Renviron file:

    QUARTO_PATH="D:/Apps/quarto/bin/quarto.cmd"
    RSTUDIO_PANDOC="D:/Apps/quarto/bin/tools"

Extras

To support rendering of PDF documents that include SVG files, automatically converting them to PDF images in Quarto 1.3+, install rsvg-convert from https://github.com/miyako/console-rsvg-convert and add to$PATH.

(Optional) tinytex is a lightweight alternative to MikTeX:

quarto install tinytex

Use OpenBLAS

You can use OpenBLAS to speed up linear algebra operations but use at your own risk! Instructions below are modified from this SO post and https://medium.com/@FredHo42/using-intel-mkl-library-on-r-4-0-641dc0c3c06b.

  1. Download latest version of OpenBLAS from https://github.com/OpenMathLib/OpenBLAS/releases.
  2. Copy Rlapack.dll and Rblas.dll from ./bin/x64 in R installation folder to safe location.
  3. Now create 2 copies of libopenblas.dll named Rlapack.dll and Rblas.dll and copy them to folder from step 1.
  4. If you run into problems, you can revert back to the original DLLs.

Check performance:

Before

> system.time(svd(matrix(runif(10000*2000), 10000, 2000), nu=0, nv=0))
   user  system elapsed 
  43.50    0.09   44.06 

After

> system.time(svd(matrix(runif(10000*2000), 10000, 2000), nu=0, nv=0))
   user  system elapsed
  20.72    1.20    5.30

DotNet

  • Install Visual Studio Community 2022:

    winget install Microsoft.VisualStudio.2022.Community

    This will also install .NET 8 SDK.

  • Install templates for dotnet new:

    dotnet new install "Boxed.Templates"
    dotnet new install "Amazon.Lambda.Templates"
    dotnet new install "NUnit3.DotNetNew.Template"
  • Set environment variables related to runtime configuration for compilation:

    [System.Environment]::SetEnvironmentVariable('DOTNET_TieredPGO', 1, 'User')

    💡 Enabled by default in .NET 8 so no longer needed after upgrading to .NET 8.

  • Disable telemetry:

    [System.Environment]::SetEnvironmentVariable('DOTNET_CLI_TELEMETRY_OPTOUT', 1, 'User')
    [System.Environment]::SetEnvironmentVariable('DOTNET_UPGRADEASSISTANT_TELEMETRY_OPTOUT', 1, 'User')

NuGet

  • Change directory for NuGet packages

    [System.Environment]::SetEnvironmentVariable('NUGET_PACKAGES', 'D:\NuGet\packages', 'Machine')
  • Install NuGet: winget install Microsoft.NuGet.

  • Add installation path to $Path.

Useful apps

  • Install LinqPad 8:

    winget install --id LINQPad.LINQPad.8 -l 'D:\Apps\LINQPad8\'
  • Install Nuget Package Explorer:

    winget install --id 9WZDNCRDMDM3
  • Install MSBuild Structured Log Viewer:

    winget install --id KirillOsenkov.MSBuildStructuredLogViewer
  • Install NSwagStudio:

    winget install --id RicoSuter.NSwagStudio
  • Install PerfView:

    winget install Microsoft.PerfView -l D:\Apps\PerfView
  • Install ILSpy:

    winget install icsharpcode.ILSpy

Dotnet Tools

Install following tools:

dotnet tool install -g benchmarkdotnet.tool
dotnet tool install -g coverlet.console
dotnet tool install -g diffenginetray
dotnet tool install -g dotnet-counters
dotnet tool install -g dotnet-depends
dotnet tool install -g dotnet-monitor
dotnet tool install -g dotnet-outdated-tool
dotnet tool install -g dotnet-reportgenerator-globaltool
dotnet tool install -g dotnet-sos
dotnet tool install -g dotnet-stack
dotnet tool install -g dotnet-stryker
dotnet tool install -g dotnet-trace
dotnet tool install -g microsoft.dotnet-httprepl
dotnet tool install -g microsoft.dotnet-interactive
dotnet tool install -g minver-cli
dotnet tool install -g roslynator.dotnet.cli
dotnet tool install -g snitch
dotnet tool install -g upgrade-assistant

# https://learn.microsoft.com/en-us/dotnet/core/porting/upgrade-assistant-telemetry?tabs=powershell#how-to-opt-out
[System.Environment]::SetEnvironmentVariable('DOTNET_UPGRADEASSISTANT_TELEMETRY_OPTOUT', '1', 'User')

LaTeX

  • Download MiKTeX command-line installer from https://miktex.org/download.

  • Extract miktexsetup_standalone.exe and set current directory to its folder location.

  • Run the following command to download MiKTeX into a local package repository:

    . .\miktexsetup_standalone.exe --verbose --local-package-repository=D:\miktex-repository --package-set=basic download
  • Next, run:

    $installFolder = 'D:\Apps\Miktex'
    
    $dataFolder = 'D:\ProgramData\Miktex'
    
    . .\miktexsetup_standalone.exe --common-config=$dataFolder --common-data=$dataFolder --common-install=$installFolder --local-package-repository=D:\miktex-repository --modify-path --package-set=basic --shared=yes --user-config="$env:APPDATA\MiKTeX" --user-data="$env:LOCALAPPDATA\MiKTeX" --print-info-only  install
  • Output should look like this:

    setup task: install from local package repository
    local package repository: D:\miktex-repository
    package set: basic
    install for all users?: yes
    portable? : no
    use registry?: yes
    modify path?: yes
    program folder name: MiKTeX
    common install root: D:\Apps\Miktex
    common config root: "D:\ProgramData\Miktex"
    common data root: "D:\ProgramData\Miktex"
    user config root: C:\Users\Ajay\AppData\Roaming\MiKTeX
    user data root: C:\Users\Ajay\AppData\Local\MiKTeX
  • If the output looks OK, remove --print-info-only from above CLI command and run to install MikTex.

  • Add $installFolder\bin\x64\ to $Path.

Troubleshooting

If you encounter an error about a missing Qt plugin, uninstall and reinstall miktex-qt6-bin-x64:

miktex --admin packages remove miktex-qt6-bin-x64
miktex --admin packages install miktex-qt6-bin-x64

latexindent

latexindent is used to format LaTeX in the VS Code extension LaTeX-Workshop.

Warning

The script that ships with MikTex requires a Perl installation but even after trying to install Perl (in standard and custom location), it still did not work.

Download latest version from here and make sure install folder is in $Path.

tectonic

Tectonic is a modern TeX/LaTeX engine written in Rust 🦀

Grab latest binary from GitHhub repo and make sure installation folder is in $Path.

chktex

chktex can be installed from CTAN to lint LaTeX files.

Note

It seems that the configuration file chktexrc is installed in <MikTex Install Folder>/chktex.

Miktex Packages

See miktex_packages.txt for list of packages to install.

Use VS Code for LaTeX

Haskell

GHCup is the main installer for Haskell. Setting up Haskell on Windows is still painful but less so than before GHCup came around.

Regular installation steps

  • If you wish to specify the installation root directory for ghcup, you can set $GHCUP_INSTALL_BASE_PREFIX2 (user-level environment variable). If not set, you can pass install directory choice to the install script or the script will prompt you if it doesn't find a drive with > 5 GB free space to install on.
  • Download install script:

    cd ~\Downloads\ && Invoke-WebRequest https://www.haskell.org/ghcup/sh/bootstrap-haskell.ps1 -OutFile bootstrap-haskell.ps1

Warning

Although the website says to run it directly, I think it's a good idea to review the script first and possibly customize invocation as the script has several parameters and the default values may not work for you.

  • Run script in non-admin powershell:

    # Hash from https://github.com/msys2/msys2-installer/releases/download/2023-07-18/msys2-base-x86_64-20230718.sfx.exe.sha256
    . .\bootstrap-haskell.ps1 -InstallStack -InStallHLS -InstallDir D:\Apps -Msys2Version '20230718' -Msys2Hash 'ab9b9a25e92d0c71136c79eeac954f1ce023341224de8d81401439f38c8b9232'

Caution

This did not work when specifying msys details. I got an error about file hash not being equal though that was not the case 😦

Alternative installation steps

This section is based on the following links:

Environment variables

  1. Assuming you plan to install msys to D:\msys64 and ghcup.exe to D:\Apps\ghcup\bin, set the following environment variables first:

    Env Variable Value Notes
    GHCUP_INSTALL_BASE_PREFIX D:\Apps Defaults to $HOME
    CABAL_DIR D:\Apps\cabal If set, all cabal-install content files will be stored as subdirectories of this directory, including the configuration file if CABAL_CONFIG is unset. See here.
    CABAL_CONFIG $USERPROFILE\.config\cabal\config Path for global configuration file.
    GHCUP_MSYS2 D:\msys64 Has to point to the root of an existing MSYS2 installation
    STACK_ROOT D:\sr This is where stack stores important files. See here.
    GITHUB_TOKEN GitHub PAT. See GitHub Token for details. Used by stack to authenticate when using GitHub REST API. See here.

Important

You also need to add D:\Apps\ghcup\bin to $Path.
You also need to make sure $HOME is set if you want to save .ghci there.

ghcup

msys2

  • Download latest version from https://github.com/msys2/msys2-installer/releases/.

  • Install the self extracting archive to D:\msys64:

    .\msys2-base-x86_64-20230718.sfx.exe -y -oD:\
  • Launch D:\Mmsyss64\msys2.exe as this does some initialization steps. If you don't, you may get this error when you try to run the next step: warning: Public keyring not found; have you run 'pacman-key --init'?.

  • Update msys2:

    ghcup run -m -- pacman --noconfirm -Syuu
    ghcup run -m -- pacman --noconfirm -S --needed curl autoconf mingw-w64-x86_64-pkgconf
    ghcup run -m -- pacman --noconfirm -S ca-certificates

    Also, refer to this.

  • Set up msys2 shell:

    • Run ghcup run -m -- sed -i -e 's/db_home:.*$/db_home: windows/' /etc/nsswitch.conf to make the `$HOME`` in your msys2 shell match the one from windows.
    • Make a desktop shortcut from D:\msys64\msys2_shell.cmd, which will allow you to start a proper msys2 shell: New-Item -ItemType SymbolicLink -Path ~\Desktop\Msys2 -Value D:\msys64\msys2_shell.cmd (requires elevated shell).
    • Run ghcup run -m -- sed -i -e "s/#MSYS2_PATH_TYPE=.*/MSYS2_PATH_TYPE=inherit/" /d/msys64/msys2.ini
    • Run ghcup run -m -- sed -i -e "s/rem set MSYS2_PATH_TYPE=inherit/set MSYS2_PATH_TYPE=inherit/" /d/msys64/msys2_shell.cmd

ghc

  • Install ghc:

    ghcup install ghc --set recommended
  • Edit config files as needed. The ghci.conf file in $AppData\ghc can be used for turning on favorite options (e.g. :set +s), and defining useful macros. $HOME/.ghci can be used as a startup script. See here for good ideas.

cabal

  • Install: ghcup install cabal

  • Edit config file:

    extra-include-dirs: D:\msys64\mingw64\include
    extra-lib-dirs: D:\msys64\mingw64\lib
    -- Would also need install folder if cabal installed in stand-alone folder: D:\cabal\bin
    extra-prog-path: D:\ghcup\bin;D:\msys64\mingw64\bin;D:\msys64\usr\bin
    

stack

  • Edit Stack's global configuration file which should be located at ${STACK_ROOT}\config.yaml, e.g. D:/sr/config.yaml4:

    # The target directory for stack build --copy-bins and stack install.
    local-bin-path: D:/stack
    # Stack 'programs' directory, where tools like GHC get installed.
    local-programs-path: D:/stack
    skip-msys: true
    # https://www.haskell.org/ghcup/install/#vscode-integration
    system-ghc: true
    install-ghc: false
    extra-path:
      - 'D:\msys64\usr\bin'
      - 'D:\msys64\mingw64\bin'
    extra-include-dirs:
      - 'D:\msys64\mingw64\include'
    extra-lib-dirs:
      - 'D:\msys64\mingw64\lib'
  • If you wish to add your config file to your dot files repo, do the following:

    # Create symlink to actual config file
    New-Item -Path ~\.stack\config.yaml -Value D:\sr\config.yaml -ItemType SymbolicLink -Force
    
    chezmoi add --follow --template ~/.stack/config.yaml

Warning

chezmoi re-add will not pick up updates to the original config.yaml. You will need to add it again via chezmoi add ... if there are any updates 😦

  • Run ghcup install stack latest.

  • Make sure that the value of local-bin-path (if not set, value is ~\AppData\Roaming\local\bin) is in $PATH as that is where stack install installs generated binaries (source).

  • In $STACK_ROOT\global-project\stack.yaml, specify resolver corresponding to the version of GHC you installed. This info can be obtained from https://www.stackage.org e.g. for GHC 9.4.8, this should be:

    resolver: lts-21.22
  • On Windows, GDB can be installed to debug an executable with ghcup run -m -- pacman -S gdb.

Checks:

  1. Output of stack path --stack-root should match $STACK_ROOT.

  2. Output of stack path --local-bin should be in $PATH

  3. Sanity checks:

    where.exe stack
    stack path
    stack exec -- which ghc
    stack exec sh

💡 Do not use stack runghc with a local package. Use stack exec instead.5

Haskell Language Server

Linting

Install hlint or grab binary from repo:

stack install hlint

Configuring VS Code

Syntax highlighting

Haskell Syntax Highlighting (justusadam.language-haskell adds syntax highlighting for Haskell and Cabal files.

Language Server

Haskell for VS Code (haskell.haskell) is powered by the Haskell Language Server.

Setup:

  1. Make sure your setting.json has this setting: "haskell.manageHLS": "GHCup"

  2. Install one of the formatters below:

    # Rerun if GHC version changes!
    stack install ormolu
    stack install brittany

Debugging

Haskell GHCi Debug Adapter Phoityne (phoityne.phoityne-vscode) provides debugging support. See website for how to configure launch.json to debug Haskell code.

Prerequisites:

Install haskell-dap, ghci-dap, haskell-debug-adapter:

$ stack update
$
$ stack install haskell-dap ghci-dap haskell-debug-adapter
-```


**Usage:**

:bulb: If you use `Debug: Add Configuration...` command in VS Code and select `haskell-debug-adapter`, it will create a `launch.json` for you with 2 configurations - one using `stack` and the other using `cabal`. The former can be changed to run `app/Main.hs` instead of `test/Spec.hs` (also, need to remove `--test` from `ghciCmd`). The latter does not work.

```powershell
stack update
# Rerun if GHC version changes!
stack install haskell-dap ghci-dap haskell-debug-adapter 

Theme

Lambda Black is optimized for Haskell.

Troubleshooting

If you encounter an error like "cannot satisfy -package-id...", you need to clean, build and restart LSP. You can add this to .vscode/task.json:

{
    "group": "build",
    "type": "shell",
    "label": "haskell clean & build",
    "command": "stack clean && stack build"
},
{
    "label": "rebuild and reload LSP",
    "command": "${command:haskell.commands.restartServer}",
    "dependsOn": [
        "haskell clean & build"
    ]
}

Additionally, you may need to create a hie.yaml file in the project's root directory looking like this:

cradle:
  stack:

Links:

pngquant

pngquant is a command-line utility and a library for lossy compression of PNG images.

Download latest version.

Miscellaneous

  • Install following apps:

    winget install --id VideoLAN.VLC
    winget install --id ImageMagick.ImageMagick
    winget install --id Mp3tag.Mp3tag
    winget install --id Citrix.Workspace
    winget install --id Postman.Postman
    winget install --id 7zip.7zip
    
    winget install --id Graphviz.Graphviz -l 'D:\Apps\Graphviz'
    winget install --id Kitware.CMake -l 'D:\Apps\CMake'
    
    winget install --id WinSCP.WinSCP -l 'D:\Apps\WinSCP\'
    winget install Microsoft.Sysinternals.ProcessExplorer
    
    winget install eza-community.eza - l D:\Apps\CLI
  • Add installation folders to $Path:

    $path = [System.Environment]::GetEnvironmentVariable('Path', 'Machine')
    $path += ';C:\Program Files\7-Zip;D:\Apps\Graphviz;D:\Apps\CMake;D:\Apps\WinSCP'
    [System.Environment]::SetEnvironmentVariable('Path', $path, 'Machine')

Footnotes

  1. See https://daniel.feldroy.com/posts/til-2023-12-forcing-pip-to-use-virtualenv for details.

  2. Whichever value you use will be set by the script as $GHCUP_INSTALL_BASE_PREFIX.

  3. The online documentation says location is ~/.ghcup/config.yaml which is not the case.

  4. If you execute a stack command before your config file is set up correctly, it will attempt to download GHC, msys2 which is not what we want 😲

    For more details, see here and here.

  5. https://www.reddit.com/r/haskell/comments/a6st8j/comment/ebyyb8n/.

About

Notes and scripts to setup new Windows machine

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published