MacOS setup
This setup has been tested on macOS Ventura 13.2.1 and Apple M2 Chip. The approach is primarily based on the instructions provided by @danielnachun and tested by @XuanLu.
Step 1
Backup your current Shell configuration file
cp ~/.zshrc ~/zshrc.backup
OPTIONAL:
For those already installed iTerm but NOT via Homebrew
You would want to install iTerm from Homebrew. Uninstall it before you proceed:
- Delete the iTerm2 Application
- Open Finder.
- Navigate to the Applications folder.
- Find iTerm2 and drag it to the Trash.
- Remove Associated Files
Open a terminal and run the following commands to remove iTerm2’s associated files and directories:
rm -rf ~/Library/Application\ Support/iTerm2
rm -rf ~/Library/Preferences/com.googlecode.iterm2.plist
rm -rf ~/Library/Caches/com.googlecode.iterm2
rm -rf ~/Library/Saved\ Application\ State/com.googlecode.iterm2.savedState
rm -rf ~/Library/Logs/iTerm2
Finally, you may want to empty your trash before you proceed.
For those who already installed Micromamba or Homebrew not through our system
- Uninstall Micromamba
rm -rf ~/micromamba
- Uninstall Homebrew
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/uninstall.sh)"
- Remove Associated Configuration Files
rm -rf ~/.bashrc ~/.bash_profile ~/.zshrc ~/.zprofile ~/.mambarc ~/.micromamba
- Remove Caches and Logs
rm -rf ~/Library/Caches/Homebrew
rm -rf /Library/Caches/Homebrew
rm -rf /usr/local/Homebrew
- Clean Up Remaining Directories
rm -rf /usr/local/var/homebrew
rm -rf /usr/local/etc/bash_completion.d/brew
rm -rf /usr/local/share/doc/homebrew
rm -rf /usr/local/share/man/man1/brew.1
rm -rf /usr/local/share/zsh/site-functions/_brew
Restart your Terminal, and you should be ready to go.
Step 2
Install Homebrew
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
You may be prompted to run these two lines:
(echo; echo 'eval "$(/opt/homebrew/bin/brew shellenv)"') >> /Users/ra/.zprofile
eval "$(/opt/homebrew/bin/brew shellenv)"
Run them as directed to add Homebrew to your PATH.
Step 3
Install iTerm2 using Homebrew
brew install --cask iterm2
Step 4 (Optional, but required if you are running Step 5)
Install special fonts to render unicode icons on the terminal:
brew install --cask font-meslo-lg-nerd-font
and download terminal color theme at: https://github.com/tinted-theming/base16-iterm2/blob/main/itermcolors/base16-one-light-256.itermcolors
*After download, go to your iTerm2 settings –> profiles –> colors –> color presets –> select import
–> import the downloaded .itermcolors
file. Be sure the file is named properly (i.e., Apple may automatically add .txt
to the file name, delete .txt
)
Also in profiles, select text –> font –> choose one of the Meslo Nerd Font you’ve downloaded.
Step 5 (Optional, use with caution)
Configure the system using a one-liner command,
sh -c "$(curl -fsLS get.chezmoi.io)" -- init --apply danielnachun
If prompted, select all-overwrite
.
This should install pixi
and the Script of Scripts (SoS) suite by one run. It will take a while.
Please note that it is recommended to use R managed by pixi
but you are also welcome to remove it via pixi global uninstall
, if you strongly prefers to work with your existing R program.
TESTING NOTE (XuanLu):
If you receive message such as wd:source: no such file or directory: /Users/ra/.local/share/zinit/snippets/OMZP ::wd/wd.sh
after you finish running the one-liner command and reinitiate Terminal, navigate to you home folder (open Finder, Command + Shift + H), unlock hidden files (Command + Shift + .), open the .zshrc
file, find zinit snippet OMZP::wd
, and comment it out.
Step 6
Finish configuring R in the pixi environment that you installed, for example:
pixi global install --environment r-base r-pacman
R --slave -e "remotes::install_github('jalvesaq/colorout')"
Some comments on MacOS initialization
- The Mac Magic Mouse may feel either too sensitive or sluggish by default. You should tweak it in
Settings
by configuring the tracking speed. Otherwise, you can use Mac Touchpad or a regular PC mouse.
Docker on Mac
We use Docker a lot running various software that are hard to install. SoS also provides an interface to run Docker images.
Install Docker and colima
In Step 5, Docker should have already been installed. If not, you can install it via
brew install docker
It is strongly recommended using colima
to run docker
. To install:
brew install colima
Then start Colima with defaults:
colima start
After colima
started (the above command completed executing), you can use docker
command on macOS after colima start
with no additional setup.
Run Docker containers
Here a demonstration to use Colima to create and run a Docker container from the gaow/bioinfo
` image on MacOS:
- Start Colima if it’s not already running:
colima start --cpu 6 --memory 8 --runtime docker
- Create a container from the image and start it:
docker run -it --name gaow_demo gaow/bioinfo /bin/bash
On MacOS with Apple Silicon (M) CPU chips,
docker run -it --platform linux/amd64 --name gaow_demo gaow/bioinfo /bin/bash
This will automatically download the image the first time you use it, then start a container from the image — which was called gaow_demo
in the command above — in interactive mode with a bash shell environment. You can now run commands inside the container.
- When done, type
exit
to exit the container shell. The container will stop but still exist. - To reenter the container that you quitted:
docker start -ai gaow_demo
- To close the container:
docker rm gaow_demo
Singularity on Mac
Singularity is an alternative to Docker as a container platform to run various software in a portable and reproducible way. SoS also provides and interface to run Singularity images.
To install Singularity please follow these steps on Apple Silicon Chip.
To run Singularity images, assuming you have previously installed colima
(see section above “Docker on Mac”), you can first create a virtual machine using:
limactl start template://apptainer-rootful --set='.cpus = 8 | .memory = "16GiB" | .disk = "20GiB"'
where you can adjust the .cpus
, .memory
and .disk
arguments based on specification of your computer.
Then you can run a singularity image — for example bioinfo.sif
— using:
limactl shell apptainer-rootful apptainer exec bioinfo.sif [command you would like to run]
Notice that the SoS workflow system will use singularity exec
to run Singularity images by default. To accommodate this, you can create an “alias” for singularity
by editing your ~/.zshrc
file adding the following line:
alias singularity="limactl shell apptainer-rootful apptainer"