diff options
author | Aaron Griffin <aaron@archlinux.org> | 2006-10-15 19:38:02 +0000 |
---|---|---|
committer | Aaron Griffin <aaron@archlinux.org> | 2006-10-15 19:38:02 +0000 |
commit | 94810222866b7cc36bf442993826f9b38dbe9c41 (patch) | |
tree | 325266e9e88208d481ce58b866e7002af4d279c0 /bindings/python | |
parent | 3f27542156125118800235c5ac1bac125fd7752c (diff) |
Final frugalware changes commit
Diffstat (limited to 'bindings/python')
-rw-r--r-- | bindings/python/Makefile.in | 48 | ||||
-rw-r--r-- | bindings/python/alpm.i | 23 |
2 files changed, 71 insertions, 0 deletions
diff --git a/bindings/python/Makefile.in b/bindings/python/Makefile.in new file mode 100644 index 00000000..fe2e84a6 --- /dev/null +++ b/bindings/python/Makefile.in @@ -0,0 +1,48 @@ +top_srcdir = @top_srcdir@ +prefix = @prefix@ + +CFLAGS = $(subst -Werror,,@CFLAGS@) +CFLAGS += $(shell python -c 'from distutils import sysconfig; print "-I" + sysconfig.get_python_inc()') +CFLAGS += -I$(top_srcdir)/lib/libalpm +ifeq ($(shell arch),x86_64) +CFLAGS += -fPIC +endif +LDFLAGS += -L$(top_srcdir)/lib/libalpm -lalpm +LIBDIR += $(shell python -c 'from distutils import sysconfig; print sysconfig.get_python_lib()'|sed 's|/usr|$(prefix)|') + +all: _alpm.so alpm.pyc + +_alpm.so: alpm_wrap.o + $(CC) -shared -Wl,-soname,$@ -o $@ $^ $(LDFLAGS) + +alpm_wrap.o: alpm_wrap.c + $(CC) $(CFLAGS) -c -o $@ -include alpm.h $^ + +alpm_wrap.c: + cp $(top_srcdir)/lib/libalpm/alpm.h ./ + cp $(top_srcdir)/bindings/alpm.i ./ + swig -python alpm.i + # strip the unnecessary prefixes + sed -i 's/^alpm_//;s/^PM_//' alpm.py + +alpm.pyc: alpm.py + python -c "import compileall; compileall.compile_dir('.',1,'.')" + +alpm.py: alpm_wrap.c + +install: install-so install-py + +install-so: _alpm.so + mkdir -p $(DESTDIR)$(LIBDIR) + install $^ $(DESTDIR)$(LIBDIR) + +install-py: alpm.py alpm.pyc + install -m644 $^ $(DESTDIR)$(LIBDIR) + +clean: + rm -f _alpm* alpm{.h,.py*,_wrap*} + +distclean: clean + rm -f Makefile + +check: diff --git a/bindings/python/alpm.i b/bindings/python/alpm.i new file mode 100644 index 00000000..dc4d680e --- /dev/null +++ b/bindings/python/alpm.i @@ -0,0 +1,23 @@ +#if defined(SWIGPERL) +%module "Alpm::Core" +#else +%module alpm +#endif +%include "cpointer.i" + +/* Wrap a class interface around a "long *" */ +%pointer_class(long, longp); + +/* Create casting functions */ + +%pointer_cast(char *, long *, void_to_long); +%pointer_cast(void *, char *, void_to_char); +%pointer_cast(void *, unsigned long, void_to_unsigned_long); +%pointer_cast(void *, PM_LIST *, void_to_PM_LIST); +%pointer_cast(void *, PM_PKG *, void_to_PM_PKG); +%pointer_cast(void *, PM_GRP *, void_to_PM_GRP); +%pointer_cast(void *, PM_SYNCPKG *, void_to_PM_SYNCPKG); +%pointer_cast(void *, PM_DB *, void_to_PM_DB); +%pointer_cast(void *, PM_CONFLICT *, void_to_PM_CONFLICT); + +%include "alpm.h" |