3

github で git リポジトリを作成し、自宅で複製しました。

 - eris:utility-functions$ ls
README

 - eris:utility-functions$ git status
# On branch master
nothing to commit, working directory clean

 - eris:utility-functions$ cat .git/config 
[core]
        repositoryformatversion = 0
        filemode = true
        bare = false
        logallrefupdates = true
[remote "origin"]
        url = https://github.com/dotancohen/utility-functions.git
        fetch = +refs/heads/*:refs/remotes/origin/*

 - eris:utility-functions$ git log --pretty=oneline
d444d752ed18b9d5b8422621b841413c30159d3c first commit

仕事で、レポを複製し、いくつかのコミットを行い、github にプッシュしました。

 - bruno:utility-functions$ ls
example-usage.php  README.md  solr.php  util.php

 - bruno:utility-functions$ git status
# On branch master
nothing to commit (working directory clean)

 - bruno:utility-functions$ cat .git/config
[core]
        repositoryformatversion = 0
        filemode = true
        bare = false
        logallrefupdates = true
[remote "origin"]
        fetch = +refs/heads/*:refs/remotes/origin/*
        url = https://github.com/dotancohen/utility-functions.git
[branch "master"]
        remote = origin
        merge = refs/heads/master

 - bruno:utility-functions$ git log --pretty=oneline
cbfe00402226457aed50f658126783151b074759 get_user_ip_address(): Handle multiple addresses for all types
998d57e333d0a0700539f7c6c12b9bad5536b430 get_user_ip_address(): Handle multiple addresses
6ed9d43a05ab8f0a4191da84d8025db59095f8c3 Add function for sending mail with Amazon Simple Email Service
051c8e3f4982028cef677b486b305f3057be1be4 Added get_external_ip_address() which relies on simplesniff.com.
76e574f9260cae0f9fc00ed56b9b6da5f3f37c42 Provide example usage for ensure_fields() function.
39a6471627e1be6b0351257428e634c6f45dd234 ensure_fields(): Properly document ensure_fields(): Return NULL on invalid i
c0b06fb40b86cba67edafc1454df64e4e8e9c9a2 Merge branch 'master' of https://github.com/dotancohen/utility-functions
1aa18cbdef9643f3d964a97ccda41df414e009cf Added ensure_fields() function. Added example usage page.
63840793056ce75ac0e9b7dcbcd9683980a24a2c Added ensure_fields() function. Added example usage page.
5cf5aba1fd808433570c7e4c2693acf03a0de862 Initial solr.php file. Added solr_escape() function.
5e75c0499bc4b1fe1350577726b0566d7c647a8e Initial commit

 - bruno:utility-functions$ git push
WARNING: gnome-keyring:: couldn't connect to: /run/user/dotancohen/keyring-wHsyrf/pkcs11: No such file or directory
Username for 'https://github.com': dotancohen
Password for 'https://dotancohen@github.com': 
Everything up-to-date

自宅でプルしようとすると、ブランチについて git が混乱します。

 - eris:utility-functions$ git pull
There is no tracking information for the current branch.
Please specify which branch you want to merge with.
See git-pull(1) for details

    git pull <remote> <branch>

If you wish to set tracking information for this branch you can do so with:

    git branch --set-upstream-to=origin/<branch> master

git branch --set-upstream-to=origin/master master現在のコミットに何が起こるか正確にはわからないので、単純に行うことには慎重です。ホーム (eris) コンピューターのブランチを変更したことがないので、エラーの原因は何ですか? コマンドgit branch --set-upstream-to=origin/master masterを自宅から実行しても安全ですか? 職場のコンピューター (ブルーノ) からこれを行う必要がなかったのはなぜですか?

ありがとう!

4

1 に答える 1

3

git branch --set-upstream-to=origin/master私の現在のコミットに何が起こるか正確にはわからないので、master.

マスターの現在のコミットには何も起こりません。

次に、 Agit pullが取得しorigin/masterて master にマージします。

必要に応じて、マージする前に、git fetch最初に2 つのブランチ間の差分を調べることができます。Mark Longairの投稿 " git: and , don't " を参照してください。
fetchmergepull

職場のコンピューター (ブルーノ) からこれを行う必要がなかったのはなぜですか?

おそらくgit push -u origin master、仕事からの最初のプッシュで、リモート追跡ブランチを (work) に設定したためですmaster
詳細については、「新しいブランチを明示的にプッシュする必要があるのはなぜですか?」を参照してください。

于 2013-06-16T10:28:36.277 に答える