Split out binaries.
This commit is contained in:
parent
e103194e1a
commit
217e87a3a8
3 changed files with 56 additions and 9 deletions
|
@ -64,12 +64,8 @@ class UpstreamRequirement(object):
|
||||||
|
|
||||||
class UpstreamOutput(object):
|
class UpstreamOutput(object):
|
||||||
|
|
||||||
def __init__(self, family, name):
|
def __init__(self, family):
|
||||||
self.family = family
|
self.family = family
|
||||||
self.name = name
|
|
||||||
|
|
||||||
def __repr__(self):
|
|
||||||
return "%s(%r, %r)" % (type(self).__name__, self.family, self.name)
|
|
||||||
|
|
||||||
def get_declared_dependencies(self):
|
def get_declared_dependencies(self):
|
||||||
raise NotImplementedError(self.get_declared_dependencies)
|
raise NotImplementedError(self.get_declared_dependencies)
|
||||||
|
|
|
@ -23,7 +23,11 @@ import re
|
||||||
from typing import Optional
|
from typing import Optional
|
||||||
import warnings
|
import warnings
|
||||||
|
|
||||||
from . import shebang_binary, UpstreamOutput, UnidentifiedError
|
from . import shebang_binary, UnidentifiedError
|
||||||
|
from .outputs import (
|
||||||
|
BinaryOutput,
|
||||||
|
PythonPackageOutput,
|
||||||
|
)
|
||||||
from .requirements import (
|
from .requirements import (
|
||||||
BinaryRequirement,
|
BinaryRequirement,
|
||||||
PythonPackageRequirement,
|
PythonPackageRequirement,
|
||||||
|
@ -202,12 +206,12 @@ class SetupPy(BuildSystem):
|
||||||
if self.result is None:
|
if self.result is None:
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
for script in self.result.scripts or []:
|
for script in self.result.scripts or []:
|
||||||
yield UpstreamOutput("binary", os.path.basename(script))
|
yield BinaryOutput(os.path.basename(script))
|
||||||
entry_points = getattr(self.result, 'entry_points', None) or {}
|
entry_points = getattr(self.result, 'entry_points', None) or {}
|
||||||
for script in entry_points.get("console_scripts", []):
|
for script in entry_points.get("console_scripts", []):
|
||||||
yield UpstreamOutput("binary", script.split("=")[0])
|
yield BinaryOutput(script.split("=")[0])
|
||||||
for package in self.result.packages or []:
|
for package in self.result.packages or []:
|
||||||
yield UpstreamOutput("python3", package)
|
yield PythonPackageOutput(package, python_version="cpython3")
|
||||||
|
|
||||||
|
|
||||||
class PyProject(BuildSystem):
|
class PyProject(BuildSystem):
|
||||||
|
|
47
ognibuild/outputs.py
Normal file
47
ognibuild/outputs.py
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
#!/usr/bin/python
|
||||||
|
# Copyright (C) 2019-2020 Jelmer Vernooij <jelmer@jelmer.uk>
|
||||||
|
# encoding: utf-8
|
||||||
|
#
|
||||||
|
# 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
|
||||||
|
# the Free Software Foundation; either version 2 of the License, or
|
||||||
|
# (at your option) any later version.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
|
||||||
|
from . import UpstreamOutput
|
||||||
|
|
||||||
|
|
||||||
|
class BinaryOutput(UpstreamOutput):
|
||||||
|
|
||||||
|
def __init__(self, name):
|
||||||
|
super(BinaryOutput, self).__init__('binary')
|
||||||
|
self.name = name
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return "%s(%r)" % (type(self).__name__, self.name)
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return "binary: %s" % self.name
|
||||||
|
|
||||||
|
|
||||||
|
class PythonPackageOutput(UpstreamOutput):
|
||||||
|
|
||||||
|
def __init__(self, name, python_version=None):
|
||||||
|
super(PythonPackageOutput, self).__init__('python-package')
|
||||||
|
self.name = name
|
||||||
|
self.python_version = python_version
|
||||||
|
|
||||||
|
def __str__(self):
|
||||||
|
return "python package: %s" % self.name
|
||||||
|
|
||||||
|
def __repr__(self):
|
||||||
|
return "%s(%r, python_version=%r)" % (
|
||||||
|
type(self).__name__, self.name, self.python_version)
|
Loading…
Add table
Add a link
Reference in a new issue