factor/extra/git/notes.txt

147 lines
4.4 KiB
Plaintext
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

CONSTANT: OBJ_COMMIT 1
CONSTANT: OBJ_TREE 2
CONSTANT: OBJ_BLOB 3
CONSTANT: OBJ_TAG 4
CONSTANT: OBJ_OFS_DELTA 6
CONSTANT: OBJ_REF_DELTA 7
"/Users/erg/factor" set-current-directory
"3dff14e2f3d0c8db662a8c6aeb5dbd427f4258eb" git-read-pack
"/Users/erg/factor" set-current-directory
git-log
"/Users/erg/factor" set-current-directory
"401597a387add5b52111d1dd954d6250ee2b2688" git-object-from-pack
git verify-pack -v .git/objects/pack/pack-816d07912ac9f9b463f89b7e663298e3c8fedda5.pack | grep a6e0867b
a6e0867b2222f3b0976e9aac6539fe8f12a552e2 commit 51 63 12938 1 8000d6670e1abdbaeebc4452c6cccbec68069ca1
! problem: a6e0867b2222f3b0976e9aac6539fe8f12a552e2
! investigate:
http://stackoverflow.com/questions/9478023/is-the-git-binary-diff-algorithm-delta-storage-standardized/9478566#9478566
http://stackoverflow.com/questions/801577/how-to-recover-git-objects-damaged-by-hard-disk-failure
git ls-tree
! eh
http://schacon.github.io/git/technical/pack-format.txt
https://schacon.github.io/gitbook/7_the_packfile.html
! most useful doc:
http://git.rsbx.net/Documents/Git_Data_Formats.txt
! git show:
git show -s --pretty=raw 2ca509a8fe681d58f80d402ea9da2be20b9ab0a0
! git add
git add -p # parts of files
! git reset
git merge --abort is alias for git reset --merge
! Merge strategies:
octopus: git merge fixes enhancements # two branches merging
git merge --no-commit maint # merge maint into current branch, but do not make a commit yet
http://git-scm.com/docs/git-merge
http://stackoverflow.com/questions/161813/fix-merge-conflicts-in-git?rq=1
# common base:
git show :1:_widget.html.erb
# 'ours'
git show :2:_widget.html.erb
# 'theirs'
git show :3:_widget.html.erb
git show :3:_widget.html.erb >_widget.html.erb
git add _widget.html.erb
aka
git checkout --theirs _widget.html.erb
Guys, "ours" and "theirs" is relative to whether or not you are merging or rebasing. If you're merging, then "ours" means the branch you're merging into, and "theirs" is the branch you're merging in. When you're rebasing, then "ours" means the commits you're rebasing onto, while "theirs" refers to the commits that you want to rebase. Cupcake May 26 '14 at 4:27
! random
https://github.com/libgit2/libgit2/blob/091165c53b2bcd5d41fb71d43ed5a23a3d96bf5d/docs/diff-internals.md
https://github.com/schacon/git-server/blob/master/git-server.rb
https://git-scm.com/blog
https://github.com/gitchain/gitchain/blob/2baefefd1795b358c98335f120738b60966fa09d/git/delta.go
https://www.kernel.org/pub/software/scm/git/docs/user-manual.html#git-concepts
! graphs in terminal:
http://stackoverflow.com/questions/1064361/unable-to-show-a-git-tree-in-terminal
git-daemon:
git daemon --reuseaddr --verbose --base-path=. --export-all
$> export GIT_TRACE_PACKET=1
git ls-remote git://127.0.0.1/git-bottom-up
raw git:
https://schacon.github.io/gitbook/7_raw_git.html
# write object
git hash-object -w myfile.txt
-----------------------------------
Now lets say you want to create a tree from your new objects. The git mktree command makes it pretty simple to generate new tree objects from git ls-tree formatted output. For example, if you write the following to a file named '/tmp/tree.txt' :
100644 blob 6ff87c4664981e4397625791c8ea3bbb5f2279a3 file1
100644 blob 3bb0e8592a41ae3185ee32266c860714980dbed7 file2
$ cat /tmp/tree.txt | git mk-tree
f66a66ab6a7bfe86d52a66516ace212efa00fe1f
100644 blob 6ff87c4664981e4397625791c8ea3bbb5f2279a3 file1-copy
040000 tree f66a66ab6a7bfe86d52a66516ace212efa00fe1f our_files
$ cat /tmp/newtree.txt | git mk-tree
5bac6559179bd543a024d6d187692343e2d8ae83
.
|-- file1-copy
`-- our_files
|-- file1
`-- file2
1 directory, 3 files
---------------------------------------------
$ export GIT_INDEX_FILE=/tmp/index
$ git read-tree --prefix=copy1/ 5bac6559
$ git read-tree --prefix=copy2/ 5bac6559
$ git write-tree
bb2fa6de7625322322382215d9ea78cfe76508c1
$>git ls-tree bb2fa
040000 tree 5bac6559179bd543a024d6d187692343e2d8ae83 copy1
040000 tree 5bac6559179bd543a024d6d187692343e2d8ae83 copy2
-------------------------------
GIT_AUTHOR_NAME
GIT_AUTHOR_EMAIL
GIT_AUTHOR_DATE
GIT_COMMITTER_NAME
GIT_COMMITTER_EMAIL
GIT_COMMITTER_DATE
$ git commit-tree bb2fa < /tmp/message
a5f85ba5875917319471dfd98dfc636c1dc65650
$ git update-ref refs/heads/master a5f85ba5875917319471dfd98dfc636c1dc65650
https://github.com/magit/magit
https://www.kernel.org/pub/software/scm/git/docs/user-manual.html