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

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

    <bug>
          <bug_id>9289</bug_id>
          
          <creation_ts>2006-03-20 19:04:05 +0300</creation_ts>
          <short_desc>некорректное удаление русских символов в однобайтной локали в терминале UTF-8</short_desc>
          <delta_ts>2012-04-08 19:53:19 +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>libreadline</component>
          <version>unstable</version>
          <rep_platform>all</rep_platform>
          <op_sys>Linux</op_sys>
          <bug_status>CLOSED</bug_status>
          <resolution>FIXED</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>
          
          <blocked>10446</blocked>
          <everconfirmed>1</everconfirmed>
          <reporter name="Anton Farygin">rider</reporter>
          <assigned_to name="Dmitry V. Levin">ldv</assigned_to>
          <cc>dottedmag</cc>
    
    <cc>glebfm</cc>
    
    <cc>mike</cc>
    
    <cc>php-coder</cc>
          
          <qa_contact>qa-sisyphus</qa_contact>

      

      

      

          <comment_sort_order>oldest_to_newest</comment_sort_order>  
          <long_desc isprivate="0" >
    <commentid>36885</commentid>
    <comment_count>0</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2006-03-20 19:04:06 +0300</bug_when>
    <thetext>Воспроизводится так:
запустить xterm в локали UTF-8, перейти на пользователя root через su -,
написать:  echo &quot;тест&quot; (тест - на русском), выполнить, нажать стрелку вверх,
удалить &quot;ст&quot;, выполнить.
Удаляется только один последний символ.
у рута локаль POSIX, система установлена в ru_RU.UTF-8. Последний Sisyphus.

[root@rider ~]# echo &quot;тест&quot;
тест
[root@rider ~]# echo &quot;те&quot;
тес</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>36886</commentid>
    <comment_count>1</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2006-03-20 19:05:34 +0300</bug_when>
    <thetext>под пользователем удаление работает нормально.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>36887</commentid>
    <comment_count>2</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2006-03-20 19:06:44 +0300</bug_when>
    <thetext>с выставленным LC_CTYPE=ru_RU.UTF-8 у рута всё работает нормально.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>36888</commentid>
    <comment_count>3</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2006-03-20 19:10:12 +0300</bug_when>
    <thetext>версия какая?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>36889</commentid>
    <comment_count>4</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2006-03-20 19:20:01 +0300</bug_when>
    <thetext>Воспроизводится с libreadline-5.1.4-alt1.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>36892</commentid>
    <comment_count>5</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2006-03-20 19:48:42 +0300</bug_when>
    <thetext>аналогичная проблема вылезает с нажатием клавиши HOME, для перехода в начало
строки при вытаскивании строки с русским текстом из HISTORY.

Только там по нажатию на HOME курсор перелезает на &lt;количество юникодных
символов в строке&quot; левее его нормального местоположения.

с LC_CTYPE, выставленным в UTF-8 локаль - также не воспроизводится.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>42132</commentid>
    <comment_count>6</comment_count>
    <who name="Michael Shigorin">mike</who>
    <bug_when>2006-11-12 20:21:27 +0300</bug_when>
    <thetext>А при чём тут тогда summary?  Локаль-то не UTF-8, а POSIX.  Бишь local
misconfiguration или бага в том, что выставило этот POSIX.  Или я опять чего-то
не понимаю?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>47539</commentid>
    <comment_count>7</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2007-03-31 23:56:14 +0400</bug_when>
    <thetext>Миша прав, речь идёт о том, что локаль однобайтная, в то время как терминал
мультибайтный.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>47554</commentid>
    <comment_count>8</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2007-04-01 01:29:53 +0400</bug_when>
    <thetext>Кстати, должно вылечиться тем же самым LC_CTYPE в en_US.UTF-8.

Вместо которого очень хотелось бы видеть у рута ru_RU.UTF-8 или то, что
выставлено в /etc/sysconfig/i18n
Ибо у некоторых не установлены никакие локали кроме ru ;)

Точнее говоря - у всех пользователей 3.0. Так что после обновления у них эта
проблема не исчезнет.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>54239</commentid>
    <comment_count>9</comment_count>
    <who name="Michael Shigorin">mike</who>
    <bug_when>2007-08-17 10:38:42 +0400</bug_when>
    <thetext>INVALID или FIXED?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>55543</commentid>
    <comment_count>10</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2007-09-20 04:25:44 +0400</bug_when>
    <thetext>Fixed by rootfiles-alt-alt9.3</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>55561</commentid>
    <comment_count>11</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2007-09-20 14:42:40 +0400</bug_when>
    <thetext>$ rpm -q rootfiles-alt
rootfiles-alt-alt9.3

на branch-4.0 у меня воспроизводится:
xterm
su -

попытка ввода и удаления русских символов в cmdline
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>55562</commentid>
    <comment_count>12</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2007-09-20 14:43:14 +0400</bug_when>
    <thetext>хотя видимо может быть нужно что-то прописать в конфиг ?

Обновление пакета поможет или нет ?
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84132</commentid>
    <comment_count>13</comment_count>
    <who name="Slava Semushin">php-coder</who>
    <bug_when>2009-01-10 01:05:53 +0300</bug_when>
    <thetext>Баг актуален?</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84155</commentid>
    <comment_count>14</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2009-01-10 02:25:22 +0300</bug_when>
    <thetext>Вполне, воспроизводится ещё проще:
LC_ALL=C bash
вводим русский текст, давим backspace до упора.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84156</commentid>
    <comment_count>15</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2009-01-10 02:39:25 +0300</bug_when>
    <thetext>(In reply to comment #14)
&gt; Вполне, воспроизводится ещё проще:
&gt; LC_ALL=C bash
&gt; вводим русский текст, давим backspace до упора.

Ну да, так воспроизводится, но зачем обманывать readline?
Так ведь работает правильно:
LC_CTYPE=$LANG LANG=C bash</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84157</commentid>
    <comment_count>16</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2009-01-10 03:01:30 +0300</bug_when>
    <thetext>Да, но под рутом не работает с таким же диагнозом.

LC_CTYPE там равен en_US.utf8, проблема воспроизводится и из под пользователя (с LC_CTYPE=en_US.utf8)
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84158</commentid>
    <comment_count>17</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2009-01-10 03:30:58 +0300</bug_when>
    <thetext>(In reply to comment #16)
&gt; Да, но под рутом не работает с таким же диагнозом.
&gt; 
&gt; LC_CTYPE там равен en_US.utf8, проблема воспроизводится и из под пользователя (с
&gt; LC_CTYPE=en_US.utf8)
&gt; 

В том то и дело, что с правильно выставленным LC_CTYPE (у нас сейчас по умолчанию en_US.utf8) никаких артефактов я не вижу.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84159</commentid>
    <comment_count>18</comment_count>
    <who name="Mikhail Gusarov">dottedmag</who>
    <bug_when>2009-01-10 03:32:43 +0300</bug_when>
    <thetext>А давайте вы оба покажете вывод locale(1) и сверите? А то обмениваетесь информацией о локалях так, будто это карты на руках и вы не хотите их раскрывать :)</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84160</commentid>
    <comment_count>19</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2009-01-10 03:38:18 +0300</bug_when>
    <thetext>О, Миша надоумил, теперь понятно в чём проблема, но непонятно как исправлять для обновляемых систем:
$ locale
locale: Cannot set LC_CTYPE to default locale: No such file or directory
locale: Cannot set LC_ALL to default locale: No such file or directory
LANG=C
LC_CTYPE=en_US.utf8
LC_NUMERIC=&quot;C&quot;
LC_TIME=&quot;C&quot;
LC_COLLATE=&quot;C&quot;
LC_MONETARY=&quot;C&quot;
LC_MESSAGES=&quot;C&quot;
LC_PAPER=&quot;C&quot;
LC_NAME=&quot;C&quot;
LC_ADDRESS=&quot;C&quot;
LC_TELEPHONE=&quot;C&quot;
LC_MEASUREMENT=&quot;C&quot;
LC_IDENTIFICATION=&quot;C&quot;
LC_ALL=

</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84161</commentid>
    <comment_count>20</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2009-01-10 03:41:16 +0300</bug_when>
    <thetext>(In reply to comment #19)
&gt; О, Миша надоумил, теперь понятно в чём проблема, но непонятно как исправлять
&gt; для обновляемых систем:
&gt; $ locale
&gt; locale: Cannot set LC_CTYPE to default locale: No such file or directory
&gt; locale: Cannot set LC_ALL to default locale: No such file or directory
&gt; LANG=C
&gt; LC_CTYPE=en_US.utf8

А в чём проблема?
$ rpmquery -f /usr/lib*/locale/en_US.utf8
glibc-locales-2.9-alt2
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84165</commentid>
    <comment_count>21</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2009-01-10 03:48:57 +0300</bug_when>
    <thetext>Явно проблема в 
$ cat /etc/rpm/macros
%_install_langs ru

Я знаю как это чинить. Не знаю как чинить для старых (когда инсталятор прописывал такое) систем.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84166</commentid>
    <comment_count>22</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2009-01-10 03:55:06 +0300</bug_when>
    <thetext>(In reply to comment #21)
&gt; Явно проблема в 
&gt; $ cat /etc/rpm/macros
&gt; %_install_langs ru
&gt; 
&gt; Я знаю как это чинить. Не знаю как чинить для старых (когда инсталятор
&gt; прописывал такое) систем.

Не помню, installer в 4.0 это ещё прописывал?
В 4.1 этого уже точно не было, см. https://bugzilla.altlinux.org/show_bug.cgi?id=14117#c14

Если всё дело в этом, то надо закрывать с resolution=NOTABUG.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84167</commentid>
    <comment_count>23</comment_count>
    <who name="Mikhail Gusarov">dottedmag</who>
    <bug_when>2009-01-10 03:58:09 +0300</bug_when>
    <thetext>Если при апгрейде 4.0-&gt;4.1 не добавлялась отсутствующая локаль, то закрывать не надо, а надо сделать добавление этой локали при апгрейде 4.1-&gt;5.0|Сизиф.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84168</commentid>
    <comment_count>24</comment_count>
    <who name="Dmitry V. Levin">ldv</who>
    <bug_when>2009-01-10 04:11:01 +0300</bug_when>
    <thetext>(In reply to comment #23)
&gt; Если при апгрейде 4.0-&gt;4.1 не добавлялась отсутствующая локаль, то закрывать не
&gt; надо, а надо сделать добавление этой локали при апгрейде 4.1-&gt;5.0|Сизиф.

Это уже совсем другая история.  Спорная, между прочим.
Ибо неясно, как отличить записанное при установке от записанного вручную.</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84169</commentid>
    <comment_count>25</comment_count>
    <who name="Mikhail Gusarov">dottedmag</who>
    <bug_when>2009-01-10 04:15:03 +0300</bug_when>
    <thetext>Ну, тогда хотя бы предупреждение вывести.

&quot;Ваш locale(1) показывает, что у вас нет локалей foo_FOO.BAR и baz_BAZ.BAZ. Возможно, это ошибка установщика &lt; 4.1. Для решения этой проблемы уберите то-то оттуда-то и сделайте такое-то приплясывание&quot;.

</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84174</commentid>
    <comment_count>26</comment_count>
    <who name="Anton Farygin">rider</who>
    <bug_when>2009-01-10 10:07:32 +0300</bug_when>
    <thetext>И куда выводить такое предупреждение ?

нужно что бы его однозначно увидел человек при обновлении - мимо не прошёл.

На мой взгляд, проще зафиксировать необходимость установки en_US в документации и радоваться жизни.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84179</commentid>
    <comment_count>27</comment_count>
    <who name="Mikhail Gusarov">dottedmag</who>
    <bug_when>2009-01-10 13:49:29 +0300</bug_when>
    <thetext>Выплёвывать из скрипта апгрейда. Насколько я помню, это считается надёжным местом, его даже GUI-фронтэнды пользователю суют.

А те, кто не смотрит на лог дист-апгрейда - те и в документацию не заглянут.
</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>84196</commentid>
    <comment_count>28</comment_count>
    <who name="Michael Shigorin">mike</who>
    <bug_when>2009-01-10 16:06:31 +0300</bug_when>
    <thetext>что-то вроде 

grep -q &apos;^%_install_langs.*en_US&apos; /etc/rpm/macros || \
sed -i &apos;s/^%_install_langs .*$/&amp;:en_US/&apos; /etc/rpm/macros &amp;&amp; \
apt-get reinstall glibc-locales</thetext>
  </long_desc><long_desc isprivate="0" >
    <commentid>130468</commentid>
    <comment_count>29</comment_count>
    <who name="Michael Shigorin">mike</who>
    <bug_when>2012-04-08 19:53:19 +0400</bug_when>
    <thetext>[root@pad ~]# echo &quot;тест&quot;
тест
[root@pad ~]# echo &quot;те&quot;
те
[root@pad ~]# locale
LANG=ru_RU.UTF-8
LC_CTYPE=uk_UA.UTF-8
LC_NUMERIC=C
LC_TIME=C
LC_COLLATE=uk_UA.UTF-8
LC_MONETARY=C
LC_MESSAGES=C
LC_PAPER=&quot;ru_RU.UTF-8&quot;
LC_NAME=&quot;ru_RU.UTF-8&quot;
LC_ADDRESS=&quot;ru_RU.UTF-8&quot;
LC_TELEPHONE=&quot;ru_RU.UTF-8&quot;
LC_MEASUREMENT=&quot;ru_RU.UTF-8&quot;
LC_IDENTIFICATION=&quot;ru_RU.UTF-8&quot;
LC_ALL=
[root@pad ~]# ls -l /root/.i18n 
-rw------- 1 root root 181 Jun 10  2010 /root/.i18n
[root@pad ~]# cat /root/.i18n
LANGUAGE=POSIX
LANG=POSIX

eval `sed -n &apos;/^LANG=[^.[:space:]]\+\.[Uu][Tt][Ff]-\?8[[:space:]]*$/ s/LANG=.*/NEED_UNICODE=1 LC_CTYPE=en_US.utf8/p&apos; /etc/sysconfig/i18n 2&gt;/dev/null` ||:
[root@pad ~]# rpm -qf /root/.i18n
rootfiles-alt-alt11
[root@pad ~]# _</thetext>
  </long_desc>
      
      

    </bug>

</bugzilla>