Questions about packaging Python modules in Ports Collection
Marcus von Appen
mva at FreeBSD.org
Fri Feb 20 14:27:07 UTC 2015
On, Fri Feb 20, 2015, Matthias Petermann wrote:
> Hello,
>
> I am maintaining the Tryton ports for FreeBSD and am about to prepare
> the update from 2.8 to 3.4. Because I think there is some potential to
> improve, I would like to address some questions and ask for advice from
> the FreeBSD Python community.
>
> First, please allow me to give you some background. Tryton consists of a
> framework (client and server component), as well as a large number (67)
> of functional modules that add business domain functionality to the
> framework. All this modules together make up a comprehensive ERP
> solution. If one wants to use only a subset from them, the framework
> allows to enable / disable them on the fly, even if they all are
> installed.
>
> The framework components are located in:
>
> /usr/ports/finance/tryton28 (client)
> /usr/ports/finance/trytond28 (server)
>
> and most of the functional modules in:
>
> /usr/ports/finance/trytond28_*
>
> For each of the functional modules there is a separate port provided,
> utilizing distutils and autoplist.
>
> This works good, but I think of the following potential issues:
>
> I) Looking on this with a users eye, it doesn't make too much sense to
> install only a subset of the modules. Some don't even provide standalone
> functionality but only provide dependencies to other modules. So most
> users likely want to install the complete set of Tryton modules and turn
> them on / off in the frameworks configuration later.
>
> II) Supporting multiple Tryton versions at the same time. The Tryton
> project does a very good job in providing security fixes for legacy
> releases for a quite long period. From a users point of view it is
> desirable to have the versions introduced to Ports Collection supported
> until their upstream EOL. This is required to not force anyone to
> upgrade to the newest version each, because this is not always possible
> when running this in production. On the other hand, having at least the
> newest version available in the ports is required to keep FreeBSD
> attractive as the platform for new Tryton users.
>
> What do you think on the following?
>
> 1) Is the large number of separate modules in the sense of the
> principles of the ports collection? My observations is that this blows
> up the directory pretty much.
They do not violate the principles. I do not know enough about tryton,
but if a single module contains some critical issue, it may come in
handy to only update that seperate module, especially, if this is
according to how the upstream vendor provides updates and fixes.
> 2) Is the statement II) valid or do I overestimate the needs of the
> typical FreeBSD user base?
You do not. FreeBSD is a typical server operating system. Continuity as
well as providing long-term support for mission-critical software is
fairly common. The python bits (speaking for lang/pythonXX) are usually
offered as ports for as long as upstream offers updates and patches
(until the EOL). The same goes for other software.
> 3) Is it technically possible to bundle multiple distutils python
> modules into one port? Is there a good example you know?
In your specific case, the tryton modules are offered as seperate
distutils packages, if I understand it correctly. In my opinion,
meta-ports, which pull in the modules as run dependencies and bundle
them into useful groups, would ease the setup of an ERP system for the
user base. There are similar ports around for other software,
e.g. x11/xorg, x11/xorg-apps, etc., which pull in relevant X.org bits
and pieces to provide users a far easier way to install a fully
functional X.org environment (or parts of it).
> 4) With regards to I), is it suggested to keep the functional modules as
> separate ports, or should I apply 3) if technically possible?
See my first comment. If upstram provides them as seperate modules,
which might be updated individually within the EOL of a major release,
it would make sense to keep them as seperate ports and use meta-ports to
bundle functional parts.
> 5) In ports collection, is it allowed in a port to reference a (common)
> Makefile of another port? I have seen in NetBSDs pkgsrc for the Tryton
> port, they source common stuff like the version number of Tryton from a
> common Makefile:
>
> For example, this modules Makefile:
> http://ftp.netbsd.org/pub/pkgsrc/current/pkgsrc/finance/py-trytond-account/Makefile
> uses this:
> http://ftp.netbsd.org/pub/pkgsrc/current/pkgsrc/devel/py-trytond/Makefile.common
Yes. This is heavily used by e.g. the OpenGL and Mesa ports, PostgreSQL
and others. You should keep in mind that this also bears certain risks
(breaking all ports using that common Makefile on updates, keeping the
include order in mind, etc.). I'd rather recommend to create a tryton
Uses to be included, especially if your functional meta-ports require
bits of other functional parts. That way, you could provide functional
parts for users (meta-ports) and provide logical/technical parts
internally for all the consumers. Something like:
finance/tryton-debitor
# Provide debit functionality
USES= tryton:base,accounts,sale
finance/tryton-accounts
# Pull in all relevant accounting bits
USES= tryton:base
# Do not use USES=tryton:accounts, since this port provides it
RUN_DEPENDS= finance/tryton-account finance/tryton-account_asset ...
Mk/Uses/tryton.mk
# Similar to e.g. Uses/twisted.mk or bsd.sdl.mk, etc.pp., depending
# on the granularity.
Additionally, the Uses can be easily used by consumer ports of Tryton,
which are not maintained by yourself, providing a sort of standard
approach for other maintainers.
Cheers
Marcus
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 181 bytes
Desc: not available
URL: <http://lists.freebsd.org/pipermail/freebsd-python/attachments/20150220/1c57fddf/attachment.sig>
More information about the freebsd-python
mailing list