Skip to content

Latest commit

 

History

History
102 lines (83 loc) · 6.06 KB

README.md

File metadata and controls

102 lines (83 loc) · 6.06 KB

BHL Git and GitHub Training

Welcome to BHL Git and GitHub training!

If you are new to Git and GitHub, or you need a refresher, you're in the right place.

In this training, you will upload a python script to bentley-historical-library/bhl_git_training repository (repo) and learn how to:

BEFORE YOU START

  • The 2024 reboot is adapted from Hyeeyoung Kim's original git training for the Bentley Historical Library. Thank you, Hyeeyoung!
  • This training assumes you've successfully set up a Python Development Environment.
  • I (Max) am a visual learner, and this visualization helped me get a basic overview of git and GitHub workflow:

Git/GitHub Workflow

STEP 1. SETTING UP

Forking a repo to your personal GitHub account

Click the Fork button in the top-right corner of a GitHub repo page
  • A fork is a copy of a repo. Forking a repo allows you to freely experiment with changes without affecting the original project. >> More

Cloning a repo to your computer with GitHub Desktop

Click File --> Clone repository... in the top-left corner of GitHub Desktop
Filter your repositories, choose a local path, and click Clone
  • Cloning (from the command line, git clone) copies a repo from your fork to create a local copy on your computer. >> More

STEP 2. UNDERSTANDING WORKFLOW

Syncing a fork

Click the Sync fork button in the top-right corner of your fork in GitHub, then Update branch
  • This refreshes your fork so that it matches whats in the upstream repo (from the command line, git fetch upstream). It allows you to see what everybody else has been working on. >> More

Fetching from fork

Click the Fetch origin button at the top of GitHub Desktop
Then (if applicable), the Pull origin button
  • This ensures that what's local on your comuter matches what's in your fork. If there are differences, you will be prompted to "pull" (from the command line, git pull) them down. >> More

Committing new changes

Fill out the Title and optionally a Description in the lower left of GitHub Desktop and click Commit to master (sic)
  • As you work on your computer, you save your work by committing it. Commits can be thought of as snapshots along the timeline of a project. Commits are created with the git commit command to capture the state of a project at that point in time. >> More
  • Tip: Use the imperative mood for your commit message

Pushing new changes

Click "Push origin" in GitHub Desktop (after committing a change)
  • Pushing is used to upload what's local on your computer to your fork. >> More

STEP 3. COLLABORATING

Creating Pull Requests

Click the Contribute button in the top right of GitHub and then the Open pull request button
Add a Title and optionally a Description
  • Pull requests let you tell others about changes you have pushed to a repo on GitHub. Once the request is reviewed and approved, your changes are merged into the repo. >> More
  • Tip: After creating a pull request and having it accepted, your fork will be technically behind the upstream repo. You'll need to start over again with syncing.

BEFORE YOU LEAVE

That was the Git and GitHub basics! Before you leave, there are few useful things you might want to know:

First and Foremost

When you are working with Git and GitHub, NEVER put confidential/senstive information (e.g., password, API keys, and etc.) into a repo.

.gitignore

  • A .gitignore file can be used to specify files and directories that should not be tracked by git. These might include log files, test data, configuration files created by a code editor, and so on.
  • Files and directories to ignore can be specified by exact name (e.g., a directory named "test-data/" or a file called "secrets.txt") to ignore those specifics files or directories or by using a wildcard to ignore patters of files or directories (e.g., "*.log" to ignore all log files).
  • Learn more about .gitignore

LET'S TRY IT OUT!

  • Forking this repo to your personal GitHub account
  • Clone this repo to your computer with GitHub Desktop
  • Sync your fork (if necessary) to this repo in GitHub
  • Fetch data from your fork (if necessary) in GitHub Desktop
  • Use your IDE or text editor to create a new file in the "2024_reboot" folder modeled after "max.py"
  • Commit this in GitHub Desktop
  • Push your commit(s) to your fork
  • Open a pull request from your fork to this repo

ADDITIONAL RESOURCES

ACKNOWLEDGMENTS