This repository contains scripts and configuration files to set up a development environment for macOS. It's tailored for software development, focusing on a clean, minimal, and efficient setup.
Click on the image below to watch the video on YouTube:
The setup includes automated scripts for installing essential software, configuring Bash and Zsh shells, and setting up Sublime Text and Visual Studio Code editors. This guide will help you replicate my development environment on your machine if you desire to do so.
WARNING: The configurations and scripts in this repository are HIGHLY PERSONALIZED to my own preferences and workflows. If you decide to use them, please be aware that they will MODIFY your current system, potentially making some changes that are IRREVERSIBLE without a fresh installation of your operating system.
Furthermore, while I strive to backup files wherever possible, I cannot guarantee that all files are backed up. The backup mechanism is designed to backup SOME files ONCE. If the script is run more than once, the initial backups will be OVERWRITTEN, potentially resulting in loss of data. While I could implement timestamped backups to preserve multiple versions, this setup is optimized for my personal use, and a single backup suffices for me.
If you would like a development environment similar to mine, I highly encourage you to fork this repository and make your own personalized changes to these scripts instead of running them exactly as I have them written for myself.
A less serious (but potentially annoying) change it will make is setting the Desktop background to the image I use in my tutorials. This is the script I use to set up machines I will be recording on, after all.
I likely won't accept pull requests unless they align closely with my personal preferences and the way I use my development environment. But if there are some obvious errors in my scripts then corrections would be welcome!
If you choose to run these scripts, please do so with EXTREME CAUTION. It's recommended to review the scripts and understand the changes they will make to your system before proceeding.
By using these scripts, you acknowledge and accept the risk of potential data loss or system alteration. Proceed at your own risk.
- macOS (The scripts are tailored for macOS)
- Clone the repository to your local machine:
git clone https://github.com/CoreyMSchafer/dotfiles.git ~/dotfiles
- Navigate to the dotfilesdirectory:cd ~/dotfiles 
- Run the installation script:
./install.sh 
This script will:
- Create symlinks for dotfiles (.bashrc,.zshrc, etc.)
- Run macOS-specific configurations
- Install Homebrew packages and casks
- Configure Sublime Text and Visual Studio Code
- .bashrc&- .zshrc: Shell configuration files for Bash and Zsh.
- .shared_prompt: Custom prompt setup used by both- .bash_prompt&- .zprompt
- .bash_prompt&- .zprompt: Custom prompt setup for Bash and Zsh.
- `.bash_profile: Setting system-wide environment variables
- .aliases: Aliases for common commands. Some are personalized to my machines specifically (e.g. the 'yt' alias opening my YouTube Scripts')
- .private: This is a file you'll create locally to hold private information and shouldn't be uploaded to version control
- .envt_vars: Single place for all variables being exported to shell.
- settings/: Directory containing editor settings and themes for Sublime Text and Visual Studio Code.
You're encouraged to modify the scripts and configuration files to suit your preferences. Here are some tips for customization:
- Dotfiles: Edit .shared_prompt,.zprompt,.bash_promptto add or modify shell configurations.
- Sublime Text and VS Code: Adjust settings in the settings/directory to change editor preferences and themes.
Feel free to fork this repository and customize it for your setup. Pull requests for improvements and bug fixes are welcome, but as said above, I likely won't accept pull requests that simply add additional brew installations or change some settings unless they align with my personal preferences.
This project is licensed under the MIT License - see the LICENSE-MIT.txt file for details.
- I originally forked this from Mathias Bynens' dotfiles
- Thanks to all the open-source projects used in this setup.