homebrew-core/Formula/wireshark.rb
BrewTestBot 9b810cb881 wireshark: add 1.10.7 bottle.
Closes Homebrew/homebrew#29844.

Signed-off-by: Mike McQuaid <mike@mikemcquaid.com>
2014-06-04 12:24:15 +01:00

162 lines
5.1 KiB
Ruby

require 'formula'
class Wireshark < Formula
homepage 'http://www.wireshark.org'
stable do
url 'http://wiresharkdownloads.riverbed.com/wireshark/src/wireshark-1.10.7.tar.bz2'
mirror 'http://www.wireshark.org/download/src/wireshark-1.10.7.tar.bz2'
sha1 '5e5ce4fdc9aa53e545fc0fbd22eea6adcf7dfc0b'
# Removes SDK checks that prevent the build from working on CLT-only systems
# Reported upstream: https://bugs.wireshark.org/bugzilla/show_bug.cgi?id=9290
patch :DATA
end
bottle do
sha1 "a369364e5488f2fdd40c66e65017af3de53c39e7" => :mavericks
sha1 "bb51c82ed19df08f4543b99d99b19dd8f10477cd" => :mountain_lion
sha1 "475e3a49e60acb0b01f94a286f3adfe1dd61f1a7" => :lion
end
head do
url 'https://code.wireshark.org/review/wireshark', :using => :git
depends_on "autoconf" => :build
depends_on "automake" => :build
depends_on "libtool" => :build
end
devel do
url 'http://wiresharkdownloads.riverbed.com/wireshark/src/wireshark-1.11.3.tar.bz2'
sha1 '7e1c6b107c178016d51c9061ef3f40efbc47a040'
end
option 'with-qt', 'Use QT for GUI instead of GTK+3'
option 'with-headers', 'Install Wireshark library headers for plug-in developemnt'
depends_on 'pkg-config' => :build
depends_on 'glib'
depends_on 'gnutls'
depends_on 'libgcrypt'
depends_on 'geoip' => :recommended
depends_on 'c-ares' => :optional
depends_on 'lua' => :optional
depends_on 'pcre' => :optional
depends_on 'portaudio' => :optional
depends_on 'qt' => :optional
depends_on "gtk+3" => :optional
depends_on "gtk+" => :optional
def install
args = ["--disable-dependency-tracking",
"--prefix=#{prefix}",
"--with-gnutls",
"--with-ssl"]
args << "--disable-wireshark" if build.without?("gtk+3") && build.without?("qt") && build.without?("gtk+")
args << "--disable-gtktest" if build.without?("gtk+3") && build.without?("gtk+")
args << "--with-qt" if build.with? "qt"
args << "--with-gtk3" if build.with? "gtk+3"
args << "--with-gtk2" if build.with? "gtk+"
if build.head?
args << "--disable-warnings-as-errors"
system "./autogen.sh"
end
system "./configure", *args
system "make"
ENV.deparallelize # parallel install fails
system "make install"
if build.with? 'headers'
(include/"wireshark").install Dir["*.h"]
(include/"wireshark/epan").install Dir["epan/*.h"]
(include/"wireshark/epan/crypt").install Dir["epan/crypt/*.h"]
(include/"wireshark/epan/dfilter").install Dir["epan/dfilter/*.h"]
(include/"wireshark/epan/dissectors").install Dir["epan/dissectors/*.h"]
(include/"wireshark/epan/ftypes").install Dir["epan/ftypes/*.h"]
(include/"wireshark/epan/wmem").install Dir["epan/wmem/*.h"]
(include/"wireshark/wiretap").install Dir["wiretap/*.h"]
(include/"wireshark/wsutil").install Dir["wsutil/*.h"]
end
end
def caveats; <<-EOS.undent
If your list of available capture interfaces is empty
(default OS X behavior), try the following commands:
curl https://bugs.wireshark.org/bugzilla/attachment.cgi?id=3373 -o ChmodBPF.tar.gz
tar zxvf ChmodBPF.tar.gz
open ChmodBPF/Install\\ ChmodBPF.app
This adds a launch daemon that changes the permissions of your BPF
devices so that all users in the 'admin' group - all users with
'Allow user to administer this computer' turned on - have both read
and write access to those devices.
See bug report:
https://bugs.wireshark.org/bugzilla/show_bug.cgi?id=3760
EOS
end
test do
system "#{bin}/randpkt", "-b", "100", "-c", "2", "capture.pcap"
output = `#{bin}/capinfos -Tmc capture.pcap`
assert_equal "File name,Number of packets\ncapture.pcap,2\n", output
end
end
__END__
diff --git a/configure b/configure
index cd41b63..c473fe7 100755
--- a/configure
+++ b/configure
@@ -16703,42 +16703,12 @@ $as_echo "yes" >&6; }
break
fi
done
- if test -z "$SDKPATH"
- then
- { $as_echo "$as_me:${as_lineno-$LINENO}: result: no" >&5
-$as_echo "no" >&6; }
- as_fn_error $? "We couldn't find the SDK for OS X $deploy_target" "$LINENO" 5
- fi
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: yes" >&5
$as_echo "yes" >&6; }
;;
esac
#
- # Add a -mmacosx-version-min flag to force tests that
- # use the compiler, as well as the build itself, not to,
- # for example, use compiler or linker features not supported
- # by the minimum targeted version of the OS.
- #
- # Add an -isysroot flag to use the SDK.
- #
- CFLAGS="-mmacosx-version-min=$deploy_target -isysroot $SDKPATH $CFLAGS"
- CXXFLAGS="-mmacosx-version-min=$deploy_target -isysroot $SDKPATH $CXXFLAGS"
- LDFLAGS="-mmacosx-version-min=$deploy_target -isysroot $SDKPATH $LDFLAGS"
-
- #
- # Add a -sdkroot flag to use with osx-app.sh.
- #
- OSX_APP_FLAGS="-sdkroot $SDKPATH"
-
- #
- # XXX - do we need this to build the Wireshark wrapper?
- # XXX - is this still necessary with the -mmacosx-version-min
- # flag being set?
- #
- OSX_DEPLOY_TARGET="MACOSX_DEPLOYMENT_TARGET=$deploy_target"
-
- #
# In the installer package XML file, give the deployment target
# as the minimum version.
#