<?xml version="1.0" encoding="UTF-8" ?>

<bugzilla version="5.2"
          urlbase="https://bugzilla.altlinux.org/"
          
          maintainer="jenya@basealt.ru"
>

    <bug>
          <bug_id>15442</bug_id>
          
          <creation_ts>2008-04-23 22:54:35 +0400</creation_ts>
          <short_desc>gear-update не работает если есть пустые каталоги</short_desc>
          <delta_ts>2008-04-25 18:07:21 +0400</delta_ts>
          <reporter_accessible>1</reporter_accessible>
          <cclist_accessible>1</cclist_accessible>
          <classification_id>4</classification_id>
          <classification>Development</classification>
          <product>Sisyphus</product>
          <component>gear</component>
          <version>unstable</version>
          <rep_platform>all</rep_platform>
          <op_sys>Linux</op_sys>
          <bug_status>CLOSED</bug_status>
          <resolution>NOTABUG</resolution>
          
          
          <bug_file_loc></bug_file_loc>
          <status_whiteboard></status_whiteboard>
          <keywords></keywords>
          <priority>P2</priority>
          <bug_severity>major</bug_severity>
          <target_milestone>---</target_milestone>
          
          
          <everconfirmed>1</everconfirmed>
          <reporter name="swi">swi</reporter>
          <assigned_to name="Alexey Gladkov">legion</assigned_to>
          <cc>evg</cc>
    
    <cc>glebfm</cc>
    
    <cc>ldv</cc>
    
    <cc>legion</cc>
    
    <cc>php-coder</cc>
    
    <cc>placeholder</cc>
    
    <cc>vvk</cc>
    
    <cc>wrar</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>68860</commentid>
    <comment_count>0</comment_count>
    <who name="swi">swi</who>
    <bug_when>2008-04-23 22:54:35 +0400</bug_when>
    <thetext>если в git репо присутствуют пустые каталоги (git их вообще не видит получается)
то gear-update не срабатывает жалуясь на то что якобы присутствуют
модифицированные или неконтролируемые git файлы. Удаление этих каталогов решает
проблему, но в tar-ball они могут присутствовать (ошметки, CVS).</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68861</commentid>
    <comment_count>1</comment_count>
    <who name="Alexey Gladkov">legion</who>
    <bug_when>2008-04-23 23:10:47 +0400</bug_when>
    <thetext>Эту проблему можно решить через --exclude или через .gitignore.

git не поддерживает пустые каталоги. Пустые каталоги это проблема, но не
проблема gear. В общем случае добавить решить эту проблему нельзя т.к. если
добавить в пустой каталог нечто, то это может создать ошибку.

Поэтому в этих случаях мантейнер должен сам решать эту проблему и решений может
быть несколько.

Так что это не бага, это фича.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68862</commentid>
    <comment_count>2</comment_count>
    <who name="swi">swi</who>
    <bug_when>2008-04-23 23:28:15 +0400</bug_when>
    <thetext>(In reply to comment #1)
&gt; git не поддерживает пустые каталоги. Пустые каталоги это проблема, но не
&gt; проблема gear. В общем случае добавить решить эту проблему нельзя т.к. если
&gt; добавить в пустой каталог нечто, то это может создать ошибку.
А может алгоритм проверки? Ведь git этих каталогов не видит не обрабатывает...
чего ж тогда gear на них реагирует? Может тоже пусть игнорирует?

</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68867</commentid>
    <comment_count>3</comment_count>
    <who name="Alexey Gladkov">legion</who>
    <bug_when>2008-04-24 00:35:43 +0400</bug_when>
    <thetext>gear-update ругается на модифицированные файлы только перед началом работы. Эта
проверка может быть отключена через --force. Эта проверка защищиает от ошибок,
когда обновляются исходники в рабочем каталоге с незакоммиченными данными.
Конечно можно в эту проверку добавить --no-empty-directory, но при наличии
--force я не вижу в этом смысла.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68871</commentid>
    <comment_count>4</comment_count>
    <who name="Andrey Rahmatullin">wrar</who>
    <bug_when>2008-04-24 08:44:06 +0400</bug_when>
    <thetext>(In reply to comment #3)
&gt; gear-update ругается на модифицированные файлы только перед началом работы. 
Эта
&gt; проверка может быть отключена через --force. Эта проверка защищиает от ошибок,
&gt; когда обновляются исходники в рабочем каталоге с незакоммиченными данными.
Ещё раз: поскольку наш любимый git не считает и не может считать пустые 
каталоги &quot;незакоммиченными данными&quot;, как и вообще данными, то почему они должны 
препятствовать обновлению?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68872</commentid>
    <comment_count>5</comment_count>
    <who name="Slava Semushin">php-coder</who>
    <bug_when>2008-04-24 08:49:33 +0400</bug_when>
    <thetext>Я вешал когда-то bug #13583 об этом же.

Не завидую судьбе этого бага -- он или INVALID или DUPLICATE..</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68891</commentid>
    <comment_count>6</comment_count>
    <who name="Alexey Gladkov">legion</who>
    <bug_when>2008-04-24 14:00:38 +0400</bug_when>
    <thetext>(In reply to comment #4)
&gt; Ещё раз: поскольку наш любимый git не считает и не может считать пустые 
&gt; каталоги &quot;незакоммиченными данными&quot;, как и вообще данными, то почему они должны 
&gt; препятствовать обновлению?

Потому что эти директории могут быть важны. То что эти директории не могут быть
добавлены это ещё не повод для того чтобы их игнорировать. gear-update не делает
предположений о назначении изменений в рабочем каталоге. Повторю комментарий из
bug #13583#c5:

У gear-update есть ключ --force на случай когда вы уверены что обновление не
удалит ничего важного или не закоммиченные данные вам не нужны.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68892</commentid>
    <comment_count>7</comment_count>
    <who name="swi">swi</who>
    <bug_when>2008-04-24 14:02:49 +0400</bug_when>
    <thetext>(In reply to comment #6)
&gt; Потому что эти директории могут быть важны. То что эти директории не могут быть
&gt; добавлены это ещё не повод для того чтобы их игнорировать.
Поэтому чтобы сделать gear-update приходится ух удалять или вносить в ignore -
т.е. игнорировать. Я чего-то недопонимаю в логике</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68893</commentid>
    <comment_count>8</comment_count>
    <who name="Alexey Gladkov">legion</who>
    <bug_when>2008-04-24 14:23:36 +0400</bug_when>
    <thetext>(In reply to comment #7)
&gt; Поэтому чтобы сделать gear-update приходится ух удалять или вносить в ignore -
&gt; т.е. игнорировать. Я чего-то недопонимаю в логике

Неправильно :)

Поэтому если вам нужно обновить директорию с незакоммиченными данными, вам нужно
выполнять gear-update c ключём --force. В этом случае gear-update обновит
директорию и удалит эти данные.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68905</commentid>
    <comment_count>9</comment_count>
    <who name="Alexey Gladkov">legion</who>
    <bug_when>2008-04-24 16:11:49 +0400</bug_when>
    <thetext>Вообщем, это документированное поведение и есть документированное решение:

$ gear-update --help |grep -A1 -- --force
  -f,--force          remove files from &lt;subdirectory&gt; even
                      if untracked or modified files found;

Также есть другие решения этой же проблемы.

Resolution =&gt; INVALID</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68906</commentid>
    <comment_count>10</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2008-04-24 16:21:26 +0400</bug_when>
    <thetext>(In reply to comment #1)
&gt; Эту проблему можно решить через --exclude или через .gitignore.
&gt; 
&gt; git не поддерживает пустые каталоги. Пустые каталоги это проблема, но не
&gt; проблема gear. В общем случае добавить решить эту проблему нельзя т.к. если
&gt; добавить в пустой каталог нечто, то это может создать ошибку.

А, может быть, просто удалять пустые каталоги, не спрашивая пользователя, нужны
они ему или нет?

find -type d -empty -delete
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68907</commentid>
    <comment_count>11</comment_count>
    <who name="Alexey Gladkov">legion</who>
    <bug_when>2008-04-24 16:31:46 +0400</bug_when>
    <thetext>А ты можешь с уверенностью сказать что этот каталог в &lt;subdirectory&gt; не был
сделан с каким-то смыслом ?

Тогда уж можно проще сделать: добавить к git-ls-files ключ --no-empty-directory.
Всё равно в этом каталоге все данные будут потеряны и незачем удалять что-либо
до полного удаления.

Но мне бы очень не хотелось удалять _любые_ несохранёные данные в &lt;subdirectory&gt;
без явного согласия пользователя.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68908</commentid>
    <comment_count>12</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2008-04-24 16:34:37 +0400</bug_when>
    <thetext>(In reply to comment #11)
&gt; А ты можешь с уверенностью сказать что этот каталог в &lt;subdirectory&gt; не был
&gt; сделан с каким-то смыслом ?

Как правило, да, но в gear-srpmimport я сделал в точности наоборот. :)
Вот упрощённая цитата оттуда:

# Add empty .gitignore file to each empty directory.
find -type d -empty -exec touch -- &apos;{}/.gitignore&apos; &apos;;&apos;
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>68909</commentid>
    <comment_count>13</comment_count>
    <who name="Alexey Gladkov">legion</who>
    <bug_when>2008-04-24 16:45:51 +0400</bug_when>
    <thetext>(In reply to comment #12)
&gt; # Add empty .gitignore file to each empty directory.
&gt; find -type d -empty -exec touch -- &apos;{}/.gitignore&apos; &apos;;&apos;

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

Кстати, ты поднял интересный вопрос: когда gear-update обновляет каталог из
архива, то в архиве запросто могут быть пустые каталоги, которые не попадут в
репозиторий. И тут я согласен, что стоит делать как gear-srpmimport. Но эта бага
уже другая история.</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>