Git Push удаленного репо - PullRequest
       6

Git Push удаленного репо

1 голос
/ 30 июня 2011

У меня есть локальная рабочая копия и удаленная копия на моей флешке. Я уже работал с флэш-накопителем, но, похоже, не могу сделать это снова.

здесь я зашел в мое удаленное хранилище на флэш-накопителе, чтобы посмотреть, в какой ветке я находился, и посмотрел журнал. Затем я вернулся в локальное хранилище рабочей копии, отредактировал файл, добавил этот файл, сделал коммит и попытался вставить его в мой флэш-накопитель, но он не сработал. Кто-нибудь может сказать, что я делаю не так?

David-Adamss-MacBook-Pro:~ davidadams$ cd /volumes/thumbdrive/repo/releventz
David-Adamss-MacBook-Pro:releventz davidadams$ git status
# On branch master
# Your branch is ahead of 'origin/master' by 2 commits.
#
nothing to commit (working directory clean)
David-Adamss-MacBook-Pro:releventz davidadams$ git branch
* master
David-Adamss-MacBook-Pro:releventz davidadams$ git log
commit 65328c9603f62b7a2058f38fb441605b0c4c431e
Author: David Adams <adams.david.10@gmail.com>
Date:   Wed Jun 29 23:30:40 2011 -0500

    third commit

commit b3883fa933609db634b98d747299c1e9c96e8269
Author: David Adams <adams.david.10@gmail.com>
Date:   Wed Jun 29 23:10:53 2011 -0500

    second commit

commit 54832381a6fe898408c9e07bc8409a2982ec6274
Author: David Adams <adams.david.10@gmail.com>
Date:   Wed Jun 29 22:20:04 2011 -0500

    changed checklist.php

commit 1955664689313a589543576477e0a134f26cc313
Author: David Adams <adams.david.10@gmail.com>
Date:   Wed Jun 29 22:12:53 2011 -0500

    first releventz commit
David-Adamss-MacBook-Pro:releventz davidadams$ cd
David-Adamss-MacBook-Pro:~ davidadams$ cd
David-Adamss-MacBook-Pro:~ davidadams$ cd /applications/mamp/htdocs/releventz
David-Adamss-MacBook-Pro:releventz davidadams$ git status
# On branch master
nothing to commit (working directory clean)
David-Adamss-MacBook-Pro:releventz davidadams$ git status
# On branch master
# Changes not staged for commit:
#   (use "git add <file>..." to update what will be committed)
#   (use "git checkout -- <file>..." to discard changes in working directory)
#
#   modified:   application/libraries/calendarclass.php
#
no changes added to commit (use "git add" and/or "git commit -a")
David-Adamss-MacBook-Pro:releventz davidadams$ git add .
David-Adamss-MacBook-Pro:releventz davidadams$ git status
# On branch master
# Changes to be committed:
#   (use "git reset HEAD <file>..." to unstage)
#
#   modified:   application/libraries/calendarclass.php
#
David-Adamss-MacBook-Pro:releventz davidadams$ git commit -m 'blah blah'
[master 853232d] blah blah
 1 files changed, 1 insertions(+), 1 deletions(-)
David-Adamss-MacBook-Pro:releventz davidadams$ git push flashdrive master
Counting objects: 17, done.
Delta compression using up to 2 threads.
Compressing objects: 100% (12/12), done.
Writing objects: 100% (12/12), 1.89 KiB, done.
Total 12 (delta 8), reused 0 (delta 0)
Unpacking objects: 100% (12/12), done.
remote: error: refusing to update checked out branch: refs/heads/master
remote: error: By default, updating the current branch in a non-bare repository
remote: error: is denied, because it will make the index and work tree inconsistent
remote: error: with what you pushed, and will require 'git reset --hard' to match
remote: error: the work tree to HEAD.
remote: error: 
remote: error: You can set 'receive.denyCurrentBranch' configuration variable t
remote: error: 'ignore' or 'warn' in the remote repository to allow pushing int
remote: error: its current branch; however, this is not recommended unless you
remote: error: arranged to update its work tree to match what you pushed in som
remote: error: other way.
remote: error: 
remote: error: To squelch this message and still keep the default behaviour, se
remote: error: 'receive.denyCurrentBranch' configuration variable to 'refuse'.
gTo /volumes/thumbdrive/repo/releventz
 ! [remote rejected] master -> master (branch is currently checked out)
    error: failed to push some refs to '/volumes/thumbdrive/repo/releventz'

Ответы [ 4 ]

2 голосов
/ 30 июня 2011

Вам не разрешено переходить в другой репозиторий с проверенным кодом.Git отказывается обновлять его.

Если вам действительно нужно резервное хранилище на флэш-накопителе, и вы никогда не будете редактировать его, тогда сделайте его пустым.

Если выВы используете его в качестве второго места для редактирования, затем перейдите в репозиторий и извлеките его из дискового хранилища.То есть, всегда вытягивайте в активно используемый репозиторий и никогда не проталкивайте.

[да, вы можете обойти это, но не должны]

1 голос
/ 11 октября 2011

Сегодня у меня была та же ошибка. И я исправляю ее методом, подобным ответу Билла Дверя.Может быть, вы можете сделать так:

David-Adamss-MacBook-Pro:~ davidadams$ cd /volumes/thumbdrive/repo/releventz
David-Adamss-MacBook-Pro:~ davidadams$ git checkout subbranch
David-Adamss-MacBook-Pro:~ davidadams$ cd /applications/mamp/htdocs/releventz
David-Adamss-MacBook-Pro:~ davidadams$ git push flashdrive master
0 голосов
/ 19 ноября 2012

Другим вариантом является , а не , чтобы иметь полное непокрытое (или даже голое) репо на флэш-накопителе (потому что это предполагает, что много файлов правильно скопировано наудаленное запоминающее устройство), но иметь или обновить связку .

Пакет git - это один файл (намного проще скопироватьчерез USB-накопитель).
И вы можете извлечь из этого одного файла, чтобы воссоздать полноценное хранилище в любом месте, где вам нужно.
См. " Как синхронизировать два репозитория git "как иллюстрация.

0 голосов
/ 01 июля 2011

Уэс предложил два хороших ответа. Другое решение - создать вторую ветку. Перейдите в ваш исходный репозиторий и извлеките вторую ветку. Теперь вы можете перейти в основную ветку из вашего рабочего репозитория.

cd master_repo
git checkout -b stepaside
cd work_repo
git push

Последующие нажатия вы можете заменить на

cd master_repo
git checkout stepaside
cd work_repo
git push
...