Как установить PYTHONPATH для поспешного пакета?

Я пытаюсь привязаться, упаковывают нечистый проект Python. Я использовал python плагин со сделанным на заказ / устанавливает сценарии.

Этот проект содержит 2 пакета Python, которые требуются для настольного приложения:

  • alfanous (API)
  • alfanous-desktop (Спокойный PySide GUI)

snapcraft.yaml файл:

name: alfanous
version: "0.7.8"
summary: Alfanous
description: GNU hello prints a friendly greeting.
  This is part of the snapcraft tour at http://snapcraft.io/create/
#confinement: strict
confinement: devmode

apps:
  alfanous-gui:
    command: usr/bin/alfanous-desktop
    #desktop: usr/share/applications/my-app.desktop
  alfanous-cli:
    command: usr/bin/alfanous-console

parts:
  alfanous-git:
    build-packages:
      #- python
      - sqlite3
      - pyside-tools
      - qt4-linguist-tools
      - python-babel
      - qt4-qmake
      - python-setuptools
      #- python-pyparsing
      #- perl
    #plugin: make
    plugin: python
    python-version: python2
    #source: https://github.com/Alfanous-team/alfanous/archive/0.7.8.tar.gz
    source: https://github.com/Alfanous-team/alfanous.git
    source-type: git
    source-depth: 1
    #source-tag: 0.7.8
    build: |
      make build
    install: |
      echo _______#######:$(pwd)
      #make install_api 
      make install_api DESTDIR=$SNAPCRAFT_PART_INSTALL
      make install_desktop DESTDIR=$SNAPCRAFT_PART_INSTALL
    stage-packages:
      - python-pyparsing
      - python-pyside
      #- epydoc
      #- sphinx
      - python-babel
      - python-setuptools
    python-packages:
      - pyparsing
      - pyside
      - babel

Поспешный пакет создан и установлен без ошибок. Однако, если я пытаюсь выполнить его:

$ alfanous.alfanous-cli
Traceback (most recent call last):
  File "/snap/alfanous/x3/usr/bin/alfanous-console", line 5, in <module>
    from pkg_resources import load_entry_point
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 2927, in <module>
    @_call_aside
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 2913, in _call_aside
    f(*args, **kwargs)
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 2940, in _initialize_master_working_set
    working_set = WorkingSet._build_master()
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 635, in _build_master
    ws.require(__requires__)
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 943, in require
    needed = self.resolve(parse_requirements(requirements))
  File "/snap/alfanous/x3/usr/lib/python2.7/dist-packages/pkg_resources/__init__.py", line 829, in resolve
    raise DistributionNotFound(req, requirers)
pkg_resources.DistributionNotFound: The 'alfanous==0.7.29' distribution was not found and is required by the application

Мой первый подозреваемый незавершен PYTHONPATH, попытка отладить:

snap run --shell alfanous.alfanous-cli
env | grep -i python

ничего не приносит.

и оба пакета там:

$ ls /snap/alfanous/current/usr/lib/python2.7/site-packages/
alfanous                        alfanousDesktop
alfanous-0.7.29-py2.7.egg-info  alfanousDesktop-0.7.29-py2.7.egg-info

Как я мог установить PYTHONPATH правильно? Разве плагин Python не должен заботиться об этом?

Ubuntu 16.04.2 snapcraft v2.28 LTS 64 бита

3
задан 18 April 2017 в 16:27

1 ответ

Я изменил alfanous-console, чтобы распечатать sys.path и восстановить снимок:

['/snap/alfanous/x4/usr/bin',
 '/snap/alfanous/x4/usr/lib/python2.7',
 '/snap/alfanous/x4/usr/lib/python2.7/plat-x86_64-linux-gnu',
 '/snap/alfanous/x4/usr/lib/python2.7/lib-tk',
 '/snap/alfanous/x4/usr/lib/python2.7/lib-old',
 '/snap/alfanous/x4/usr/lib/python2.7/lib-dynload',
 '/snap/alfanous/x4/usr/lib/python2.7/dist-packages']

Это кажется ясным эти snap, не включает site-packages в PYTHONPATH, где мой целевой пакет устанавливает себя.

  • , Таким образом, я должен изменить его путь установки
  • Или сообщить, что это привязывает команду для добавления usr/lib/python2.7/site-packages

    Связанный отчет об ошибках № 1670749: классическое заключение требует вручную установки PATH и PYTHONPATH

    , предложенное решение там не работало:

    apps:
      alfanous-gui:
        command: usr/bin/alfanous-desktop
        environment:
          PATH: $SNAP/usr/bin:$SNAP/bin/:$PATH
          PYTHONPATH: $SNAP/usr/lib/python2.7/site-packages:$SNAP/usr/lib/python2.7/dist-packages:$PYTHONPATH
        #desktop: usr/share/applications/my-app.desktop
      alfanous-cli:
        command: usr/bin/alfanous-console
        environment:
          PATH: $SNAP/usr/bin:$SNAP/bin/:$PATH
          PYTHONPATH: $SNAP/usr/lib/python2.7/site-packages:$SNAP/usr/lib/python2.7/dist-packages:$PYTHONPATH
    

    Из-за того странного пути, указывающего для хостинга /home папка

    ['/snap/alfanous/x7/usr/bin',
     '/snap/alfanous/x7/usr/lib/python2.7/site-packages',
     '/snap/alfanous/x7/usr/lib/python2.7/dist-packages',
     '/usr/lib/python2.7/site-packages',
     '/usr/lib/python2.7/dist-packages',
     '/home/sneetsher/Desktop/sandbox/alfanous-snap',
     '/snap/alfanous/x7/usr/lib/python2.7',
     '/snap/alfanous/x7/usr/lib/python2.7/plat-x86_64-linux-gnu',
     '/snap/alfanous/x7/usr/lib/python2.7/lib-tk',
     '/snap/alfanous/x7/usr/lib/python2.7/lib-old',
     '/snap/alfanous/x7/usr/lib/python2.7/lib-dynload']
    
1
ответ дан 1 December 2019 в 17:30

Другие вопросы по тегам:

Похожие вопросы: