Easily build Portfiles from ruby gems

Paul Guyot pguyot at kallisys.net
Mon Nov 6 13:26:35 PST 2006


Le 7 nov. 06 à 01:39, John Labovitz a écrit :

> On Nov 6, 2006, at 6:40am, Paul Guyot wrote:
>
>> With such a script, there's no reason to continue to use gem to  
>> install ruby gems. Using gem may yield in inconsistencies. I know  
>> that most ruby tutorial around say: get ruby with darwinports,  
>> then use gem. But I strongly disagree. At some point, we may  
>> rename gem binary and put a fake one that displays a warning message.
>
> Please don't.
>
> I've been using native Ruby gems for at least two years with  
> MacPorts, and have had absolutely no trouble.
>
> I don't have any problem with *providing* gem ports, especially for  
> major/complex systems like ImageMagick and Rails.  I use a select  
> few rb-* gems, for their ease of installation (eg, rb- 
> imagemagick).  The combination of native and ported gems has never  
> caused me grief; on the contrary, it's been a very pleasant  
> experience.  (Yes, I realize there could be dependency issues with  
> a gem that required something installed as a port.)
>
> Besides, there are currently over a thousand gems; only ~130 of  
> those currently have ports.  Do you really suggest that we make  
> ports for every single one?  And keep them up to date?
>
> Perhaps if there are specific issues or conflicts, we could talk  
> about those and try to find a solution or a workaround. (For  
> example, I wonder whether a gem port could somehow be a wrapper  
> around the gem command; that way the user would continue to use the  
> ports system, but actually be installing native gems that were kept  
> track of.)

This is exactly what happens for a while now. That's true that only  
12 ports use this technology, but it's there and it works (including  
for rails).

If you look at rb-actionmailer, the ruby.setup line says:
ruby.setup	actionmailer 1.2.3 gem {} rubyforge:11331

It means: use the gem mechanism, get it from rubyforge, the ID is 11331.

However, the trouble with this was to get the ID. I realized that gem  
itself doesn't know about it but download from another URL. So the  
new code (available only in svn now, forthcoming in 1.3.3) works like  
this:
ruby.setup	mongrel 0.3.13.4 gem {} rubyforge_gem

I know that using gem and port at the same time is almost without any  
trouble. Gem is a good piece of code and it's behaving. The only  
issue is that gem is installing stuff in /opt/local and MacPorts  
doesn't know about it.

So from there, I think there are the following paths:
- port the one thousand or something gems to MacPorts using the  
script I wrote. It's just a matter of converting and testing.
- patch gem so it registers the files into MacPorts system.
- something between the two.

It is what FreeBSD does with CPAN as far as I know. CPAN can install  
stuff and what is installed is registered in FreeBSD database. Until  
then, it might be worth it when enough gems are made available  
through MacPorts to just rename gem command so it's still available  
and implement a fake warning one to convince ruby users to use the  
MacPort version or provides tickets so we update to the latest when  
there's a problem.

Paul
-- 
Ministre ultraplénipotentiaire en disponibilité.
Mobile. Sans baignoire fixe.
http://www.kallisys.com/
http://www-poleia.lip6.fr/~guyot/




More information about the macports-dev mailing list