Remove the resource-path file

Attempt to derive the resource path from the package path assuming that
one of the three main installation schemes has been used.

The package path will be one of the following:

  <prefix>/lib/pythonX.Y/site-packages
  <prefix>\Lib\site-packages

  <home>/lib/python

  <userbase>/lib/pythonX.Y/site-packages
  <userbase>\PythonXY\site-packages

  Where <prefix>, <home> and <userbase> are the resource paths used in the
  Prefix, Home and User installation schemes.

The use of the command line option "--install-data" in the setup script
is no longer supported.

This change is intended to allow a Gramps core package to be created
as a wheel and installed via pip.
This commit is contained in:
Nick Hall 2020-08-24 19:22:18 +01:00
parent 8ffb544b2c
commit 3ca82e2ebc
2 changed files with 45 additions and 50 deletions

View File

@ -2,6 +2,7 @@
# Gramps - a GTK+/GNOME based genealogy program # Gramps - a GTK+/GNOME based genealogy program
# #
# Copyright (C) 2013 John Ralls <jralls@ceridwen.us> # Copyright (C) 2013 John Ralls <jralls@ceridwen.us>
# Copyright (C) 2020 Nick Hall <nick-h@gramps-project.org>
# #
# This program is free software; you can redistribute it and/or modify # This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by # it under the terms of the GNU General Public License as published by
@ -35,6 +36,25 @@ class ResourcePath:
It should be called only by const.py; other code should retrieve the It should be called only by const.py; other code should retrieve the
paths from there. paths from there.
Attempt to derive the resource path from the package path assuming that
one of the three main installation schemes has been used.
The package path will be one of the following:
<prefix>/lib/pythonX.Y/site-packages
<prefix>\Lib\site-packages
<home>/lib/python
<userbase>/lib/pythonX.Y/site-packages
<userbase>\PythonXY\site-packages
Where <prefix>, <home> and <userbase> are the resource paths used in the
Prefix, Home and User installation schemes.
The use of the command line option "--install-data" in the setup script
is no longer supported.
""" """
instance = None instance = None
def __new__(cls): def __new__(cls):
@ -47,9 +67,9 @@ class ResourcePath:
def __init__(self): def __init__(self):
if self.initialized: if self.initialized:
return return
resource_file = os.path.join(os.path.abspath(os.path.dirname( package_path = os.path.abspath(os.path.join(os.path.dirname(
__file__)), 'resource-path') __file__), '..', "..", ".."))
installed = os.path.exists(resource_file) installed = not os.path.exists(os.path.join(package_path, '.git'))
if installed: if installed:
test_path = os.path.join("gramps", "authors.xml") test_path = os.path.join("gramps", "authors.xml")
else: else:
@ -59,26 +79,29 @@ class ResourcePath:
if (tmp_path and os.path.exists(os.path.join(tmp_path, test_path))): if (tmp_path and os.path.exists(os.path.join(tmp_path, test_path))):
resource_path = tmp_path resource_path = tmp_path
elif installed: elif installed:
try: base_path = None
with open(resource_file, encoding='utf-8', head, tail = os.path.split(package_path)
errors='strict') as fp: if tail in ('site-packages', 'dist-packages'):
resource_path = fp.readline() # Prefix or User installation scheme
except UnicodeError as err: head, tail = os.path.split(head)
LOG.exception("Encoding error while parsing resource path", err) if tail.startswith('python'):
sys.exit(1) base_path, tail = os.path.split(head)
except IOError as err: elif tail == 'Lib' or tail.startswith('Python'):
LOG.exception("Failed to open resource file", err) base_path = head
sys.exit(1) elif tail == 'python':
if not os.path.exists(os.path.join(resource_path, test_path)): # Home installation scheme
LOG.error("Resource Path %s is invalid", resource_path) base_path, tail = os.path.split(head)
if base_path is not None:
resource_path = os.path.join(base_path, 'share')
else:
LOG.error("Unable to determine resource path")
sys.exit(1) sys.exit(1)
else: else:
# Let's try to run from source without env['GRAMPS_RESOURCES']: # Let's try to run from source without env['GRAMPS_RESOURCES']:
resource_path = os.path.join(os.path.abspath(os.path.dirname( resource_path = package_path
__file__)), '..', "..", "..")
test_path = os.path.join("data", "authors.xml")
if (not os.path.exists(os.path.join(resource_path, test_path))): if (not os.path.exists(os.path.join(resource_path, test_path))):
LOG.error("Unable to determine resource path") LOG.error("Resource Path %s is invalid", resource_path)
sys.exit(1) sys.exit(1)
resource_path = os.path.abspath(resource_path) resource_path = os.path.abspath(resource_path)

View File

@ -36,7 +36,6 @@ from distutils import log
from distutils.core import setup, Command from distutils.core import setup, Command
from distutils.util import convert_path, newer from distutils.util import convert_path, newer
from distutils.command.build import build as _build from distutils.command.build import build as _build
from distutils.command.install import install as _install
import os import os
import glob import glob
import codecs import codecs
@ -60,19 +59,10 @@ if svem_flag in sys.argv:
# Die, setuptools, die. # Die, setuptools, die.
sys.argv.remove(svem_flag) sys.argv.remove(svem_flag)
# check if the resourcepath option is used and store the path
# this is for packagers that build out of the source tree
# other options to setup.py are passed through
resource_path = ''
packaging = False
argparser = argparse.ArgumentParser(add_help=False) argparser = argparse.ArgumentParser(add_help=False)
argparser.add_argument("--resourcepath", dest="resource_path")
argparser.add_argument("--no-compress-manpages", dest="no_compress_manpages", argparser.add_argument("--no-compress-manpages", dest="no_compress_manpages",
action="store_true") action="store_true")
args, passthrough = argparser.parse_known_args() args, passthrough = argparser.parse_known_args()
if args.resource_path:
resource_path = args.resource_path
packaging = True
sys.argv = [sys.argv[0]] + passthrough sys.argv = [sys.argv[0]] + passthrough
def intltool_version(): def intltool_version():
@ -273,22 +263,6 @@ class build(_build):
build_intl(self) build_intl(self)
_build.run(self) _build.run(self)
class install(_install):
"""Custom install command."""
def run(self):
resource_file = os.path.join(os.path.dirname(__file__), 'gramps', 'gen',
'utils', 'resource-path')
with open(resource_file, 'w', encoding='utf-8', errors='strict') as fp:
if packaging:
path = resource_path
else:
path = os.path.abspath(os.path.join(self.install_data, 'share'))
fp.write(path)
_install.run(self)
os.remove(resource_file)
class test(Command): class test(Command):
"""Command to run Gramps unit tests""" """Command to run Gramps unit tests"""
description = "run all unit tests" description = "run all unit tests"
@ -409,8 +383,6 @@ for (dirpath, dirnames, filenames) in os.walk(basedir):
package_data_core.append(dirpath[7:] + '/' + dirname + '/*.xml') package_data_core.append(dirpath[7:] + '/' + dirname + '/*.xml')
package_data_core.append(dirpath[7:] + '/' + dirname + '/*.ini') package_data_core.append(dirpath[7:] + '/' + dirname + '/*.ini')
package_data_core.append('gen/utils/resource-path')
package_data_gui = ['gui/glade/*.glade'] package_data_gui = ['gui/glade/*.glade']
package_data = package_data_core + package_data_gui package_data = package_data_core + package_data_gui
@ -488,7 +460,7 @@ setup(name = 'gramps',
url = 'http://gramps-project.org', url = 'http://gramps-project.org',
license = 'GPL v2 or greater', license = 'GPL v2 or greater',
platforms = ['FreeBSD', 'Linux', 'MacOS', 'Windows'], platforms = ['FreeBSD', 'Linux', 'MacOS', 'Windows'],
cmdclass = {'build': build, 'install': install, 'test': test}, cmdclass = {'build': build, 'test': test},
packages = packages, packages = packages,
package_data = {'gramps': package_data}, package_data = {'gramps': package_data},
data_files = data_files, data_files = data_files,