Skip to content

New Workspace Setup

balacij edited this page Sep 11, 2021 · 65 revisions

System Prerequisites

Collaboratively working on any software, you generally need a few things; a compiler, terminal + generally available system tools, version control system, and an IDE. In addition to this, we often construct TeX documents alongside our software, requiring you also have a working LaTeX installation. This guide will give you a simple workspace recommendation for installing Stack (a Haskell development toolkit), VSCode (an IDE), and a basic LaTeX toolkit. Windows users will need to also install Git Bash if they don't already have it so that they can have a good BASH shell + Git client.

In order, you should be installing:

  1. Git (all) + Shell environment (Windows only)
  2. Stack
  3. VSCode + Extensions
  4. LaTeX
  5. Inkscape
  6. Graphviz

Optionally, some functions will be limited without:

  1. Doxygen

Note: If you use the nix package manager and/or the NixOS operating system, you may alternatively use the shell.nix ad-hoc development environment provided, however, you should still install VSCode + Extensions and install the lmodern and lmmath fonts.

Git / Git Bash

Git is a version control system for collaboratively building software with others. Using git, you may distribute and contribute software source code, with a full version history of the source project. We use git for collaborating development efforts on Drasil. In addition to the bountiful publicly available documentation on using git, we also have our own primer Git2Know document.

If you're using a Mac or Linux based computer, you will already have a terminal. Mac users may press Apple Logo+SPACE and search for "Terminal" to use it. Linux users may use their terminal and shell of their choice, but should use something that is compatible with BASH.

Installation

Please follow the instructions related to your operating system.

Windows

If you're on Windows, you will need some sort of bash shell and a git client. Git Bash is a custom terminal for Windows users packaged with git and other various generally used *nix system tools. The installation is process is fairly simple; you will need to download their Git Bash installer and run it. The installer will give you a series of steps, please go through them, leaving all options shown default, unless you specifically know what each option does. Once it's been installed, you can open it by pressing the four-flagged Windows key and searching for "Git Bash", clicking on the "Git Bash" application showing up (this will open up a black terminal window which you can use). The rest of the steps in this guide will assume that you are using Git Bash as your preferred Windows terminal.

Unicode Support (Important)

Unfortunately, it seems that Git Bash and Windows still has issues with UTF-8 encoding, resulting in odd errors in development and empty characters appearing in the Git Bash window. To resolve this issue, each time you open up Git Bash, you will need to run chcp.com 65001 or chcp 65001 so as to change the encoding of the terminal to UTF-8.

Mac

Mac already comes with a shell + good terminal, so you will only need to install git.

If you're using a recent version of Mac (> Mavericks/10.9), please open up a terminal window (Apple Logo+SPACE, then search "Terminal"), and type in git --version into it, and press enter. A GUI installer will appear prompting you to install Git. Please follow the on-screen steps, leaving all options default. Once the installation is complete, you should be able to type git --version into your Terminal window again and receive a version code back instead of having the GUI pop up again. If you're using an older version of Mac, you may follow through the steps of installing Git using any of the official repositories.

Linux

It's very likely that your operating system came with an installation of git, however, if it didn't, you will be able to use your package manager to install it.

Apt-based distributions:

sudo apt install git

pacman-based distributions:

sudo pacman -S git

dnf-based distributions:

sudo dnf install git-all

Portage-based distributions:

emerge --ask dev-vcs/git

Nix:

Add git to your system packages list.

Configuring git

Out of the box, git is almost ready to use for our purposes. We require that you set your identity and create an SSH key to clone our repo from GitHub.

Setting your identity

You will need to set your name and email in your Git configuration so that when you contribute your work, others will know who to credit the work to.

Please run the following commands in your terminal, replacing the fields with your information.

git config --global user.name 'Your Name'
git config --global user.email '[email protected]'

If you would like to remain anonymous, you are free to set your name to anything you would like (but please keep it appropriate), and you can use your GitHub's private personal email as your email.

Please note that the email that you use must match one of the emails registered on your GitHub account. Otherwise, your work will not be counted in the Drasil statistics and contributions page.

SSH keys

As per Wikipedia, SSH uses public-key cryptography to authenticate your identity from other machines, frequently used for client-server connection authentication.

You can read more on GitHub's About SSH webpage if you're interested.

Creating an SSH key

Please follow GitHub's official documentation on generating a new SSH key.

Registering your SSH key with GitHub

Please follow GitHub's official documentation on adding an SSH key to your account and testing your connection.

Cloning Drasil locally

To copy/clone Drasil's software on your machine, please open up your terminal window, navigate to a directory you want Drasil placed in, and run git clone [email protected]:JacquesCarette/Drasil.git. Afterwards, a Drasil folder will appear in your working directory and you can work on it as you see fit.

BONUS: Signing your commits

If you use GPG, you can also protect your commits by signing them with GPG.

Stack

Stack is an easy to use toolkit for building, executing, testing, and benchmarking your Haskell software, including tooling for isolated GHC installations and dependency management (similar to Python's virtualenv using a curated listed of packages).

Stack has an amazing document repository available on their Read the Docs Official Website. It has an Installation Guide, Quickstart Guide, User Guide, and much more!

Installation

Please follow the related instructions to your operating system.

Windows

Run the Stack installer executable file and follow the on-screen steps. While going through the installer, don't change any of the default settings. The default settings will ensure that "stack" is available in your PATH, and hence usable in your Git Bash.

Confirm Installation

To confirm you've successfully installed stack, press the four-flagged Windows key, search for Git Bash, and click the Git Bash application that shows up. A blue/black window should pop up. Finally, to confirm that "stack" has been successfully installed, type in stack --help into the terminal window. If some manual information appears, then you have successfully installed stack! Otherwise, you will need to go through these steps again.

Mac

For Mac users, open up your terminal (Apple logo + Space, then search "Terminal"), and run:

xcode-select --install

Note: It may take a while to run.

Finally, run:

curl -sSL https://get.haskellstack.org/ | sh

(from Official Stack Webpage) inside the terminal window. This will fully install Stack. It might ask you for permissions while installing, this is normal, please give it permission.

Using homebrew (Alternative)

If you prefer to use Homebrew to install software on your machine, please run:

brew install haskell-stack

However, the homebrew Stack package is unofficial and may not be up-to-date.

Confirm Installation

To confirm you've successfully installed stack, you should run stack --help in your terminal window. If some manual information appears, then you have successfully installed stack! Otherwise, you will need to go through these steps again.

Important Note for Mac Users

If you later find errors in your make logs similar to:

Warning: Installation path /Users/YOUR_USERNAME/.local/bin
         not found on the PATH environment variable.

You may need to add the path listed above to your $PATH environment.

Linux

For Linux users, please run:

curl -sSL https://get.haskellstack.org/ | sh

(from Official Stack Webpage) inside a terminal window. This will fully install Stack. It might ask you for permissions while installing, this is normal, please give it permission.

Confirm Installation

To confirm you've successfully installed stack, you should run stack --help in your terminal window. If some manual information appears, then you have successfully installed stack! Otherwise, you will need to go through these steps again.

Pinning your Stack Version

If you later experience issues with .cabal files being frequently rebuilt, you may pin your stack version against our LTS's preferred version. In your terminal window, please run stack upgrade --binary-version CURRENT_STACK_VERSION (e.g., 2.5.1) and it should stop frequently rebuilding the .cabal files.

VSCode

VSCode is a code editor with a large repository of plugins that you can use to extend it's functionality. VSCode has support for Haskell via the Haskell Language Server plugin (github). If you choose to use VSCode to work with Drasil, you may follow these steps, however, if you prefer to use an alternative IDE, you may want to look for a Haskell Language Server plugin for that IDE for similar support and tooling for Haskell.

Installation

Please download the binary related to your operating system from the Official VSCode Downloads webpage. Then please follow the related installation instructions for your operating system.

Windows

Please run the executable from the above download link and follow the on-screen steps. You will need to just accept their EULA. Please leave all of the options along the installation default.

Mac

Once you've downloaded the zip file from the above download link, please open up the zip file and drag-and-drop the internal Visual Studio Code.app file into your Applications folder.

Extensions

The following list of extensions are recommended and are helpful for working with Drasil specifically.

For each of the following plugins/extensions, the same general installation process is followed:

  1. Open up VSCode
  2. Press CTRL+SHIFT+X to open up the Extensions menu (if nothing opens on the left side of your screen, press View > Extensions at the top bar)
  3. In the menu created on the left-hand side of your screen, search for the plugin name
  4. Click on the target and press "Install". While installing, a little pop up might appear at the bottom right of your screen indicating the progress of the installation (and the installation of the dependencies).

Recommended Extensions:

  1. Haskell - Please see the Haskell support section.
  2. LaTeX Language Support
  3. Code Spell Checker

Helpful Extensions/Configurations (all optional):

  1. Insert Unicode - We often use unicode symbols in Drasil, so having a quick way to search unicode symbols by name is very helpful.
  2. Haskelly - Some useful GHCi commands for Haskell among other things.
  3. Graphviz support - Sometimes deal with graphviz commands and .dot files, so the CTRL+K V command from here helps to view those files quickly.
  4. Nix Environment Selector - Automatically use the Drasil shell.nix!
  5. If you're interested in using a font that mimics unicode characters for Haskell, consider using the FiraCode font (installation instructions)

Despite most of these above being "optional", if you have a powerful computer, it's best to install all of them.

Haskell Support

VSCode with the Haskell Language Server plugin creates a very smooth and powerful IDE for Haskell developers. However, the Haskell Language Server is still fairly new and under heavy development, so there will likely be issues that arise while using it. As Drasil is split into multiple packages (each drasil-* is a package), we end up with a multi-root software suite. Unfortunately, we are not able to use HLS efficiently under our multi-root software suite, resulting in an instance of HLS opening for each package. This also results in the lack of updates of cross package changes until we re-open HLS/VSCode. For example, if we update a component of drasil-lang, using an HLS tool in any of the packages that rely on drasil-lang will not "see" the changes you had already made to drasil-lang. This often makes refactoring large things across packages a bit difficult due to the HLS plugin showing you false errors. To resolve this issue, you may either restart your HLS plugin, or restart VSCode entirely.

Using the terminal/PowerShell/Git Bash in VSCode

With VSCode open, please press CTRL+SHIFT+` (or alternatively, press Terminal > New Terminal). It will open up a terminal window in the bottom of your screen.

Using an alternative Shell

If you prefer to use a different shell (e.g., Git Bash instead of PowerShell, or bash instead of zsh) as your default in VSCode, after opening a shell, you may select an alternative shell environment as your default using the dropdown on the right-hand side of the shell window that opens up.

General helpful VSCode shortcuts

Keybinding Description
CTRL+SHIFT+P Show the command palette
CTRL+K CTRL+T Show the lists of themes
CTRL+T Finding a class, function, or variable in all files
CTRL+SHIFT+<Any arrow> Selects text by words in the direction given
CTRL+F Open search bar
CTRL+L Select the current line in the cursor.
CTRL+R Reload window
CTRL+` Toggle the terminal window
CTRL+SHIFT+` Create a new terminal instance
CTRL+P Find a specific file in your current folder
CTRL+K CTRL+Z Comment a block of code
CTRL+K CTRL+U Uncomment a block of code
CTRL+, Go to user settings
CTRL+SHIFT+ENTER Replace All
ALT+ENTER Select all occurrences of Find match
CTRL+F2 Select all occurrences of a word

Note for MacOS users

Switch out CTRL for CMD if you’re using MacOS.

LaTeX

LaTeX is a language for typesetting documents, similar to Word and PowerPoint but with much more flexibility. While you might not often handle LaTeX manually while working with Drasil, it may still be a useful piece of software to learn. Feel free to check out some tutorials, or a different tutorial with an online editor, or even a table generator.

MiKTeX is an easy to use modern TeX distribution and package manager. It allows you to compile your TeX files with it's tools (e.g., pdflatex) and download packages and dependencies on-the-fly (from CTAN & it's package list). MiKTeX is only one of many possible solutions you may use.

Installation

Please follow the instructions according to your operating system and preferred method of installation.

Mac, with homebrew

For the GUI version of MacTeX, use: brew install --cask mactex. For the non-GUI version, use: brew install --cask mactex-no-gui. The GUI version is useful if you would for those that need the tex file editor TeXShop. The GUI version also installs LaTeXiT, TeX Live Utility, and BibDesk.

Linux, with your package manager

Apt-based distributions:

sudo apt install fonts-lmodern texlive-bibtex-extra texlive-latex-extra texlive-science texlive-xetex texlive-luatex

Nix:

Add texlive.combined.scheme-full to your nix packages.

Windows / Mac / Linux, with MiKTeX

If you're using a MacOS-based computer and prefer to use homebrew to install your software packages, please skip to Mac alternative section. Alternatively, if you're using Linux-based computer and prefer to use your native package manager, please skip to the Linux alternative section.

Check out the installation documents from MiKTeX. After installing MiKTeX, we recommend that you open up it's GUI, force update your packages, and manually install the lm-math package.

You may also want an IDE, in which case, you can choose from any of your choice VSCode (as installed above), GNU Kile, Gummi (installation), etc.

Common MiKTeX troubles

make tex takes forever!

Running make tex, for the first time in particular, will require you to manually accept many pop up installation windows. This is normal. However, please be aware that when MiKTeX installs packages, it may take a while if you're using a slow mirror. You can try to change your mirror if you'd like from the MiKTeX Console.

make tex says I'm missing packages!

Please see the discussion from issue 2347.

  1. Open your MikTeX console
  2. Manually check for updates
  3. Update all necessary packages
  4. Go to the "Packages" tab
  5. Search for "lm-" and an lm-math item should pop up
  6. Install lm-math
  7. Close all open git bash terminals you have, and re-open them
  8. cd Drasil/code
  9. make tex

Here's what lm-math should look like in your MiKTeX console:

image

Hopefully, it should work now, but if it doesn't, please file an issue.

Learning Resources

Inkscape

We use Inkscape in order to get svg diagrams to render in LaTeX. The program itself is actually an svg image creator, but Drasil uses it on the command line instead.

Installation Instructions

Please visit the Inkscape website for more detailed instructions. For convenience, we have a summary for Linux, Windows, and Mac below.

Linux

On Ubuntu or Debian, enter these two commands:

sudo apt-get update
sudo apt-get install inkscape

The first command will ensure that all of the packages are up do date, and the second will fetch and automatically install Inkscape for you.

Windows

Download the executable installer for Inkscape (64-bit or 32-bit), run the file, and follow the instructions on screen. Make sure you add Inkscape to your PATH when the installer asks. If the installer cannot automatically add Inkscape to you PATH or if you already have Inkscape without using the PATH, please follow these instructions.

Mac

Download the disk image for Inkscape, run the file, and follow the on-screen instructions.

Graphviz

In Drasil, Graphviz is used to render generated dot graphs. These are used in creating traceability graphs to parallel the traceability matrices of the generated SRS documents. In addition, they are used to create dependency graphs for Drasil's class, type, and module structure.

Installation Instructions

Please visit the Graphviz website for more detailed instructions. For convenience, we have a summary for some Linux distributions, Windows, and Mac below.

Linux

For Ubuntu and Debian, you can use the following command to install graphviz:

sudo apt install graphviz

Windows

Download, run, and follow the on-screen instructions of the official GraphViz Windows installer.

Alternatively, if you have chocolatey installed, you can open up a new command line as an administrator and run the following command:

choco install graphviz

Mac

If you use homebrew, you can install via the following command:

brew install graphviz

Or, you can use MacPorts:

sudo port install graphviz

Doxygen

Doxygen is used for generating documentation from code. Detailed download instructions can be found here.

Linux

You can install Doxygen on Linux by using the following command:

sudo apt-get install doxygen

Windows

The Doxygen download page has a Windows executable download. Open it and follow the on-screen instructions. You will also need to add the Doxygen bin to your path:

  1. In the search bar at the bottom left of the screen, type in Edit the system variables.
  2. Click Environment Variables
  3. In the top list (labelled User variables), navigate to the Path variable. Click on it and then select Edit.
  4. Click New and add the installation path for Doxygen. By default, this path should be C:\Program Files\doxygen\bin
  5. Select OK and restart any open terminals. Your Doxygen setup should now be complete.

Mac OS

The Doxygen download page has a disk image download for Mac OS. Open it and follow the on-screen instructions.

Working with Drasil

Congratulations! Now that you've successfully setup your workspace, you should move on to our Contributer's Guide.

Clone this wiki locally