From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Date: Wed, 12 Jan 2022 23:06:23 +0300 From: "Dmitry V. Levin" To: ALT Devel discussion list Message-ID: <20220112200623.GA13204@altlinux.org> References: <20220111111209.0ec47280@tower> <3005468.b3WyR9EExj@zerg.malta.altlinux.ru> <20220112002655.d7kqtjsj32hv5j23@altlinux.org> <20220112003920.GG32049@altlinux.org> <20220112122051.GB7960@altlinux.org> <20220112165907.GA11057@altlinux.org> <20220112191434.32rmrfqok73vdime@example.org> MIME-Version: 1.0 Content-Type: text/plain; charset=koi8-r Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <20220112191434.32rmrfqok73vdime@example.org> Subject: Re: [devel] gear-store-submodules X-BeenThere: devel@lists.altlinux.org X-Mailman-Version: 2.1.12 Precedence: list Reply-To: ALT Linux Team development discussions List-Id: ALT Linux Team development discussions List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 12 Jan 2022 20:06:23 -0000 Archived-At: List-Archive: List-Post: On Wed, Jan 12, 2022 at 08:14:34PM +0100, Alexey Gladkov wrote: > On Wed, Jan 12, 2022 at 07:59:07PM +0300, Dmitry V. Levin wrote: > > > Вроде бы дочитал, отредактировал, запушил в > > > https://git.altlinux.org/people/ldv/packages/?p=gear.git;a=shortlog;h=submodules > > > но всё равно у меня нет полной уверенности, что предпоследний коммит, > > > который обрабатывает .gear/submodules/list в gear, делает это совершенно > > > безопасно. > > > > Этот подход работает, но он подойдёт не всем. > > > > Постановка задачи была, насколько я помню, примерно следующая: > > - в некотором проекте используются submodules для сравнительно небольших > > внешних подпроектов; > > - требуется собирать пакеты из этого проекта в Сизиф; > > - требуется не засорять историю этого проекта историями внешних подпроектов; > > - пользоваться этим должно быть не сложнее, чем gear-store-tags; > > - за всё это удобство можно заплатить увеличением размера git-репозитория > > проекта. > > > > В общих чертах реализация построена та том, что > > - есть новый инструмент gear-store-submodules, похожий на gear-store-tags, > > который превращает submodules в бандлы с помощью git-bundle(1), > > а эти бандлы, в свою очередь, добавляются в репозиторий как обычные файлы; > > - gear умеет автоматически конвертировать такие бандлы в архивы > > и добавлять такие архивы к основным архивам. > > Эта реализация сделана с учётом основного критерия gear - все необходимые > объекты должны быть доступны по хэшу. При этом истории не должны > смешиваться иначе это уже не submodule, а subtree. Такую реализацию > поддержки submodules для gear я тоже делал, но это было совсем не то что > хотелось. Может быть, кому-то конвертирование submodule в subtree подошло бы лучше, чем конвертирование submodule в bundle. -- ldv