2013-12-03 06:22:36 +00:00
|
|
|
require 'formula'
|
|
|
|
|
|
|
|
class JohnJumbo < Formula
|
|
|
|
homepage 'http://www.openwall.com/john/'
|
|
|
|
url 'http://www.openwall.com/john/g/john-1.7.9.tar.bz2'
|
|
|
|
sha1 '8f77bdd42b7cf94ec176f55ea69c4da9b2b8fe3b'
|
|
|
|
|
|
|
|
conflicts_with 'john', :because => 'both install the same binaries'
|
|
|
|
|
|
|
|
def patches
|
|
|
|
[
|
2014-02-10 05:04:44 +00:00
|
|
|
"http://www.openwall.com/john/g/john-1.7.9-jumbo-7.diff.gz", # Jumbo
|
|
|
|
# First patch taken from MacPorts, tells john where to find runtime files
|
|
|
|
# Second patch protects against a redefinition of _mm_testz_si128 which
|
|
|
|
# tanked the build in clang;
|
|
|
|
# see https://github.com/Homebrew/homebrew/issues/26531
|
|
|
|
DATA
|
2013-12-03 06:22:36 +00:00
|
|
|
]
|
|
|
|
end
|
|
|
|
|
|
|
|
fails_with :llvm do
|
|
|
|
build 2334
|
|
|
|
cause "Don't remember, but adding this to whitelist 2336."
|
|
|
|
end
|
|
|
|
|
|
|
|
def install
|
|
|
|
ENV.deparallelize
|
2014-02-09 03:33:38 +00:00
|
|
|
arch = MacOS.prefer_64_bit? ? '64' : 'sse2'
|
2013-12-03 06:22:36 +00:00
|
|
|
arch += '-opencl'
|
|
|
|
|
2014-02-09 03:32:34 +00:00
|
|
|
target = "macosx-x86-#{arch}"
|
|
|
|
|
2013-12-03 06:22:36 +00:00
|
|
|
cd 'src' do
|
|
|
|
inreplace 'Makefile' do |s|
|
|
|
|
s.change_make_var! "CC", ENV.cc
|
2014-02-09 03:32:34 +00:00
|
|
|
if MacOS.version > :leopard && ENV.compiler != :clang
|
2013-12-03 06:22:36 +00:00
|
|
|
s.change_make_var! "OMPFLAGS", "-fopenmp -msse2 -D_FORTIFY_SOURCE=0"
|
|
|
|
end
|
|
|
|
end
|
2014-02-09 03:32:34 +00:00
|
|
|
system "make", "clean", target
|
2013-12-03 06:22:36 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
# Remove the README symlink and install the real file
|
|
|
|
rm 'README'
|
|
|
|
prefix.install 'doc/README'
|
|
|
|
doc.install Dir['doc/*']
|
|
|
|
|
|
|
|
# Only symlink the binary into bin
|
|
|
|
(share/'john').install Dir['run/*']
|
|
|
|
bin.install_symlink share/'john/john'
|
|
|
|
|
|
|
|
# Source code defaults to 'john.ini', so rename
|
|
|
|
mv share/'john/john.conf', share/'john/john.ini'
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
__END__
|
|
|
|
--- a/src/params.h 2012-08-30 13:24:18.000000000 -0500
|
|
|
|
+++ b/src/params.h 2012-08-30 13:25:13.000000000 -0500
|
|
|
|
@@ -70,15 +70,15 @@
|
|
|
|
* notes above.
|
|
|
|
*/
|
|
|
|
#ifndef JOHN_SYSTEMWIDE
|
|
|
|
-#define JOHN_SYSTEMWIDE 0
|
|
|
|
+#define JOHN_SYSTEMWIDE 1
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if JOHN_SYSTEMWIDE
|
|
|
|
#ifndef JOHN_SYSTEMWIDE_EXEC /* please refer to the notes above */
|
|
|
|
-#define JOHN_SYSTEMWIDE_EXEC "/usr/libexec/john"
|
|
|
|
+#define JOHN_SYSTEMWIDE_EXEC "HOMEBREW_PREFIX/share/john"
|
|
|
|
#endif
|
|
|
|
#ifndef JOHN_SYSTEMWIDE_HOME
|
|
|
|
-#define JOHN_SYSTEMWIDE_HOME "/usr/share/john"
|
|
|
|
+#define JOHN_SYSTEMWIDE_HOME "HOMEBREW_PREFIX/share/john"
|
|
|
|
#endif
|
|
|
|
#define JOHN_PRIVATE_HOME "~/.john"
|
|
|
|
#endif
|
2014-02-10 05:04:44 +00:00
|
|
|
|
|
|
|
diff --git a/src/rawSHA1_ng_fmt.c b/src/rawSHA1_ng_fmt.c
|
|
|
|
index 5f89cda..6cbd550 100644
|
|
|
|
--- a/src/rawSHA1_ng_fmt.c
|
|
|
|
+++ b/src/rawSHA1_ng_fmt.c
|
|
|
|
@@ -530,7 +530,7 @@ static void sha1_fmt_crypt_all(int count)
|
|
|
|
|
|
|
|
#if defined(__SSE4_1__)
|
|
|
|
|
|
|
|
-# if !defined(__INTEL_COMPILER)
|
|
|
|
+# if !defined(__INTEL_COMPILER) && !defined(__clang__)
|
|
|
|
// This intrinsic is not always available in GCC, so define it here.
|
|
|
|
static inline int _mm_testz_si128 (__m128i __M, __m128i __V)
|
|
|
|
{
|