###To get started:
- Download and install a good text editor like Atom.
- Download and install the GitHub Desktop app.
- Setup the Github Desktop app by telling it your GitHub user name (which you need to create if you haven't already).
Git is a version control program that helps you very accurately keep track of changes to text files, with or without collaborators. Note that .txt, .do, .R, .md, and many other files are actually text files. Others like .doc, .docx, .xls, .xlsx, .pdf, .dta, are not text files. So there's huge value in using Git and Github for your Stata script (.do) files, but there's little value in using it with your data (.dta) files.
Most people use the command line to run Git, but GitHub has built an app that can do some of the simpler tasks, and that's what we'll use.
###Cloning, Creating, and Changing: The options in the Github app under the "+" button are to add, create, or clone a repository. Adding is just telling the app that a repository is already on your computer. Creating creates a new repository. Cloning is copying an existing repository from your GitHub account. To clone a public repository that doesn't belong to you, click the download button that is just to the left of the "Download ZIP" button on the repository's GitHub.com page, or drag and drop the URL from your browser into the open GitHub Desktop app (oddly, there is no way to type the URL directly into the app.)
- Create a new repository. What files are in it?
- Add a README.md
- Commit the changes.
- Make some more changes, and also add a .do file. What do changes look like? History?
- Commit the changes separately.
- Undo a commit with Revert. Does it work if you try to revert a commit that adds a file?
- Undo a commit with the undo menu option. What's the difference?
- Discard uncommitted changes.
###Publishing (pushing and pulling):
You can store stuff online at GitHub.com (or any server with Git installed), which will enable you to work on multiple computers.
- Just click the Publish button.
- Make changes online via GitHub.com.
- Sync with the sync button.
Go back and forth between local and remote (online) changes, being sure to sync between each commit. Eventually you'll screw up and not sync enough. (That is, change a file online and commit it. Don't sync. Make a contradictory change locally and commit it. Try and sync. What happens?)
###Branching: Git uses branches to let you experiment on new ideas or bug fixes.
- Create, name, and sync a new 'experimental' branch with the 'fork' button.
- Make changes, save, and commit them to 'experimental.'
- Oh wait, no. Emergency, you have to go back to the main (master) branch.
- Change a different file or a different part of the same file. Save and commit to master.
- Merge the experimental and master branches.
- Between the experimental branch and the main branch, make some conflicting changes (that is, changes to the same lines of the same file). Then try and merge. What happens?
###Collaborating: Thus far we've been working solo. Now we'll collaborate. GitHub is built for this. Thousands of people contribute code to large open source coding projects without ever meeting in person. It's also great for just a few people to collaborate on simpler coding projects.
There are two ways to collaborate:
- Make everyone you trust a collaborator. For small projects with trusted collaborators only.
- Pull requests. For big projects--let anyone make suggestions (called pull requests) and the owner gets to choose whether to accept.
We'll probably only have time for #1.
- Pair up with a neighbor. One of you be A and one be B for this exercise.
- In the settings tab for A's repository on Github.com (that A published above), add B as a collaborator.
- B accept the invitation, and clone A's repository so you have it on your own computer.
- B make a change, commit, and sync (push) the change.
- A sync (pull) B's changes, make your own changes, commit, and push.
- After handing off back and forth successfully, make simultaneous conflicting changes. How do you resolve the conflicts?
- Switch roles between A & B and repeat.
###Additional Git Topics:
####Pull Requests: This is how you suggest changes to repositories to which you aren't a full fledged collaborator. Try this with a partner if you have time. Clone a repo you don't own, make a change, submit a pull request, and ask the owner to merge the pull request. Switch roles.
####Command Line: Many, if not most, experienced users will use Git via the command line. (Terminal on a Mac, the Git Shell that came with the Desktop app, Windows PowerShell, there are a lot of options. They're all where you type commands for your computer to execute.) You can read why here. Basically, it's more powerful.
There are a million and one online tutorials for Git in the command line. Software Carpentry's is good, as is Atlassian's. The basic stuff is all nicely summarized here in a single page.