Войти в систему

Home
    - Создать дневник
    - Написать в дневник
       - Подробный режим

LJ.Rossia.org
    - Новости сайта
    - Общие настройки
    - Sitemap
    - Оплата
    - ljr-fif

Редактировать...
    - Настройки
    - Список друзей
    - Дневник
    - Картинки
    - Пароль
    - Вид дневника

Сообщества

Настроить S2

Помощь
    - Забыли пароль?
    - FAQ
    - Тех. поддержка



Пишет superhuman ([info]superhuman)
@ 2016-03-29 01:24:00


Previous Entry  Add to memories!  Tell a Friend!  Next Entry
Заебала ситуация когда не могу пользоваться гитом между двумя тачками (под виндой). Решил разъебать эту проблему мега-волевым усилием. Даже сорцы гита скачал. Но до дебага не дошло.

Всё же разобрался - копаясь (часами) в мусоре великого инетного разума, втыкая в гит, сорцы и конфиги, включая логику и программерскую чуйку.

К слову, проблемы обычно не разъябуются волевым усилием. Обычно воля "беззащитного человечка" разбивается о проблему. На практике проблемы решаются - как вода обтекает камень. Типа "падай как камень, ползи как змея", - если хочешь чтобы заработало. Хотя ебал я такой подход. Пусть лучше не работает. Ведь работа не хуй - сто лет простоит, как говорится, и в этом дзен. (не много ли я ругаюсь?)

Ну, да, к нашим баранам. Протокол используем гитовый. Всяких советчиков гита-через-хттп на хуй. Минималистичный подход. Демон запускать надо так:
git daemon --export-all --base-path=<путь> --enable=receive-pack
- причём <путь> надо не к репозиторию, а к директории, где он лежит. Без --enable=receive-pack по дефолту push отключен.

На стороне клиента pull работает, а push, - сюрприз, - виснет. В гите дедлок на пуше - этому багу 5 лет минимум. Вася, который лабает гит, ленится фиксить (и закрыл багрепорт "чтобы глаза не мозолил"). Баг где-то там между гитом, mingw64 и виндой. "Но юзеру похуй", как говорит Линус. Ирония, кстати, в том, что этот гит сам Линус и лабал вначале. Однако, FOSS на то и FOSS, чтобы дев слал юзера на хуй (а также девы девов, юзеры девов, юзеры юзеров и т.д.). Это ж не энтерпрайз, где клиент ставит дева раком и ебёт за деньги. (Снова лирическое отступление, так сказать).

Надо отключить на клиенте мультиплексирование пакетов:
git config --global sendpack.sideband false
Вот так пуш будет работать... но не сразу. Ибо на двух репах один дев работает, скорее всего, на том же брэнче в данный конкретный момент.

Гит не даёт пушить в отчекаутнутый брэнч. Напоминаю, юскейс - это две репы на двух тачках и один дев (я). Причём надо лабать на обоих. Советчики сделать третий "bare" репозиторий или временный брэнч идут на хуй. Самое простое, по моему, - это git checkout --detach на сервере, потом пулл и обратно на мастер-брэнч. Ну, это, конечно, если не особо часто синкать.


(Добавить комментарий)


[info]wasserstrahl
2016-03-29 09:05 (ссылка)
"В гите девспоминает ше - этому багу 5 лет минимум"
*иронично вспоминает пафосных разрабов, которые рвали на себе тельняшку, доказывая, что гит рулез*

(Ответить) (Ветвь дискуссии)


[info]phantom
2016-03-29 10:35 (ссылка)
А он и есть рулез - нужно только напильником слегка помассировать.

(Ответить) (Уровень выше) (Ветвь дискуссии)


[info]wasserstrahl
2016-03-29 11:21 (ссылка)
Ну началось)

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

(Ответить) (Уровень выше) (Ветвь дискуссии)


[info]phantom
2016-03-29 11:37 (ссылка)
С чего б я тебя убеждать начал? Делать мне нечего. Ви делаете мне смешно.

(Ответить) (Уровень выше) (Ветвь дискуссии)


[info]wasserstrahl
2016-03-29 12:23 (ссылка)
Ты -- нет. Но деятели находились.

Не, все ок)

(Ответить) (Уровень выше) (Ветвь дискуссии)


[info]phantom
2021-03-05 17:07 (ссылка)
Спустя 5 лет - я понял, чем mercurial лучше гита, есть хорошая статья на эту тему, если чо.

(Ответить) (Уровень выше)


(Анонимно)
2016-03-29 15:11 (ссылка)
ребята, на флибусту заходите? опять ватные книжки читаете?

(Ответить)