[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