I’m relatively new on macOS and one of the biggest problems switching from Windows was set up all those SDK and libraries required for web/mobile development.
I made several mistakes, but I think that finally found a good way to set up a macOS as a development machine.
It's not a definite solution because there are uncountable combinations and I can cover all of them. Just use what you need, don't install SDK or software that you will not gonna use.
Before start highly recommend change your terminal follow this configuration:
iTerm2 + Oh My Zsh! + Powerlevel10K best terminal combination for Geeks!
Camilo Martinez ・ Sep 25 '18
Software Repository
Homebrew
Brew has his own classification. The inside brew can found the CLI app and utilities. Inside is cask all the application with Graphical Interface.
/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
Add this lines to ~/.bash_profile
and/or ~/.zshrc
file:
#Brew
eval "$(/opt/homebrew/bin/brew shellenv)"
Run this commands on terminal:
eval "$(/opt/homebrew/bin/brew shellenv)"
source ~/.zshrc
source ~/.bash_profile
Restart your terminal, then update and upgrade brew sources:
Run this command, and follow doctor recommendations:
brew doctor
SDK Man
Permissions
Add permissions to user (or group) under this folders and enclosed items:
sudo chown -R $(whoami) /usr/local/opt
sudo chown -R $(whoami) /usr/local/share
WARNING: Add the next permission just in case your machine is used by only one user.
sudo chown -R $(whoami) /usr/local/lib
General Purpose
Visual Studio Code
On first run press ⌘
+ ⇧
+ P
and run the command: Shell Command: install 'code' command PATH
. And now you can use code
command from the command line. Example: code .
open an editor on the current folder.
Git
Git Config
In order to use setup git config
to use Visual Studio Code instead of Vim run this command:
git config --global core.editor 'code --wait'
Use this command to edit global configuration:
git config --edit --global
Merge and Diff Config
If also want to use VScode as your difftool and your mergetool. Add the below configuration to your global configuration.
[merge]
tool = vscode
[mergetool "vscode"]
cmd = code --wait $MERGED
[diff]
tool = vscode
[difftool "vscode"]
cmd = code --wait --diff $LOCAL $REMOTE
Use main branch
And if you want to change your default branch with main
as GitHub does.
git config --global init.defaultBranch main
Source Tree
Web Development
Node.js
I prefer to install Node through Volta.
brew install volta
Add this environment variables to ~/.bash_profile
and/or ~/.zshrc
file:
export VOLTA_HOME="$HOME/.volta"
export PATH="$VOLTA_HOME/bin:$PATH"
To install a version use:
Version | Description |
---|---|
@atest |
Latest version |
@lts |
Long Term Support |
@# |
Suitable version |
@#.#.# |
Specific version |
I'll prefer works with LTS version
To list all installed versions use:
volta list all
ℹ️ to switch between versions use the same command to install.
Yarn (npm alternative)
Packages
Do it with your favorite node package manager: yarn or npm
Name | Yarn | npm |
---|---|---|
Angular | yarn global add @angular/cli |
npm i -g @angular/cli |
Cordova | yarn global add cordova |
npm i -g cordova |
Gulp | yarn global add gulp |
npm i -g gulp |
ESLint | yarn global add eslint |
npm i -g eslint |
Typescript | yarn global add typescript |
npm i -g typescript |
CLI Tools
Do it with your favorite node package manager: yarn or npm
Name | Yarn | npm |
---|---|---|
fkill-cli | yarn global add fkill-cli |
npm i -g fkill-cli |
npkill | yarn global add npkill |
npm i -g npkill |
Yarn with VSCode
If you are using Visual Studio Code and ESLint extension, need extra configurations settings:
Yarn with Angular
Using Yarn with Angular CLI, needs to run a command inside an Angular project.
v1.7.4- | v6+ |
---|---|
ng set --global packageManager=yarn |
ng config -g cli.packageManager yarn |
Angular Console
The Power of the Angular CLI. The Convenience of an App.
brew install --cask angular-console
Browsers
brew install --cask google-chrome
brew install --cask firefox
brew install --cask homebrew/cask-versions/firefox-developer-edition
brew install --cask opera
brew install --cask opera-developer
brew install --cask microsoft-edge
brew install --cask microsoft-edge-dev
Take this FREE course: DevTools Pro: The Basics of Chrome Developer Tools.
Mobile
I like to install Gradle and Java with SDK Man because have projects that and need switch between different version, change it with SDK Man is easy.
Gradle
I'm working with 3.3 and 4.4.1 versions, if you want to use the last version, avoid the version number at the end.
Java
sdk list java
Search AdoptOpenJDK version, like 8.0.272.hs-adpt
on this list, and use it at the end like those commands.
Android SDK
Useful SDK Manager commands:
Action | Command |
---|---|
List packages | sdkmanager --list |
Install NDK | sdkmanager "ndk-bundle" |
Install build-tools | sdkmanager "build-tools;28.0.3" |
Install platform | sdkmanager "platforms;android-28" |
Update installed packages | sdkmanager --update |
Add this environment variables to ~/.bash_profile
and/or ~/.zshrc
file:
Android Bundle Tool
brew install bundletool
Android Studio
On the first run go to Tools -> Create Command-line Launcher
. And now you can use studio
command from the command line. Example: studio .
open IDE on current folder.
JADX
Dex to Java decompiler
Scrcpy (Mobile Screen Sharing)
Share your Android screen and audio on macOS
Camilo Martinez ・ Oct 8 '20
Xcode
Just install it from Apple Store: Xcode and Xcode Command Line Tools
xcode-select --install
Enable Dark Mode in some macOS apps
Camilo Martinez ・ Sep 24 '19
Cloud and Remote
Docker
FileZilla (FTP Client)
Cryptomator
Free client-side encryption for your cloud files. Open-source software: No backdoors, no registration.
Database
MySQL + Workbench
To launch MySQL now and restart at login:
brew services start mysql
Or, if you don’t want/need a background service you can just use the mysql.server tool
:
mysql.server start
mysql.server stop
PostgreSQL and pgAdmin
brew install postgresql
brew install --cask pgadmin4
Add this environment variables to ~/.bash_profile
and/or ~/.zshrc
file:
export POSTGRESQL_HOME="/usr/local/opt/postgresql"
export PATH="$POSTGRESQL_HOME/bin:$PATH"
export LDFLAGS="-L$POSTGRESQL_HOME/lib"
export CPPFLAGS="-I$POSTGRESQL_HOME/include"
Initialize and start server
initdb /usr/local/var/postgres -E utf8
createuser -s postgres
brew services start postgresql
Microsoft
.Net Core SDK
Add this environment variables to ~/.bash_profile
and/or ~/.zshrc
file:
export DOTNET_HOME="/usr/local/share/dotnet/dotnet"
export PATH="$DOTNET_HOME/bin:$PATH"
Graphic Design
Gimp (Image Editor)
Slurp (Color Picker)
Just install Slurp from Apple Store and remove all his shortcuts because interferes with VSCode ones.
Utilities
Don't use the default mail app, it's primitive and not usable at all. Just install Spark Mail from Apple Store.
Communicators
brew install --cask slack
brew install --cask discord
brew install --cask microsoft-teams
brew install --cask webex-teams
Notion
Keka (File Compression)
Follow these instructions: set as default compress application
App Cleaner (App Uninstaller)
Use it with software installed manually. With software installed with brew
use brew remove <package_name>
or brew remove --cask <software_name>
.
Karabiner (Keyboard Customizer)
What’s the better way to use PC Keyboard on macOS?
Camilo Martinez ・ Sep 23 '18
Muzzle
Silence embarrassing notifications while screencasting.
Dozer
Hide menu bar icons on your Mac.
The Clock
EUL
Status monitoring with Big Sur widgets
Productivity
Yes, I'm that kind of Developer that turn Caffeine Music into Code
.
YouTube Music (Desktop Player)
I've preferred YTM over Spotify because I can upload my own underground music collection that is not available in public music collections. That's a plus for Metalheads 🤘.
Remove all his shortcuts because interferes with macOS and VSCode ones.
Spotify
Rectangle (Windows Management)
To avoid collisions with Visual Studio Code keyboard combination uses the alternative shortcuts. Running this command in a terminal and restart rectangle:
defaults write com.knollsoft.Rectangle alternateDefaultShortcuts -bool true
Keeping You Awake
A small menu bar utility that can prevent your Mac from entering sleep mode for a predefined duration or as long as it is activated.
Aware (Track Time)
A simple menubar app that tracks how long you’ve been actively using your computer.
CheatSheet (Key Shortcuts)
Just hold the ⌘-Key
a bit longer to get a list of all active short cuts of the current application. It’s as simple as that.
Bonus Track
Once finish install of what you need, run the command brew cleanup
to release disk space.
Screenshot without Shadow
Just use Shift ⇧
+ ⌘
+ 4
+ Space
, and hold down ⌥
when you click to select the window.
Or you can disable forever the shadow added when capturing an entire window by executing the following command from the terminal:
And change the default location
defaults write com.apple.screencapture location ~/Pictures/Screenshots
Drag & Drop
Learn these useful tips:
That’s All Folks!
Happy Coding 🖖