by shigemk2

当面は技術的なことしか書かない

Git

git-commit reuse-message

Git

git-commitするときに、特定のコミットのメッセージを再利用する。そのコミットのメッセージでそのままgit-commitするから、その場では編集はできない。 --reuse-message=<commit> Take an existing commit object, and reuse the log message and the authorship in</commit>…

git-merge allow-unrelated-histories

Git

git-merge allow-unrelated-histories --allow-unrelated-histories オプションを見てみる By default, git merge command refuses to merge histories that do not share a common ancestor. This option can be used to override this safety when merging…

Git installation

Git

Git installation Normally you can just do "make" followed by "make install", and that will install the git programs in your own ~/bin/ directory. ですって。なるほど。なお、make を実行すると直下にgitファイルができる。

git coding guidelines

Git

git coding guidelines とりあえずCで書かれていることを覚えたい

git mailing list

Git

git mailing list こちら。 https://git-scm.com/community

git diff option source code

Git

git diff option source code git diffのオプションをいろいろ判定するソースコードの箇所。 Cが(まだ)分からない。 git/diff.c at master · git/git · GitHub 文字列を見ているのか。 http://www9.plala.or.jp/sgwr-t/lib/strcmp.html

settings for core.whitespace

Git

settings for core.whitespace https://git-scm.com/book/ja/v2/Git-%E3%81%AE%E3%82%AB%E3%82%B9%E3%82%BF%E3%83%9E%E3%82%A4%E3%82%BA-Git-%E3%81%AE%E8%A8%AD%E5%AE%9A core.whitespaceの設定について デフォルト有効 blank-at-eol 行末空白を表示 blank-…

git-describe

Git

git-describe Describe a commit using the most recent tag reachable from it 最近のタグのコミット情報を取得する v2.10.0-33-ga3e80ea9d だと、最新のタグはv2.10.0で、最新のコミットから33コミット前で、gはprefix(gitの略)で、該当するタグがつけられ…

git cherry-pick in remote branch

Git

git cherry-pick in remote branch リモートブランチのコミットもcherry-pickできるの?できるよ。 git fetchしてればね。ってはなし。 # fetch just the one remote git fetch <remote> # or fetch from all remotes git fetch --all # make sure you're back on th</remote>…

git vs bzr

Git

git vs bzr の対応表。checkoutはsubversion的であるし、branchはgitっぽい なお、shallow clone的な使い方はcheckoutだけで使える。 http://doc.bazaar.canonical.com/migration/en/survival/bzr-for-git-users.html http://doc.bazaar.canonical.com/beta/…

git clone depth

Git

git clone depth shallow cloneともいうけど、 --depth n とすることでコミット数だけcloneする だいたい --depth 1 みたいな使い方をする --depth <depth> Create a shallow clone with a history truncated to the specified number of commits. Implies --single</depth>…

commentChar config.c

Git

commentCharの実装のところ極めていい加減な雑感 git/config.c at master · git/git · GitHub valueは文字の配列 valueが空(!チェック)だったらおなくなり auto_comment_line_charは0 or 1でなんかしている auto_comment_line_charはvalueが"auto"だったら1 …

commentChar

Git

git config --global core.commentChar コメントのデフォルトはシャープなのを別の文字に変更できる。ただし文字数制限は一文字。 https://git.kaarsemaker.net/git/commit/84c9dc2c5a2d34351a06554af32501d4f99990e9/

git commit cleanup whitespace

Git

git commit cleanup whitespace git config --global commit.cleanup whitespace コミットログのシャープ(#)を無視する。GitHubのプルリクエスト対策に有効。 https://git-scm.com/docs/git-commit

git commit

Git

prestoの開発ガイドラインになってた。 件名と本文は改行で分ける 件名の文は50文字以内に収める 件名は大文字から始める 件名をピリオドで終わらせない 直説法を使う 本文も各行は80文字以内に収める howではなくwhat/whyを書く https://chris.beams.io/pos…

show all tags in git log

Git

git log --no-walk --tags --pretty="%h %d %s" --decorate=full no-walk 対象となるコミットログしか表示しない(–no-walkだけだと直近のログしか出ない) tags 最後にタグが付けられたコミットログから表示する pretty 詳細表示 decorate=full refも表示する…

git commit amend now

Git

2.7.0から。 git commit --amend --date=now 今の時間にamendすることができる。 stackoverflow.com

git am

Git

git am パッチの適用。 git am diff.path これを応用して curl -s -L https://patch-diff.githubusercontent.com/raw/cask/cask/pull/392.patch | git am - みたいなこともできる http://blog.a-way-out.net/blog/2015/03/28/github-pull-request-merge/ htt…

git diff patch

git

git diff master topic_branch > diff.patch patch -p1 < diff.patch diffの取り方はなんでもいい。HEAD~1みたいな書き方でも可能。

誰がコミットしたかを確認する

Git

こんな感じ。git shortlog を使う。 ➜ kuroko2 git:(master) git shortlog -s -n | head -4 341 Eisuke Oishi 16 Kohei Suzuki 8 shigemk2 7 Naoto Takai Git - git-shortlog Documentation

bitbucketの最小プラン

Git

d.hatena.ne.jp 5人チームだと無料でいける bitbucket.org

gitbook-cli

Git

npm install -g gitbookからの、 gitbook serve で、ローカルからGitBookの見た目をブラウザで確認出来る。いちおう変更をwatchしてくれるけど、Emacsだと#のファイルが出来てコケる。 github.com

remote: fatal error in commit_refs

Git

remote: fatal error in commit_refs に遭遇した時どうしたらいいんだろう git gc ネットにつながっているか確認する git push origin master -rしてからgit push origin master いろいろあるけど、僕の場合もう一度pushしたら通ったので、いろいろなパター…

git statusの文字化け対策

Git

git config --global core.quotepath false ってやるといいんだけど、なんでこの設定にしないといけないんだっていうのが見つからなかったので。 The commands that output paths (e.g. ls-files, diff), when not given the -z option, will quote "unusual…

git send-email

Git

考えてみると、GitHubというツールは偉大であると同時に不自由でもあるため、パッチのメールを送る時のコマンド群を記す。 事前設定(Gmailの例 送信メールアドレスの設定を~/.gitconfigで) [sendemail] smtpencryption = tls smtpserver = smtp.gmail.com sm…

gitの今のbranchを取得する

Git

思い出してきた。 git rev-parse --abbrev-ref HEAD

Git push master fatal: You are not currently on a branch

Git

Git push master fatal: You are not currently on a branch エラーの文章いっぱいでてたけど、最後のコマンドを実行したらばうまく行きました。 fatal: You are not currently on a branch. To push the history leading to the current (detached HEAD) st…

git rebaseでNeeded a single revision

凡ミスの間違い探し。 $ git rebase -i head~2 fatal: Needed a single revision invalid upstream head~2 stackoverflow.com ただしくは、headではなくHEADだ。

git add upstream毎回やるの面倒だった

Git

#!/bin/bash git remote add upstream $1 これ。毎回git add upstreamするの面倒なので。 qiita.com

Gitで既に削除したファイルのコミットログを確認したい

Git

git log -p -- delete_test.txt man git-log には以下のように書いてあって、 Show only commits that are enough to explain how the files that match the specified paths came to be. See History Simplification below for details and other simplific…