I read the documentation and googled a good bit, but there is no real simple steps to be able to commit your local changes to github. I compiled the following steps and I just want to make sure am doing the right thing. If I changed a file foo.java locally:
git status -s //will show me that foo.java has changed
git add foo.java //will add it to my local repo
git commit -m "my changes" //commit to the local repo
git tag "v1.1" //create a tag
git push --tags //finally, move the local commit to the remote repo with the new tag. this will prompt for your password. if no tag is set as in step 4, then just
git push
is enough. right?
I am just trying to make sure that these basic steps for the most use cases is what is required to use github. I am brand new to github, and these steps are working for me, but want to make sure i am not making any fundamental mistake. Please comment if there are any missing steps. Again, am concerned about the most generic day-to-day use (like, am not really concerned about branches, etc. which I will learn on a need basis). Thank you in advance.
After (3), you should be able to call
git push origin master
which will push your currentmaster
branch to githubYour steps are fine. To nit-pick slightly, though, about the comments:
The comments about step (2) and (3) are not the best way to think about what's happening, I don't believe.
The step which "adds" your file to the local repository is
git-commit
. That's why it's calledcommit
; you commit changes to the repository.git-add foo
addsfoo
to the staging area, not to the repo itself.Your
git
repository has three "areas",working
,staging
andrepository
, depicted here (image taken from the Pro Git book):You make changes and work in the creatively named "working directory".
When you've made some changes, you want to prepare to make a commit. This is where the "staging area" comes into play. You "stage" the changes that you want to commit, and when you're happy with what the commit will look like, you commit the "staging area" to the "repository". [Note: in the
man
pages, thisstaging area
is mostly referred to theindex
].This allows you a lot of flexibility. You can stage all the changes since your last commit, or you can stage files individually, or you can stage parts of files. You can add and delete files from the staging area without losing changes or messing up the repositories history. That's what the
git add
andgit rm
commands do; they add from theworking directory
to thestaging area
, but they don't add directly into therepository
. (Hopefully the image helps make the distinctions clear).Your steps are fine. If you want to understand more about branching, commiting, manipulating commits and branches and whatnot, I'd recommend reading the Pro Git book - it's got a whole bunch of pretty pictures and language simple enough that I can understand it ;)
I think that that's enough for very basic usage. I'd just like to add two comments:
git add
): either usegit diff
, or do agit add --patch
, which will start an interactive procedure to let you decide whether to accept or reject each hunk of code you modified. If you messed anything up during this phase, you can alwaysgit reset HEAD
to get the changes back to the working copy (i.e., you would simply undo the add)git commit -a -m 'your message'
.