Sha256: 65ffca0e67fd04c23b6f045320c51168af6c518322c22f9047c4ff087c74d802

Contents?: true

Size: 1.69 KB

Versions: 1

Compression:

Stored size: 1.69 KB

Contents

require 'logger'
require 'shellwords'
require 'tmpdir'

module Ruby
  module Builder
    BuildFailure = Class.new(StandardError)

    class << RubyBuilder = Module.new
      # @param [Ruby::Builder::Revision] revision
      # @param [String] source_dir
      # @param [String] build_dir
      # @param [String] install_dir
      def build(revision, source_dir:, build_dir:, install_dir:)
        execute('git', '-C', source_dir, 'checkout', revision.git)
        unless File.executable?(File.join(source_dir, 'configure'))
          execute('autoreconf', dir: source_dir)
        end

        # Workaround to force updating revision in RUBY_DESCRIPTION
        timestamp_file = File.join(build_dir, '.revision.time')
        if File.exist?(timestamp_file)
          execute('rm', timestamp_file)
        end

        execute(File.join(source_dir, 'configure'), '--disable-install-doc', "--prefix=#{install_dir}", dir: build_dir)
        execute('make', "-j#{Etc.nprocessors}", dir: build_dir)
        execute('make', 'install', dir: build_dir)
      end

      private

      # @param [Array<String>] command
      # @param [String] dir
      def execute(*command, dir: nil)
        if dir
          Dir.chdir(dir) do
            assert_execute(*command)
          end
        else
          assert_execute(*command)
        end
      end

      # @param [Array<String>] command
      def assert_execute(*command)
        logger.info("+ #{command.shelljoin}")
        unless system(command.shelljoin)
          raise BuildFailure.new("Failed to execute '#{command.shelljoin}' at '#{dir}' (exit status: #{$?.exitstatus})")
        end
      end

      def logger
        @logger ||= Logger.new(STDOUT)
      end
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
ruby-builder-0.1.2 lib/ruby/builder/ruby_builder.rb