aboutsummaryrefslogtreecommitdiff
path: root/mesonbuild/dependencies/misc.py
diff options
context:
space:
mode:
authorJussi Pakkanen <jpakkane@gmail.com>2017-08-13 22:46:23 +0300
committerGitHub <noreply@github.com>2017-08-13 22:46:23 +0300
commit8c8e9230a532196da0072e82df1452fa8486176b (patch)
tree883042e2cbb8cbedb14a782fbd64337713aebb79 /mesonbuild/dependencies/misc.py
parent0ad448f89009e87fc3f22a85b0af53de5ebf8355 (diff)
parent0a6f848aa3ed632d584bce8f9b91bce65ceac971 (diff)
downloadmeson-8c8e9230a532196da0072e82df1452fa8486176b.zip
meson-8c8e9230a532196da0072e82df1452fa8486176b.tar.gz
meson-8c8e9230a532196da0072e82df1452fa8486176b.tar.bz2
Merge pull request #2130 from bruce-richardson/pcap_config_support
add support for pcap dependencies
Diffstat (limited to 'mesonbuild/dependencies/misc.py')
-rw-r--r--mesonbuild/dependencies/misc.py49
1 files changed, 49 insertions, 0 deletions
diff --git a/mesonbuild/dependencies/misc.py b/mesonbuild/dependencies/misc.py
index f5cbb96..e9effc6 100644
--- a/mesonbuild/dependencies/misc.py
+++ b/mesonbuild/dependencies/misc.py
@@ -19,10 +19,12 @@ import os
import re
import shlex
import stat
+import shutil
import sysconfig
from .. import mlog
from .. import mesonlib
+from ..mesonlib import Popen_safe
from ..environment import detect_cpu_family
from .base import DependencyException, DependencyMethods
@@ -574,3 +576,50 @@ class Python3Dependency(ExternalDependency):
return [DependencyMethods.PKGCONFIG, DependencyMethods.EXTRAFRAMEWORK]
else:
return [DependencyMethods.PKGCONFIG]
+
+class PcapDependency(ExternalDependency):
+ def __init__(self, environment, kwargs):
+ super().__init__('pcap', environment, None, kwargs)
+ if DependencyMethods.PKGCONFIG in self.methods:
+ try:
+ kwargs['required'] = False
+ pcdep = PkgConfigDependency('pcap', environment, kwargs)
+ if pcdep.found():
+ self.type_name = 'pkgconfig'
+ self.is_found = True
+ self.compile_args = pcdep.get_compile_args()
+ self.link_args = pcdep.get_link_args()
+ self.version = pcdep.get_version()
+ return
+ except Exception as e:
+ mlog.debug('Pcap not found via pkgconfig. Trying next, error was:', str(e))
+ if DependencyMethods.PCAPCONFIG in self.methods:
+ pcapconf = shutil.which('pcap-config')
+ if pcapconf:
+ stdo = Popen_safe(['pcap-config', '--cflags'])[1]
+ self.compile_args = stdo.strip().split()
+ stdo = Popen_safe(['pcap-config', '--libs'])[1]
+ self.link_args = stdo.strip().split()
+ self.version = '0'
+ self.is_found = True
+ mlog.log('Dependency', mlog.bold('pcap'), 'found:',
+ mlog.green('YES'), '(%s)' % pcapconf)
+ return
+ mlog.debug('Could not find pcap-config binary, trying next.')
+ if DependencyMethods.EXTRAFRAMEWORK in self.methods:
+ if mesonlib.is_osx():
+ fwdep = ExtraFrameworkDependency('pcap', False, None, self.env,
+ self.language, kwargs)
+ if fwdep.found():
+ self.is_found = True
+ self.compile_args = fwdep.get_compile_args()
+ self.link_args = fwdep.get_link_args()
+ self.version = '2' # FIXME
+ return
+ mlog.log('Dependency', mlog.bold('pcap'), 'found:', mlog.red('NO'))
+
+ def get_methods(self):
+ if mesonlib.is_osx():
+ return [DependencyMethods.PKGCONFIG, DependencyMethods.PCAPCONFIG, DependencyMethods.EXTRAFRAMEWORK]
+ else:
+ return [DependencyMethods.PKGCONFIG, DependencyMethods.PCAPCONFIG]