Class: MiniPortile

Inherits:
Object
  • Object
show all
Defined in:
lib/mini_portile.rb

Instance Attribute Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(name, version) ⇒ MiniPortile

Returns a new instance of MiniPortile.



14
15
16
17
18
19
20
21
22
23
# File 'lib/mini_portile.rb', line 14

def initialize(name, version)
  @name = name
  @version = version
  @target = 'ports'
  @files = []
  @patch_files = []
  @logger = STDOUT

  @original_host = @host = detect_host
end

Instance Attribute Details

#configure_optionsObject



55
56
57
# File 'lib/mini_portile.rb', line 55

def configure_options
  @configure_options ||= configure_defaults
end

#filesObject

Returns the value of attribute files.



12
13
14
# File 'lib/mini_portile.rb', line 12

def files
  @files
end

#hostObject

Returns the value of attribute host.



12
13
14
# File 'lib/mini_portile.rb', line 12

def host
  @host
end

#loggerObject

Returns the value of attribute logger.



12
13
14
# File 'lib/mini_portile.rb', line 12

def logger
  @logger
end

#nameObject (readonly)

Returns the value of attribute name.



10
11
12
# File 'lib/mini_portile.rb', line 10

def name
  @name
end

#original_hostObject (readonly)

Returns the value of attribute original_host.



10
11
12
# File 'lib/mini_portile.rb', line 10

def original_host
  @original_host
end

#patch_filesObject

Returns the value of attribute patch_files.



12
13
14
# File 'lib/mini_portile.rb', line 12

def patch_files
  @patch_files
end

#targetObject

Returns the value of attribute target.



12
13
14
# File 'lib/mini_portile.rb', line 12

def target
  @target
end

#versionObject (readonly)

Returns the value of attribute version.



10
11
12
# File 'lib/mini_portile.rb', line 10

def version
  @version
end

Instance Method Details

#activateObject



116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
# File 'lib/mini_portile.rb', line 116

def activate
  lib_path = File.join(port_path, "lib")
  vars = {
    'PATH'          => File.join(port_path, 'bin'),
    'CPATH'         => File.join(port_path, 'include'),
    'LIBRARY_PATH'  => lib_path
  }.reject { |env, path| !File.directory?(path) }

  output "Activating #{@name} #{@version} (from #{port_path})..."
  vars.each do |var, path|
    full_path = File.expand_path(path)

    # turn into a valid Windows path (if required)
    full_path.gsub!(File::SEPARATOR, File::ALT_SEPARATOR) if File::ALT_SEPARATOR

    # save current variable value
    old_value = ENV[var] || ''

    unless old_value.include?(full_path)
      ENV[var] = "#{full_path}#{File::PATH_SEPARATOR}#{old_value}"
    end
  end

  # rely on LDFLAGS when cross-compiling
  if File.exist?(lib_path) && (@host != @original_host)
    full_path = File.expand_path(lib_path)

    old_value = ENV.fetch("LDFLAGS", "")

    unless old_value.include?(full_path)
      ENV["LDFLAGS"] = "-L#{full_path} #{old_value}".strip
    end
  end
end

#compileObject



69
70
71
# File 'lib/mini_portile.rb', line 69

def compile
  execute('compile', make_cmd)
end

#configureObject



59
60
61
62
63
64
65
66
67
# File 'lib/mini_portile.rb', line 59

def configure
  return if configured?

  md5_file = File.join(tmp_path, 'configure.md5')
  digest   = Digest::MD5.hexdigest(computed_options)
  File.open(md5_file, "w") { |f| f.write digest }

  execute('configure', %Q(sh configure #{computed_options}))
end

#configured?Boolean

Returns:

  • (Boolean)


87
88
89
90
91
92
93
94
95
96
# File 'lib/mini_portile.rb', line 87

def configured?
  configure = File.join(work_path, 'configure')
  makefile  = File.join(work_path, 'Makefile')
  md5_file  = File.join(tmp_path, 'configure.md5')

  stored_md5  = File.exist?(md5_file) ? File.read(md5_file) : ""
  current_md5 = Digest::MD5.hexdigest(computed_options)

  (current_md5 == stored_md5) && newer?(makefile, configure)
end

#cookObject



105
106
107
108
109
110
111
112
113
114
# File 'lib/mini_portile.rb', line 105

def cook
  download unless downloaded?
  extract
  patch
  configure unless configured?
  compile
  install unless installed?

  return true
end

#downloadObject



25
26
27
28
29
30
# File 'lib/mini_portile.rb', line 25

def download
  @files.each do |url|
    filename = File.basename(url)
    download_file(url, File.join(archives_path, filename))
  end
end

#downloaded?Boolean

Returns:

  • (Boolean)


78
79
80
81
82
83
84
85
# File 'lib/mini_portile.rb', line 78

def downloaded?
  missing = @files.detect do |url|
    filename = File.basename(url)
    !File.exist?(File.join(archives_path, filename))
  end

  missing ? false : true
end

#extractObject



32
33
34
35
36
37
# File 'lib/mini_portile.rb', line 32

def extract
  @files.each do |url|
    filename = File.basename(url)
    extract_file(File.join(archives_path, filename), tmp_path)
  end
end

#installObject



73
74
75
76
# File 'lib/mini_portile.rb', line 73

def install
  return if installed?
  execute('install', %Q(#{make_cmd} install))
end

#installed?Boolean

Returns:

  • (Boolean)


98
99
100
101
102
103
# File 'lib/mini_portile.rb', line 98

def installed?
  makefile  = File.join(work_path, 'Makefile')
  target_dir = Dir.glob("#{port_path}/*").find { |d| File.directory?(d) }

  newer?(target_dir, makefile)
end

#patchObject



39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'lib/mini_portile.rb', line 39

def patch
  # Set GIT_DIR while appying patches to work around
  # git-apply doing nothing when started within another
  # git directory.
  ENV['GIT_DIR'], old_git = '.', ENV['GIT_DIR']
  begin
    @patch_files.each do |full_path|
      next unless File.exists?(full_path)
      output "Running git apply with #{full_path}..."
      execute('patch', %Q(git apply #{full_path}))
    end
  ensure
    ENV['GIT_DIR'] = old_git
  end
end

#pathObject



151
152
153
# File 'lib/mini_portile.rb', line 151

def path
  File.expand_path(port_path)
end