summaryrefslogtreecommitdiffstats
path: root/python-config.py
diff options
context:
space:
mode:
authorHuang Peng <shawn.p.huang@gmail.com>2008-06-17 16:46:55 +0800
committerHuang Peng <shawn.p.huang@gmail.com>2008-06-17 16:46:55 +0800
commit57522e42d54375596542c98de0bd3be344d744fa (patch)
tree61ba241e3f9c306f3748e97bb2c7c6771ce8678a /python-config.py
parenteb28cd1b6d495e61b757991657da0804f097760c (diff)
downloadibus-57522e42d54375596542c98de0bd3be344d744fa.tar.gz
ibus-57522e42d54375596542c98de0bd3be344d744fa.tar.xz
ibus-57522e42d54375596542c98de0bd3be344d744fa.zip
WIP.
Diffstat (limited to 'python-config.py')
-rwxr-xr-xpython-config.py53
1 files changed, 53 insertions, 0 deletions
diff --git a/python-config.py b/python-config.py
new file mode 100755
index 0000000..e53fb2c
--- /dev/null
+++ b/python-config.py
@@ -0,0 +1,53 @@
+#!/usr/bin/python2.5
+
+import sys
+import os
+import getopt
+from distutils import sysconfig
+
+valid_opts = ['prefix', 'exec-prefix', 'includes', 'libs', 'cflags',
+ 'ldflags', 'help']
+
+def exit_with_usage(code=1):
+ print >>sys.stderr, "Usage: %s [%s]" % (sys.argv[0],
+ '|'.join('--'+opt for opt in valid_opts))
+ sys.exit(code)
+
+try:
+ opts, args = getopt.getopt(sys.argv[1:], '', valid_opts)
+except getopt.error:
+ exit_with_usage()
+
+if not opts:
+ exit_with_usage()
+
+opt = opts[0][0]
+
+pyver = sysconfig.get_config_var('VERSION')
+getvar = sysconfig.get_config_var
+
+if opt == '--help':
+ exit_with_usage(0)
+
+elif opt == '--prefix':
+ print sysconfig.PREFIX
+
+elif opt == '--exec-prefix':
+ print sysconfig.EXEC_PREFIX
+
+elif opt in ('--includes', '--cflags'):
+ flags = ['-I' + sysconfig.get_python_inc(),
+ '-I' + sysconfig.get_python_inc(plat_specific=True)]
+ if opt == '--cflags':
+ flags.extend(getvar('CFLAGS').split())
+ print ' '.join(flags)
+
+elif opt in ('--libs', '--ldflags'):
+ libs = getvar('LIBS').split() + getvar('SYSLIBS').split()
+ libs.append('-lpython'+pyver)
+ # add the prefix/lib/pythonX.Y/config dir, but only if there is no
+ # shared library in prefix/lib/.
+ if opt == '--ldflags' and not getvar('Py_ENABLE_SHARED'):
+ libs.insert(0, '-L' + getvar('LIBPL'))
+ print ' '.join(libs)
+