Re: qt5- prefix

2015-01-17 Thread Lawrence Velázquez
On Jan 17, 2015, at 4:09 AM, René J.V. Bertin  wrote:

> On Saturday January 17 2015 00:14:09 Mojca Miklavec wrote:
> 
>> I don't know what exactly QtCurve does, so I find it a bit difficult
>> to judge to which category it belongs and whether a prefix is
>> justified in that case.
> 
> It's a theme (or style, in Qt speak). As such, it's in a category that 
> corresponds to the one you would consider appropriate for a prefix, it seems.

There's some precedent for this usage; see `port search theme`.

vq
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-17 Thread Lawrence Velázquez
On Jan 17, 2015, at 4:09 AM, René J.V. Bertin  wrote:

> There's a difference between ports for which Qt represents an optional 
> dependency, and ports that cannot live without it. Let's face it, a Qt app 
> isn't so very different from a Python or Perl app: it simply extends what the 
> base technology already has to offer (and yes I'm aware that Qt is a library 
> and not a runtime environment). 
> And again, ports building on Python and Perl are pyXY-foo or px.yz-foo .

This is incorrect. `py-foo` and `p5-foo` are only used for Python and Perl 
modules that can be imported and used by other programs. Applications that are 
merely written in Python and Perl (e.g., `trac`, `ack`) should NOT have a 
prefix.

vq
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-17 Thread René J . V . Bertin
On Saturday January 17 2015 12:02:26 Marko Käning wrote:

> > I have a somewhat strong feeling against using the prefix for Qt
> > applications.
> +1
> > could be downloaded from the Nokia website, maybe a bit more), but I
> > would never use something like qt5-gnuplot or qt5-wireshark.
> +1

I'd prefer the Qt4 versions too O:^)

Seriously, it'd be constructive to propose an alternative way of providing Qt4 
and Qt5 versions of ports for applications that can be built atop either 
version (i.e. that don't provide an *optional* Qt-based backend, which would be 
provided through a variant).
NB: wireshark apparently cannot be built against Qt 5 yet.

R.


___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-17 Thread Marko Käning
> I have a somewhat strong feeling against using the prefix for Qt
> applications.

+1


> I would use a prefix for ports and modules that are
> strictly related to Qt, for example qt5-widgets, qt5-webkit,
> qt5-sensors, qt5-bluetooth, qt5-doc, ... (basically anything that
> could be downloaded from the Nokia website, maybe a bit more), but I
> would never use something like qt5-gnuplot or qt5-wireshark.

+1
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-16 Thread Mojca Miklavec
On Fri, Jan 16, 2015 at 4:11 PM, René J.V. wrote:
>
> I only picked the qt5- prefix because there's some precedence, though 
> admittedly Qt Creator has a qt4- prefix for the Qt4 version.
> Similarly, GTk ports indeed have -gtk2 or -gtk3 suffixes ... though there it 
> might be more usual to have a GTk2 dependency be the implicit default.
>
>> I find the "qt5-" prefix objectionable.
>
> Frankly, I don't know and I don't have a real preference: I'm open to 
> suggestions.
> We do have the likely situation where more and more ports will transition to, 
> or at least add support for, Qt5. As long as MacPorts doesn't provide a 
> mechanism to signal a port name change and thus let user installations go 
> from, say, QtCurve to qt4-QtCurve automatically, I don't see another solution 
> of the kind I've adopted in my 2 proposals (Charm and QtCurve).

Like other explained, you could use replaced_by to change the port
name, so you could have both qt4-qtcurve and qt5-qtcurve for example,
with qtcurve being automatically replaced by qt4-curve.

My view about prefix vs. suffix:

I have a somewhat strong feeling against using the prefix for Qt
applications. I would use a prefix for ports and modules that are
strictly related to Qt, for example qt5-widgets, qt5-webkit,
qt5-sensors, qt5-bluetooth, qt5-doc, ... (basically anything that
could be downloaded from the Nokia website, maybe a bit more), but I
would never use something like qt5-gnuplot or qt5-wireshark. Maybe
gnuplot-qt5 if it has to be, but it feels just wrong to me to prefix
random applications that only uses Qt. And honestly I would prefer to
keep using "gnuplot +qt5" rather than a separate port. This might be
different for modules/libraries/building blocks that other
applications need where you actually need to provide both versions. At
least until all other dependents upgrade to Qt 5.

I don't know what exactly QtCurve does, so I find it a bit difficult
to judge to which category it belongs and whether a prefix is
justified in that case.

But again, that's just my view.

Mojca

PS: The only reason why I didn't switch to Qt5 in one of my ports was
because Qt4 and Qt5 still conflict and I cannot afford to make my port
Qt5-only, thus conflicting with many other ports.
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-16 Thread Lawrence Velázquez
On Jan 16, 2015, at 5:09 PM, René J.V. Bertin  wrote:

> On Friday January 16 2015 16:43:45 Lawrence Velázquez wrote:
> 
>> A buildslave will not provide archives that a user could not compile 
>> themselves.
> 
> So the buildslaves for 10.6 run 10.6 themselves?

Yes.

> Does each buildslave build with the minimal OS version set to the target OS 
> version, and use the "current OS" SDK?

As far as I know, the buildslaves more or less do a `port install` with the 
default MacPorts configuration; they don't do anything out of the ordinary. So 
most C-language ports are built for deployment on the host operating system.

> Out of curiosity: If the binary packages for 10.7 are not built against the 
> 10.7 SDK, it ought to be possible to rename them and put them in the right 
> download directory on 10.6 and thus trick MacPorts into installing them, 
> which should give working apps, no?

Theoretically yes, but the Lion archives are intended to be deployed on Lion. 
If any of them were built to be deployed on 10.6, it was probably unintentional.

vq
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-16 Thread René J . V . Bertin
On Friday January 16 2015 16:43:45 Lawrence Velázquez wrote:

> > To be equally blunt: the user is always right.
> 
> This is not our general attitude towards this matter.

And I rarely work on ports that I don't use or intend to use myself, so ... :)

> We prefer users not be allowed to choose their dependencies unless there's a 
> good reason, such as API/ABI incompatibilities, or if the dependencies would 
> take a very long time to build.

Both of which apply to Qt. 

> A buildslave will not provide archives that a user could not compile 
> themselves.

So the buildslaves for 10.6 run 10.6 themselves? Does each buildslave build 
with the minimal OS version set to the target OS version, and use the "current 
OS" SDK? (I'm pretty sure I've seen the minimal OS version set to 10.6 when 
building Qt5 this week, but not the SDK of course. In fact, I had to rename the 
10.10 SDK Xcode 6.1 dumped on me to NOT build against that one... on 10.9).

Out of curiosity: If the binary packages for 10.7 are not built against the 
10.7 SDK, it ought to be possible to rename them and put them in the right 
download directory on 10.6 and thus trick MacPorts into installing them, which 
should give working apps, no?

R.
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-16 Thread Lawrence Velázquez
On Jan 16, 2015, at 4:29 PM, René J.V. Bertin  wrote:

> Bit rot, in source code?

Not literal rot, but as the operating system and developer tools move on, it 
gets more and more difficult to maintain older software that is not under 
active development.

> I frankly don't see any reason to prefer subports over independent ports; I'm 
> pretty sure the replaced_by/obsolete functionality will work fine for 
> subports too.

Subports are just an organizational tool. Once in the index, the ports created 
with the `subport` command are basically equivalent to those created at the 
"top level" of the portfiles. Replacing subports works fine.

>> To be blunt, tough.  If a user really wants 
> 
> To be equally blunt: the user is always right.

This is not our general attitude towards this matter.

>> portfile for themselves.  The port maintainer 
>> ought to pick one variant as the default.  My 
> 
> Picking a default isn't the same as imposing it, to the point of throwing in 
> an additional Qt install.
> 
> Anyway, that's up to port maintainers to decide for their ports, and not to 
> be imposed as dogma by MacPorts, IMHO.

We prefer users not be allowed to choose their dependencies unless there's a 
good reason, such as API/ABI incompatibilities, or if the dependencies would 
take a very long time to build.

(For instance, if llvm-* didn't take so long to build, we'd probably make ld64 
and cctools rely on a single version instead of providing variants.)

> Building on 10.6 is (neigh) impossible, but you can build on 10.7+ (or just 
> 10.7?) with backward compatibility for 10.6, and then deploy to 10.6 . I've 
> tested that by using Digia's Qt5 installed on a 10.9 VM and then copying the 
> install dir to my 10.6.8 host. Works fine.
> 
> I'm not sure how that'd work out for the buildbots though ...

A buildslave will not provide archives that a user could not compile themselves.

vq
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-16 Thread René J . V . Bertin
On Friday January 16 2015 14:52:35 Craig Treleaven wrote:

> The replaced_by keyword (and obsolete PortGroup) support what you've 
> described:
> 
> https://guide.macports.org/#development.practices.rename-replace-port

Interesting. 

> Qt4 (or just bit rot) are going to push projects 

Bit rot, in source code? If Qt3's continued survival is any indication, Qt4 
will continue to see some form of maintenance for a long time.

> to give up on Qt4.  IOW, sub-ports or variants 
> for Qt4/Qt5 should be unusual exceptions rather 
> than the norm.  Pick the right time and make the 

I frankly don't see any reason to prefer subports over independent ports; I'm 
pretty sure the replaced_by/obsolete functionality will work fine for subports 
too.

> move.  Use a -devel port if experimentation is 
> required in the interim.

In fact, -devel ports are commonly used to test a newer version of the port 
itself, not of some API it depends on.

Besides, there's precedence from the GTk, Python and Perl ports.

> >version-agnostic Qt PortGroup that could even 
> >include the version-specific PortGroup, though.
> 
> Could you clarify what you mean here?

Forget it, that was a little too wild an idea. I thought one could come up with 
some kind of common denominator PortGroup to ease the transition, but if so I 
need to think it over more.

> >If you accept that detection of the installed 
> >version is done automatically, yes. But when you 
> >do that, how do you handle the case the user has 
> >both Qt versions installed? Even if you as a 
> >port developer (knowing the port and all) have a 
> >preference, the user might not agree.
> 
> To be blunt, tough.  If a user really wants 

To be equally blunt: the user is always right.

> portfile for themselves.  The port maintainer 
> ought to pick one variant as the default.  My 

Picking a default isn't the same as imposing it, to the point of throwing in an 
additional Qt install.

Anyway, that's up to port maintainers to decide for their ports, and not to be 
imposed as dogma by MacPorts, IMHO.

> I see the Qt5 supports OS X 10.7 and later ('best 
> efforts' for 10.6, if I read it right):

Building on 10.6 is (neigh) impossible, but you can build on 10.7+ (or just 
10.7?) with backward compatibility for 10.6, and then deploy to 10.6 . I've 
tested that by using Digia's Qt5 installed on a 10.9 VM and then copying the 
install dir to my 10.6.8 host. Works fine.

I'm not sure how that'd work out for the buildbots though ...


> For some ports, if the maintainer wants to keep 
> it running on old OS X versions, they might use 
> Qt4 for older OS environments and Qt5 for newer. 
> Not a variant, just do the right thing in the 
> environment.

R.
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-16 Thread Craig Treleaven

At 4:11 PM +0100 1/16/15, René J.V. Bertin wrote:

On Friday January 16 2015 08:27:18 Craig Treleaven wrote:

IIUC, your post isn't related to Qt4/5 
co-installability, but to how Qt-specific 
versions of ports distinguish themselves.



 https://trac.macports.org/ticket/46575

 If I understand correctly, Charm will create subports ala:

 qt5-charm
 charm


Yes.


 Is this supposed to be a model for going forward?


No idea.

I only picked the qt5- prefix because there's 
some precedence, though admittedly Qt Creator 
has a qt4- prefix for the Qt4 version.
Similarly, GTk ports indeed have -gtk2 or -gtk3 
suffixes ... though there it might be more usual 
to have a GTk2 dependency be the implicit 
default.



 I find the "qt5-" prefix objectionable.


Frankly, I don't know and I don't have a real 
preference: I'm open to suggestions.
We do have the likely situation where more and 
more ports will transition to, or at least add 
support for, Qt5. As long as MacPorts doesn't 
provide a mechanism to signal a port name change 
and thus let user installations go from, say, 
QtCurve to qt4-QtCurve automatically, I don't 
see another solution of the kind I've adopted in 
my 2 proposals (Charm and QtCurve).


The replaced_by keyword (and obsolete PortGroup) support what you've described:

https://guide.macports.org/#development.practices.rename-replace-port



 > Going forward, I believe we will have the following cases:

 1) Projects that work with Qt4 but not Qt5
 2) Projects that work with Qt5 but not Qt4
 3) Projects that work with either Qt4 or Qt5 but differ in non-trivial ways
 4) Projects that work with the same with Qt4 or Qt5

 Assuming we have co-installable Qt4 and Qt5 via
 MacPorts, cases 1), 2) and 4) are
 straightforward:  'port:' style dependencies for
 1) and 2) and 'path:' style for 4).


AFAIC, case 4) ports will either impose a choice 
(port: style dependency) or leave choice to the 
user, as I did with Charm.


As port maintainers, I believe we _should_ make 
choices on behalf of users.  Case by case, 
revision by revision, if there is a choice 
between Qt4 and Qt5, the port maintainer should 
evaluating whether to stay with Qt4 or jump to 5. 
At some point, I suspect security problems with 
Qt4 (or just bit rot) are going to push projects 
to give up on Qt4.  IOW, sub-ports or variants 
for Qt4/Qt5 should be unusual exceptions rather 
than the norm.  Pick the right time and make the 
move.  Use a -devel port if experimentation is 
required in the interim.


There is something to say with providing a 
version-agnostic Qt PortGroup that could even 
include the version-specific PortGroup, though.


Could you clarify what you mean here?


 > OTOH, there might be rare cases where users might

 need to choose between the Qt4 version (more
 compatible, say) and a Qt5 version (new
 features).  Qt4/Qt5 variants would then be
 appropriate.


If you accept that detection of the installed 
version is done automatically, yes. But when you 
do that, how do you handle the case the user has 
both Qt versions installed? Even if you as a 
port developer (knowing the port and all) have a 
preference, the user might not agree.


To be blunt, tough.  If a user really wants 
another configuration, they can create a modified 
portfile for themselves.  The port maintainer 
ought to pick one variant as the default.  My 
impression is that the vast majority of installs 
use only the default variants.  We shouldn't shy 
away from the doing the right thing for (the 
majority of) our users.


I see the Qt5 supports OS X 10.7 and later ('best 
efforts' for 10.6, if I read it right):


http://doc.qt.io/qt-5/osx.html

For some ports, if the maintainer wants to keep 
it running on old OS X versions, they might use 
Qt4 for older OS environments and Qt5 for newer. 
Not a variant, just do the right thing in the 
environment.


Craig
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev


Re: qt5- prefix

2015-01-16 Thread René J . V . Bertin
On Friday January 16 2015 08:27:18 Craig Treleaven wrote:

IIUC, your post isn't related to Qt4/5 co-installability, but to how 
Qt-specific versions of ports distinguish themselves.

> https://trac.macports.org/ticket/46575
> 
> If I understand correctly, Charm will create subports ala:
> 
> qt5-charm
> charm

Yes.

> Is this supposed to be a model for going forward? 

No idea.

I only picked the qt5- prefix because there's some precedence, though 
admittedly Qt Creator has a qt4- prefix for the Qt4 version.
Similarly, GTk ports indeed have -gtk2 or -gtk3 suffixes ... though there it 
might be more usual to have a GTk2 dependency be the implicit default.

> I find the "qt5-" prefix objectionable.

Frankly, I don't know and I don't have a real preference: I'm open to 
suggestions.
We do have the likely situation where more and more ports will transition to, 
or at least add support for, Qt5. As long as MacPorts doesn't provide a 
mechanism to signal a port name change and thus let user installations go from, 
say, QtCurve to qt4-QtCurve automatically, I don't see another solution of the 
kind I've adopted in my 2 proposals (Charm and QtCurve).

R.


> Going forward, I believe we will have the following cases:
> 1) Projects that work with Qt4 but not Qt5
> 2) Projects that work with Qt5 but not Qt4
> 3) Projects that work with either Qt4 or Qt5 but differ in non-trivial ways
> 4) Projects that work with the same with Qt4 or Qt5
> 
> Assuming we have co-installable Qt4 and Qt5 via 
> MacPorts, cases 1), 2) and 4) are 
> straightforward:  'port:' style dependencies for 
> 1) and 2) and 'path:' style for 4).

AFAIC, case 4) ports will either impose a choice (port: style dependency) or 
leave choice to the user, as I did with Charm.
There is something to say with providing a version-agnostic Qt PortGroup that 
could even include the version-specific PortGroup, though.

> OTOH, there might be rare cases where users might 
> need to choose between the Qt4 version (more 
> compatible, say) and a Qt5 version (new 
> features).  Qt4/Qt5 variants would then be 
> appropriate.

If you accept that detection of the installed version is done automatically, 
yes. But when you do that, how do you handle the case the user has both Qt 
versions installed? Even if you as a port developer (knowing the port and all) 
have a preference, the user might not agree.

R.
___
macports-dev mailing list
macports-dev@lists.macosforge.org
https://lists.macosforge.org/mailman/listinfo/macports-dev