[devel] U: Безусловный LC_ALL=C в /usr/lib/rpm/functions

Ivan A. Melnikov iv на altlinux.org
Пт Фев 22 10:07:24 MSK 2013


2013/2/20 Aleksey Avdeev <solo на solin.spb.ru>:
> 20.02.2013 10:25, Ivan A. Melnikov пишет:
[...]
>
>> Мне кажется, надо учить
>> 096-bytecompile_python3.brp понимать -*- encoding: ... -*-, и
>> использовать utf-8 по умолчанию.
>
>   Кто возьмётся за отображение множества python`их лангов на системное?
> Насколько я знаю, они перекликаются, но не совпадают.

Это и не обязательно, имхо локаль вообще трогать не нужно, нужно
трогать /usr/lib/rpm/python3.compileall.py.

Вот traceback  из логов сборки:

Traceback (most recent call last):
  File "/usr/lib/rpm/python3.compileall.py", line 131, in <module>
    exit_status = bool(main())
  File "/usr/lib/rpm/python3.compileall.py", line 128, in main
    return compile_path(**dopt)
  File "/usr/lib/rpm/python3.compileall.py", line 93, in compile_path
    compile_all(join_prefix(prefix,item),[join_prefix(prefix,x) for x
in exclude],deep,skip_x,clean,prefix)
  File "/usr/lib/rpm/python3.compileall.py", line 81, in compile_all
    compile_all(p,exclude,deep-1,skip_x,clean,prefix)
  File "/usr/lib/rpm/python3.compileall.py", line 81, in compile_all
    compile_all(p,exclude,deep-1,skip_x,clean,prefix)
  File "/usr/lib/rpm/python3.compileall.py", line 84, in compile_all
    if not (skip_x and executable(p)) :
  File "/usr/lib/rpm/python3.compileall.py", line 60, in executable
    line = open(file).readline()
  File "/usr/lib/python3.3/encodings/ascii.py", line 26, in decode
    return codecs.ascii_decode(input, self.errors)[0]
UnicodeDecodeError: 'ascii' codec can't decode byte 0xc2 in position
14: ordinal not in range(128)
error: Bad exit status from /usr/src/tmp/rpm-tmp.41412 (%install)

Посмотрим на /usr/lib/rpm/python3.compileall.py, строку 60

http://git.altlinux.org/people/solo/packages/?p=rpm-build-python3.git;a=blob;f=rpm-build-python3/python3.compileall.py;h=3c8fb4e3023d686d926b43744bc8a6ee3d0896ff;hb=0d8ba0d9dff3be076604aa59accd673cd7056f71#l57

  57 def executable(file):
  58     import stat
  59     if stat.S_IEXEC & (os.stat(file)[stat.ST_MODE]) :
  60         line = open(file).readline()
  61         if "#!" == line[:2] :
  62             return 1

То есть, LANG вообще не нужен, нужно передать правильный encoding в
стандартный питоновский open. Я подозреваю, что если заменить строку
60 на

  60         line = open(file, encoding='utf-8').readline()

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

Ещё более правильным решением будет работать с файлами так, как это
делает сам питон (см tokenize.py, там есть и функция detect_encoding):

http://git.altlinux.org/people/solo/packages/python3.git?p=python3.git;a=blob;f=python3/Lib/tokenize.py;h=d669412db3eb0c7eb89c316acec89d4acb541380;hb=20543a67c862d487199f572f29e9b9a67aafdb06

Если никто не сделает раньше, попробую за выходные предложить решение.

Так что не трогайте локаль, она не виновата.

[...]
>
>   Но как, опять таки, показала практика, в стадо python пакетов
> затесалась минимум одна паршивая овца: UTF8 на этапе байткомпиляции
> нужен как минимум для python3-module-pycairo.

Внезапно, крамольная мысль: пропатчить pycairo при помощи sed
's/©/(c)/g'  и спокойно жить дальше с существующей локалью и
rpm-build-python3. Пока овца одна ;)

-- 
WBR,
Ivan A. Melnikov


Подробная информация о списке рассылки Devel