100 lines
3 KiB
Ruby
100 lines
3 KiB
Ruby
require 'formula'
|
|
|
|
class Luarocks < Formula
|
|
homepage 'http://luarocks.org'
|
|
url 'http://luarocks.org/releases/luarocks-2.0.12.tar.gz'
|
|
sha1 'bfa36d5a9931c240c0253dee09c0cfb69372d276'
|
|
|
|
option 'with-luajit', 'Use LuaJIT instead of the stock Lua'
|
|
option 'with-lua52', 'Use Lua 5.2 instead of the stock Lua'
|
|
|
|
if build.include? 'with-luajit'
|
|
depends_on 'luajit'
|
|
elsif build.include? 'with-lua52'
|
|
depends_on 'lua52'
|
|
else
|
|
depends_on 'lua'
|
|
end
|
|
|
|
fails_with :llvm do
|
|
cause "Lua itself compiles with llvm, but may fail when other software tries to link."
|
|
end
|
|
|
|
# See comments at __END__
|
|
def patches
|
|
DATA if HOMEBREW_PREFIX.to_s == '/usr/local'
|
|
end
|
|
|
|
def install
|
|
# Install to the Cellar, but direct modules to HOMEBREW_PREFIX
|
|
args = ["--prefix=#{prefix}",
|
|
"--rocks-tree=#{HOMEBREW_PREFIX}",
|
|
"--sysconfdir=#{etc}/luarocks"]
|
|
|
|
if build.include? 'with-luajit'
|
|
args << "--with-lua-include=#{HOMEBREW_PREFIX}/include/luajit-2.0"
|
|
args << "--lua-suffix=jit"
|
|
end
|
|
|
|
system "./configure", *args
|
|
system "make"
|
|
system "make install"
|
|
end
|
|
|
|
def caveats; <<-EOS.undent
|
|
Rocks install to: #{HOMEBREW_PREFIX}/lib/luarocks/rocks
|
|
|
|
You may need to run `luarocks install` inside the Homebrew build
|
|
environment for rocks to successfully build. To do this, first run `brew sh`.
|
|
EOS
|
|
end
|
|
|
|
def test
|
|
opoo "Luarocks test script installs 'lpeg'"
|
|
system "#{bin}/luarocks", "install", "lpeg"
|
|
system "lua", "-llpeg", "-e", 'print ("Hello World!")'
|
|
end
|
|
end
|
|
|
|
|
|
# This patch because we set the permissions of /usr/local to root owned
|
|
# not user writable to be "good" citizens of /usr/local. Actually LUA is being
|
|
# pedantic since all the directories it wants under /usr/local are writable
|
|
# so we just return true. Naughty, but I don't know LUA and don't want to
|
|
# write a better patch.
|
|
__END__
|
|
diff --git a/src/luarocks/fs/lua.lua b/src/luarocks/fs/lua.lua
|
|
index 67c3ce0..2d149c7 100644
|
|
--- a/src/luarocks/fs/lua.lua
|
|
+++ b/src/luarocks/fs/lua.lua
|
|
@@ -669,29 +669,5 @@ end
|
|
-- @return boolean or (boolean, string): true on success, false on failure,
|
|
-- plus an error message.
|
|
function check_command_permissions(flags)
|
|
- local root_dir = path.root_dir(cfg.rocks_dir)
|
|
- local ok = true
|
|
- local err = ""
|
|
- for _, dir in ipairs { cfg.rocks_dir, root_dir } do
|
|
- if fs.exists(dir) and not fs.is_writable(dir) then
|
|
- ok = false
|
|
- err = "Your user does not have write permissions in " .. dir
|
|
- break
|
|
- end
|
|
- end
|
|
- local root_parent = dir.dir_name(root_dir)
|
|
- if ok and not fs.exists(root_dir) and not fs.is_writable(root_parent) then
|
|
- ok = false
|
|
- err = root_dir.." does not exist and your user does not have write permissions in " .. root_parent
|
|
- end
|
|
- if ok then
|
|
- return true
|
|
- else
|
|
- if flags["local"] then
|
|
- err = err .. " \n-- please check your permissions."
|
|
- else
|
|
- err = err .. " \n-- you may want to run as a privileged user or use your local tree with --local."
|
|
- end
|
|
- return nil, err
|
|
- end
|
|
+ return true
|
|
end
|