Project

General

Profile

Actions

Backport #6807

closed

Can't compile ruby without ruby

Added by devcurmudgeon (Paul Sherwood) over 11 years ago. Updated about 11 years ago.


Description

=begin
=== What happened:
I tried to compile on a new Linux systems (Ubuntu 12.04 and a current custom Linux build)
I get the error:
executable host ruby is required. use --with-baseruby option.
make: *** [miniprelude.c] Error 1

=== What I expected:
I expect that ruby should compile.

This is a repeat of bug #3008, which was closed a couple of years ago. I tried checking out at the exact commit that fixed #3008 and got the same result, so I'm thinking either something has changed outside of ruby since the fix, or possibly the fix never worked for Linux (the comment in the commit says ...for HP UX")?

There are no docs for how to get around this. How can I get ruby on a system if I can't compile ruby?
=end


Related issues 1 (0 open1 closed)

Has duplicate Ruby master - Bug #7943: Can't build from source or snapshots without pre-existing RubyRejected02/24/2013Actions

Updated by luislavena (Luis Lavena) over 11 years ago

AFAIK, if you build from trunk (a direct checkout) you need Ruby.

Release packages do not need a base Ruby since the specific files that depend on installed Ruby has already been generated and packaged in the file.

Perhaps you can try the nightly snapshots which I believe meet this scenario.

From download page:

http://www.ruby-lang.org/en/downloads/

Downloaded http://ftp.ruby-lang.org/pub/ruby/snapshot.tar.gz

That should work without an installed Ruby.

Updated by mame (Yusuke Endoh) over 11 years ago

  • Status changed from Open to Rejected

Please follow Luis's advice, and reopen if you find another issue. Thanks.

--
Yusuke Endoh

Updated by devcurmudgeon (Paul Sherwood) about 11 years ago

I'd like to reopen this, but I don't see how to do that. I'll raise a new one.

On a Linux system with autotools, GCC etc,
but no pre-existing Ruby, make fails for the following snapshots:

http://ftp.ruby-lang.org/pub/ruby/snapshot.tar.gz
http://ftp.ruby-lang.org/pub/ruby/1.9/ruby-1.9.3-p392.tar.gz
http://ftp.ruby-lang.org/pub/ruby/2.0/ruby-2.0.0-p0.tar.gz

Updated by luislavena (Luis Lavena) about 11 years ago

  • Category set to build
  • Status changed from Rejected to Assigned
  • Assignee set to mame (Yusuke Endoh)
  • Target version set to 2.0.0

Updated by luislavena (Luis Lavena) about 11 years ago

  • Priority changed from 3 to Normal

Updated by luislavena (Luis Lavena) about 11 years ago

=begin
Reported error:

make
CC = gcc
LD = ld
LDSHARED =
CFLAGS =
XCFLAGS = -include ruby/config.h -include ruby/missing.h -D_FORTIFY_SOURCE=2 -fstack-protector -fno-strict-overflow -fvisibility=hidden -DRUBY_EXPORT -fPIE
CPPFLAGS = -I. -I.ext/include/x86_64-linux -I./include -I.
DLDFLAGS = -fstack-protector -pie
SOLIBS =
generating miniprelude.c
executable host ruby is required. use --with-baseruby option.
uncommon.mk:900: recipe for target `miniprelude.c' failed
make: *** [miniprelude.c] Error 1

=end

Updated by paulsherwood (Paul Sherwood) about 11 years ago

Sorry, Luis, I crossed with you - please feel free to close the new bug

On 24/02/2013 13:41, luislavena (Luis Lavena) wrote:

Issue #6807 has been updated by luislavena (Luis Lavena).

Category set to build
Status changed from Rejected to Assigned
Assignee set to mame (Yusuke Endoh)
Target version set to 2.0.0


Bug #6807: Can't compile ruby without ruby
https://bugs.ruby-lang.org/issues/6807#change-36925

Author: devcurmudgeon (Paul Sherwood)
Status: Assigned
Priority: Low
Assignee: mame (Yusuke Endoh)
Category: build
Target version: 2.0.0
ruby -v: current trunk

=begin
What happened:
I tried to compile on a new Linux systems (Ubuntu 12.04 and a current custom Linux build)
I get the error:
executable host ruby is required. use --with-baseruby option.
make: *** [miniprelude.c] Error 1

What I expected:
I expect that ruby should compile.

This is a repeat of bug 3008, which was closed a couple of years ago. I tried checking out at the exact commit that fixed 3008 and got the same result, so I'm thinking either something has changed outside of ruby since the fix, or possibly the fix never worked for Linux (the comment in the commit says ...for HP UX")?

There are no docs for how to get around this. How can I get ruby on a system if I can't compile ruby?
=end

Updated by mame (Yusuke Endoh) about 11 years ago

  • Status changed from Assigned to Feedback

Could you elaborate what you did exactly?

I could not reproduce it with a Ubuntu 12.10 sandbox created by debootstrap.

$ sudo debootstrap --arch amd64 quantal /srv/ubuntu http://archive.ubuntu.com/ubuntu
$ sudo cp ruby-2.0.0-p0.tar.bz2 /srv/ubuntu/tmp
$ sudo cp /etc/apt/sources.list /srv/ubuntu/etc/apt
$ sudo chdoor /srv/ubuntu

apt-get install autoconf make gcc

cd /tmp

tar xjf ruby-2.0.0-p0.tar.bz2

cd /ruby-2.0.0-p0

ruby # ruby: command not found

./configure

make # succeeded

--
Yusuke Endoh

Updated by paulsherwood (Paul Sherwood) about 11 years ago

I'm working on a custom Linux appliance build, in a chroot, so it is possible the problem is at my end. I'll follow your steps when I have access to an Ubuntu machine and update then

Thank you
Paul

Updated by nobu (Nobuyoshi Nakada) about 11 years ago

  • Description updated (diff)

Updated by nobu (Nobuyoshi Nakada) about 11 years ago

  • % Done changed from 100 to 0
Actions #12

Updated by nobu (Nobuyoshi Nakada) about 11 years ago

  • Status changed from Feedback to Closed
  • % Done changed from 0 to 100

This issue was solved with changeset r39492.
Paul, thank you for reporting this issue.
Your contribution to Ruby is greatly appreciated.
May Ruby be with you.


common.mk: clean miniprelude.c

  • common.mk (realclean-local): miniprelude.c is made by srcs, so it
    should not removed by distclean but by realclean. [Bug #6807]

Updated by nobu (Nobuyoshi Nakada) about 11 years ago

The only situation which we could thought of was that you did make distclean' before make'.

If it's not the case, please reopen this ticket.

Actions #14

Updated by nobu (Nobuyoshi Nakada) about 11 years ago

  • Tracker changed from Bug to Backport
  • Project changed from Ruby master to Backport200
  • Category deleted (build)
  • Status changed from Closed to Assigned
  • Assignee changed from mame (Yusuke Endoh) to nagachika (Tomoyuki Chikanaga)
  • Target version deleted (2.0.0)
Actions #15

Updated by nagachika (Tomoyuki Chikanaga) about 11 years ago

  • Status changed from Assigned to Closed

This issue was solved with changeset r39705.
Paul, thank you for reporting this issue.
Your contribution to Ruby is greatly appreciated.
May Ruby be with you.


merge revision(s) 39492: [Backport #6807]

* common.mk (realclean-local): miniprelude.c is made by srcs, so it
  should not removed by distclean but by realclean.  [Bug #6807]
Actions

Also available in: Atom PDF

Like0
Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0Like0