pyenv BUILD FAILED (Fedora 28 использует python-build 20180424) - PullRequest
0 голосов
/ 29 августа 2018

Я пытался установить python 3.7.0, и вот часть сообщения из файла журнала после сбоя сборки:

......

Python build finished successfully!
The necessary bits to build these optional modules were not found:
_dbm                  _gdbm                 _tkinter           
_uuid                 nis                                      
To find the necessary bits, look in setup.py in detect_modules() for the module's name.


The following modules found by detect_modules() in setup.py, have been
built by the Makefile instead, as configured by the Setup files:
_abc                  atexit                pwd                
time                                                           

running build_scripts
creating build/scripts-3.7
copying and adjusting /tmp/python-build.20180829114540.17502/Python-3.7.0/Tools/scripts/pydoc3 -> build/scripts-3.7
copying and adjusting /tmp/python-build.20180829114540.17502/Python-3.7.0/Tools/scripts/idle3 -> build/scripts-3.7
copying and adjusting /tmp/python-build.20180829114540.17502/Python-3.7.0/Tools/scripts/2to3 -> build/scripts-3.7
copying and adjusting /tmp/python-build.20180829114540.17502/Python-3.7.0/Tools/scripts/pyvenv -> build/scripts-3.7
changing mode of build/scripts-3.7/pydoc3 from 664 to 775
changing mode of build/scripts-3.7/idle3 from 664 to 775
changing mode of build/scripts-3.7/2to3 from 664 to 775
changing mode of build/scripts-3.7/pyvenv from 664 to 775
renaming build/scripts-3.7/pydoc3 to build/scripts-3.7/pydoc3.7
renaming build/scripts-3.7/idle3 to build/scripts-3.7/idle3.7
renaming build/scripts-3.7/2to3 to build/scripts-3.7/2to3-3.7
renaming build/scripts-3.7/pyvenv to build/scripts-3.7/pyvenv-3.7
Creating directory /home/gio/.pyenv/versions/3.7.0/bin
if test "no-framework" = "no-framework" ; then \
    /usr/bin/install -c python /home/gio/.pyenv/versions/3.7.0/bin/python3.7m; \
else \
    /usr/bin/install -c -s Mac/pythonw /home/gio/.pyenv/versions/3.7.0/bin/python3.7m; \
fi
if test "3.7" != "3.7m"; then \
    if test -f /home/gio/.pyenv/versions/3.7.0/bin/python3.7 -o -h /home/gio/.pyenv/versions/3.7.0/bin/python3.7; \
    then rm -f /home/gio/.pyenv/versions/3.7.0/bin/python3.7; \
    fi; \
    (cd /home/gio/.pyenv/versions/3.7.0/bin; ln python3.7m python3.7); \
fi
if test -f libpython3.7m.a && test "no-framework" = "no-framework" ; then \
    if test -n "" ; then \
        /usr/bin/install -c -m 555  /home/gio/.pyenv/versions/3.7.0/bin; \
    else \
        /usr/bin/install -c -m 555 libpython3.7m.a /home/gio/.pyenv/versions/3.7.0/lib/libpython3.7m.a; \
        if test libpython3.7m.a != libpython3.7m.a; then \
            (cd /home/gio/.pyenv/versions/3.7.0/lib; ln -sf libpython3.7m.a libpython3.7m.a) \
        fi \
    fi; \
    if test -n ""; then \
        /usr/bin/install -c -m 555  /home/gio/.pyenv/versions/3.7.0/lib/; \
    fi; \
else    true; \
fi
zsh:9: parse error near `fi'
make: *** [Makefile:1173: altbininstall] Error 1

После строки BUILD FAILED больше нет информации:

Я установил pyenv через

curl -L https://github.com/pyenv/pyenv-installer/raw/master/bin/pyenv-installer | bash

и установили все данные требования.

sudo yum install zlib-devel bzip2 bzip2-devel readline-devel sqlite sqlite-devel \
openssl-devel xz xz-devel libffi-devel

Также

echo 'export PYENV_ROOT="$HOME/.pyenv"' >> ~/.zshenv
echo 'export PATH="$PYENV_ROOT/bin:$PATH"' >> ~/.zshenv
echo -e 'if command -v pyenv 1>/dev/null 2>&1; then\n  eval "$(pyenv init -)"\nfi' >> ~/.zshenv

Но все равно каждый раз получайте сообщение об ошибке выше. Как мне заставить это работать?

1 Ответ

0 голосов
/ 01 сентября 2018

Проблема решена.

Каким-то образом мои /bin/sh были связаны с /usr/bin/zsh. Исправлена ​​установка Pyenv после ссылки /bin/sh обратно на /usr/bin/bash.

...