aboutsummaryrefslogtreecommitdiffstats
path: root/Library/Formula/lua.rb
diff options
context:
space:
mode:
Diffstat (limited to 'Library/Formula/lua.rb')
-rw-r--r--Library/Formula/lua.rb153
1 files changed, 71 insertions, 82 deletions
diff --git a/Library/Formula/lua.rb b/Library/Formula/lua.rb
index 6de54f804..16dec015b 100644
--- a/Library/Formula/lua.rb
+++ b/Library/Formula/lua.rb
@@ -1,18 +1,10 @@
require 'formula'
class Lua < Formula
- # 5.2 is not fully backwards compatible, and breaks e.g. luarocks.
- # It is available in Homebrew-versions for the time being.
homepage 'http://www.lua.org/'
- url 'http://www.lua.org/ftp/lua-5.1.5.tar.gz'
- sha1 'b3882111ad02ecc6b972f8c1241647905cb2e3fc'
-
- bottle do
- cellar :any
- sha1 "dcc3b430fd59fd3c16774ecc159d82256ac587db" => :mavericks
- sha1 "4ddadaaeaca408964255de43761a7f12b7457bb5" => :mountain_lion
- sha1 "212b1a9a5822afd9796fefb42bab63c6466e6faa" => :lion
- end
+ url 'http://www.lua.org/ftp/lua-5.2.3.tar.gz'
+ sha1 '926b7907bc8d274e063d42804666b40a3f3c124c'
+ revision 1
fails_with :llvm do
build 2326
@@ -20,122 +12,119 @@ class Lua < Formula
end
option :universal
- option 'with-completion', 'Enables advanced readline support'
- option 'without-sigaction', 'Revert to ANSI signal instead of improved POSIX sigaction'
# Be sure to build a dylib, or else runtime modules will pull in another static copy of liblua = crashy
# See: https://github.com/Homebrew/homebrew/pull/5043
patch :DATA
- # sigaction provided by posix signalling power patch from
- # http://lua-users.org/wiki/LuaPowerPatches
- patch do
- url "http://lua-users.org/files/wiki_insecure/power_patches/5.1/sig_catch.patch"
- sha1 "19f361f0c590f80fccd033486cbee6c9dc8616c8"
- end if build.with? "sigaction"
-
- # completion provided by advanced readline power patch from
- # http://lua-users.org/wiki/LuaPowerPatches
- patch do
- url "http://luajit.org/patches/lua-5.1.4-advanced_readline.patch"
- sha1 "3cfe2eb027b51202923d20042ae37f3249508664"
- end if build.with? "completion"
-
def install
- ENV.universal_binary if build.universal?
-
# Use our CC/CFLAGS to compile.
inreplace 'src/Makefile' do |s|
s.remove_make_var! 'CC'
- s.change_make_var! 'CFLAGS', "#{ENV.cflags} $(MYCFLAGS)"
+ s.change_make_var! 'CFLAGS', "#{ENV.cflags} -DLUA_COMPAT_ALL $(SYSCFLAGS) $(MYCFLAGS)"
s.change_make_var! 'MYLDFLAGS', ENV.ldflags
- s.sub! 'MYCFLAGS_VAL', "-fno-common -DLUA_USE_LINUX"
end
# Fix path in the config header
inreplace 'src/luaconf.h', '/usr/local', HOMEBREW_PREFIX
- # Fix paths in the .pc
- inreplace 'etc/lua.pc' do |s|
- s.gsub! "prefix= /usr/local", "prefix=#{HOMEBREW_PREFIX}"
- s.gsub! "INSTALL_MAN= ${prefix}/man/man1", "INSTALL_MAN= ${prefix}/share/man/man1"
- end
-
- # this ensures that this symlinking for lua starts at lib/lua/5.1 and not
- # below that, thus making luarocks work
- (HOMEBREW_PREFIX/"lib/lua"/version.to_s.split('.')[0..1].join('.')).mkpath
-
+ # We ship our own pkg-config file as Lua no longer provide them upstream.
system "make", "macosx", "INSTALL_TOP=#{prefix}", "INSTALL_MAN=#{man1}"
system "make", "install", "INSTALL_TOP=#{prefix}", "INSTALL_MAN=#{man1}"
-
- (lib+"pkgconfig").install 'etc/lua.pc'
+ (lib+"pkgconfig/lua.pc").write pc_file
+
+ # Fix some software potentially hunting for different pc names.
+ ln_s "#{bin}/lua", "#{bin}/lua5.2"
+ ln_s "#{bin}/lua", "#{bin}/lua-5.2"
+ ln_s "#{bin}/luac", "#{bin}/luac5.2"
+ ln_s "#{bin}/luac", "#{bin}/luac-5.2"
+ ln_s "#{include}", "#{include}/lua5.2"
+ ln_s "#{lib}/pkgconfig/lua.pc", "#{lib}/pkgconfig/lua5.2.pc"
+ ln_s "#{lib}/pkgconfig/lua.pc", "#{lib}/pkgconfig/lua-5.2.pc"
end
- test do
- output = `#{bin}/lua -e "for i=0,9 do io.write(i) end"`
- assert_equal "0123456789", output
- assert_equal 0, $?.exitstatus
+ def pc_file; <<-EOS.undent
+ V= 5.2
+ R= 5.2.3
+ prefix=#{HOMEBREW_PREFIX}
+ INSTALL_BIN= ${prefix}/bin
+ INSTALL_INC= ${prefix}/include
+ INSTALL_LIB= ${prefix}/lib
+ INSTALL_MAN= ${prefix}/share/man/man1
+ INSTALL_LMOD= ${prefix}/share/lua/${V}
+ INSTALL_CMOD= ${prefix}/lib/lua/${V}
+ exec_prefix=${prefix}
+ libdir=${exec_prefix}/lib
+ includedir=${prefix}/include
+
+ Name: Lua
+ Description: An Extensible Extension Language
+ Version: 5.2.3
+ Requires:
+ Libs: -L${libdir} -llua -lm
+ Cflags: -I${includedir}
+ EOS
end
end
__END__
diff --git a/Makefile b/Makefile
-index 209a132..9387b09 100644
+index bd9515f..5940ba9 100644
--- a/Makefile
+++ b/Makefile
-@@ -43,7 +43,7 @@ PLATS= aix ansi bsd freebsd generic linux macosx mingw posix solaris
+@@ -41,7 +41,7 @@ PLATS= aix ansi bsd freebsd generic linux macosx mingw posix solaris
# What to install.
TO_BIN= lua luac
- TO_INC= lua.h luaconf.h lualib.h lauxlib.h ../etc/lua.hpp
+ TO_INC= lua.h luaconf.h lualib.h lauxlib.h lua.hpp
-TO_LIB= liblua.a
-+TO_LIB= liblua.5.1.5.dylib
++TO_LIB= liblua.5.2.3.dylib
TO_MAN= lua.1 luac.1
# Lua version and release.
-@@ -64,6 +64,8 @@ install: dummy
- cd src && $(INSTALL_DATA) $(TO_INC) $(INSTALL_INC)
- cd src && $(INSTALL_DATA) $(TO_LIB) $(INSTALL_LIB)
- cd doc && $(INSTALL_DATA) $(TO_MAN) $(INSTALL_MAN)
-+ ln -s -f liblua.5.1.5.dylib $(INSTALL_LIB)/liblua.5.1.dylib
-+ ln -s -f liblua.5.1.dylib $(INSTALL_LIB)/liblua.dylib
-
- ranlib:
- cd src && cd $(INSTALL_LIB) && $(RANLIB) $(TO_LIB)
+@@ -63,6 +63,8 @@ install: dummy
+ cd src && $(INSTALL_DATA) $(TO_INC) $(INSTALL_INC)
+ cd src && $(INSTALL_DATA) $(TO_LIB) $(INSTALL_LIB)
+ cd doc && $(INSTALL_DATA) $(TO_MAN) $(INSTALL_MAN)
++ ln -s -f liblua.5.2.3.dylib $(INSTALL_LIB)/liblua.5.2.dylib
++ ln -s -f liblua.5.2.dylib $(INSTALL_LIB)/liblua.dylib
+
+ uninstall:
+ cd src && cd $(INSTALL_BIN) && $(RM) $(TO_BIN)
diff --git a/src/Makefile b/src/Makefile
-index e0d4c9f..4477d7b 100644
+index 8c9ee67..7f92407 100644
--- a/src/Makefile
+++ b/src/Makefile
-@@ -22,7 +22,7 @@ MYLIBS=
+@@ -28,7 +28,7 @@ MYOBJS=
PLATS= aix ansi bsd freebsd generic linux macosx mingw posix solaris
-LUA_A= liblua.a
-+LUA_A= liblua.5.1.5.dylib
- CORE_O= lapi.o lcode.o ldebug.o ldo.o ldump.o lfunc.o lgc.o llex.o lmem.o \
- lobject.o lopcodes.o lparser.o lstate.o lstring.o ltable.o ltm.o \
- lundump.o lvm.o lzio.o
-@@ -48,11 +48,13 @@ o: $(ALL_O)
++LUA_A= liblua.5.2.3.dylib
+ CORE_O= lapi.o lcode.o lctype.o ldebug.o ldo.o ldump.o lfunc.o lgc.o llex.o \
+ lmem.o lobject.o lopcodes.o lparser.o lstate.o lstring.o ltable.o \
+ ltm.o lundump.o lvm.o lzio.o
+@@ -56,11 +56,12 @@ o: $(ALL_O)
a: $(ALL_A)
- $(LUA_A): $(CORE_O) $(LIB_O)
-- $(AR) $@ $(CORE_O) $(LIB_O) # DLL needs all object files
+ $(LUA_A): $(BASE_O)
+- $(AR) $@ $(BASE_O)
- $(RANLIB) $@
-+ $(CC) -dynamiclib -install_name HOMEBREW_PREFIX/lib/liblua.5.1.dylib \
-+ -compatibility_version 5.1 -current_version 5.1.5 \
-+ -o liblua.5.1.5.dylib $^
++ $(CC) -dynamiclib -install_name HOMEBREW_PREFIX/lib/liblua.5.2.dylib \
++ -compatibility_version 5.2 -current_version 5.2.3 \
++ -o liblua.5.2.3.dylib $^
$(LUA_T): $(LUA_O) $(LUA_A)
-- $(CC) -o $@ $(MYLDFLAGS) $(LUA_O) $(LUA_A) $(LIBS)
-+ $(CC) -fno-common $(MYLDFLAGS) \
-+ -o $@ $(LUA_O) $(LUA_A) -L. -llua.5.1.5 $(LIBS)
+- $(CC) -o $@ $(LDFLAGS) $(LUA_O) $(LUA_A) $(LIBS)
++ $(CC) -fno-common $(MYLDFLAGS) -o $@ $(LUA_O) $(LUA_A) -L. -llua.5.2.3 $(LIBS)
$(LUAC_T): $(LUAC_O) $(LUA_A)
- $(CC) -o $@ $(MYLDFLAGS) $(LUAC_O) $(LUA_A) $(LIBS)
-@@ -99,7 +101,7 @@ linux:
- $(MAKE) all MYCFLAGS=-DLUA_USE_LINUX MYLIBS="-Wl,-E -ldl -lreadline -lhistory -lncurses"
+ $(CC) -o $@ $(LDFLAGS) $(LUAC_O) $(LUA_A) $(LIBS)
+@@ -106,7 +107,7 @@ linux:
+ $(MAKE) $(ALL) SYSCFLAGS="-DLUA_USE_LINUX" SYSLIBS="-Wl,-E -ldl -lreadline"
macosx:
-- $(MAKE) all MYCFLAGS=-DLUA_USE_LINUX MYLIBS="-lreadline"
-+ $(MAKE) all MYCFLAGS="MYCFLAGS_VAL" MYLIBS="-lreadline"
- # use this on Mac OS X 10.3-
- # $(MAKE) all MYCFLAGS=-DLUA_USE_MACOSX
+- $(MAKE) $(ALL) SYSCFLAGS="-DLUA_USE_MACOSX" SYSLIBS="-lreadline" CC=cc
++ $(MAKE) $(ALL) SYSCFLAGS="-DLUA_USE_MACOSX -fno-common" SYSLIBS="-lreadline" CC=cc
+
+ mingw:
+ $(MAKE) "LUA_A=lua52.dll" "LUA_T=lua.exe" \