提交 c700613b 编写于 作者: E Eric Blake

python: use libvirt_util to avoid raw free

This patch starts the process of elevating the python binding code
to be on the same level as the rest of libvirt when it comes to
requiring good coding styles.  Statically linking against the
libvirt_util library makes it much easier to write good code,
rather than having to open-code and reinvent things locally.

Done by global search and replace of s/free(/VIR_FREE(/, followed
by hand-inspection of remaining malloc and redundant memset.

* cfg.mk (exclude_file_name_regexp--sc_prohibit_raw_allocation):
Remove python from exemption.
* python/Makefile.am (INCLUDES): Add gnulib and src/util.  Drop
$(top_builddir)/$(subdir), as automake already guarantees that.
(mylibs, myqemulibs): Pull in libvirt_util and gnulib.
(libvirtmod_la_CFLAGS): Catch compiler warnings if configured to
use -Werror.
* python/typewrappers.c (libvirt_charPtrSizeWrap)
(libvirt_charPtrWrap): Convert free to VIR_FREE.
* python/generator.py (print_function_wrapper): Likewise.
* python/libvirt-override.c: Likewise.
上级 8fe454ce
...@@ -744,7 +744,7 @@ exclude_file_name_regexp--sc_prohibit_nonreentrant = \ ...@@ -744,7 +744,7 @@ exclude_file_name_regexp--sc_prohibit_nonreentrant = \
^((po|tests)/|docs/.*py$$|tools/(virsh|console)\.c$$) ^((po|tests)/|docs/.*py$$|tools/(virsh|console)\.c$$)
exclude_file_name_regexp--sc_prohibit_raw_allocation = \ exclude_file_name_regexp--sc_prohibit_raw_allocation = \
^(src/util/memory\.[ch]|(examples|python)/.*)$$ ^(src/util/memory\.[ch]|examples/.*)$$
exclude_file_name_regexp--sc_prohibit_readlink = ^src/util/util\.c$$ exclude_file_name_regexp--sc_prohibit_readlink = ^src/util/util\.c$$
......
...@@ -7,9 +7,13 @@ SUBDIRS= . tests ...@@ -7,9 +7,13 @@ SUBDIRS= . tests
INCLUDES = \ INCLUDES = \
$(PYTHON_INCLUDES) \ $(PYTHON_INCLUDES) \
-I$(top_builddir)/gnulib/lib \
-I$(top_srcdir)/gnulib/lib \
-I$(top_builddir)/src \
-I$(top_srcdir)/src \
-I$(top_srcdir)/src/util \
-I$(top_builddir)/include \ -I$(top_builddir)/include \
-I$(top_srcdir)/include \ -I$(top_srcdir)/include \
-I$(top_builddir)/$(subdir) \
$(GETTEXT_CPPFLAGS) $(GETTEXT_CPPFLAGS)
AM_CFLAGS = $(WARN_CFLAGS) AM_CFLAGS = $(WARN_CFLAGS)
...@@ -35,8 +39,14 @@ EXTRA_DIST = \ ...@@ -35,8 +39,14 @@ EXTRA_DIST = \
$(DOCS) $(DOCS)
if WITH_PYTHON if WITH_PYTHON
mylibs = $(top_builddir)/src/libvirt.la mylibs = \
myqemulibs = $(top_builddir)/src/libvirt-qemu.la $(top_builddir)/src/libvirt.la \
$(top_builddir)/src/libvirt_util.la \
$(top_builddir)/gnulib/lib/libgnu.la
myqemulibs = \
$(top_builddir)/src/libvirt-qemu.la \
$(top_builddir)/src/libvirt_util.la \
$(top_builddir)/gnulib/lib/libgnu.la
all-local: libvirt.py libvirt_qemu.py all-local: libvirt.py libvirt_qemu.py
...@@ -46,7 +56,7 @@ libvirtmod_la_SOURCES = libvirt-override.c typewrappers.c ...@@ -46,7 +56,7 @@ libvirtmod_la_SOURCES = libvirt-override.c typewrappers.c
nodist_libvirtmod_la_SOURCES = libvirt.c libvirt.h nodist_libvirtmod_la_SOURCES = libvirt.c libvirt.h
# Python <= 2.4 header files contain a redundant decl, hence we # Python <= 2.4 header files contain a redundant decl, hence we
# need extra flags here # need extra flags here
libvirtmod_la_CFLAGS = $(WARN_PYTHON_CFLAGS) libvirtmod_la_CFLAGS = $(WARN_CFLAGS) $(WARN_PYTHON_CFLAGS)
libvirtmod_la_LDFLAGS = -module -avoid-version -shared -L$(top_builddir)/src/.libs \ libvirtmod_la_LDFLAGS = -module -avoid-version -shared -L$(top_builddir)/src/.libs \
$(CYGWIN_EXTRA_LDFLAGS) $(CYGWIN_EXTRA_LDFLAGS)
......
...@@ -580,7 +580,7 @@ def print_function_wrapper(module, name, output, export, include): ...@@ -580,7 +580,7 @@ def print_function_wrapper(module, name, output, export, include):
if ret[0] == 'void': if ret[0] == 'void':
if file == "python_accessor": if file == "python_accessor":
if args[1][1] == "char *": if args[1][1] == "char *":
c_call = "\n free(%s->%s);\n" % ( c_call = "\n VIR_FREE(%s->%s);\n" % (
args[0][0], args[1][0], args[0][0], args[1][0]) args[0][0], args[1][0], args[0][0], args[1][0])
c_call = c_call + " %s->%s = (%s)strdup((const xmlChar *)%s);\n" % (args[0][0], c_call = c_call + " %s->%s = (%s)strdup((const xmlChar *)%s);\n" % (args[0][0],
args[1][0], args[1][1], args[1][0]) args[1][0], args[1][1], args[1][0])
......
此差异已折叠。
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
* types.c: converter functions between the internal representation * types.c: converter functions between the internal representation
* and the Python objects * and the Python objects
* *
* Copyright (C) 2005, 2007 Red Hat, Inc. * Copyright (C) 2005, 2007, 2012 Red Hat, Inc.
* *
* Daniel Veillard <veillard@redhat.com> * Daniel Veillard <veillard@redhat.com>
*/ */
...@@ -16,6 +16,8 @@ ...@@ -16,6 +16,8 @@
#include "typewrappers.h" #include "typewrappers.h"
#include "memory.h"
#ifndef Py_CAPSULE_H #ifndef Py_CAPSULE_H
typedef void(*PyCapsule_Destructor)(void *, void *); typedef void(*PyCapsule_Destructor)(void *, void *);
#endif #endif
...@@ -86,7 +88,7 @@ libvirt_charPtrSizeWrap(char *str, Py_ssize_t size) ...@@ -86,7 +88,7 @@ libvirt_charPtrSizeWrap(char *str, Py_ssize_t size)
return (Py_None); return (Py_None);
} }
ret = PyString_FromStringAndSize(str, size); ret = PyString_FromStringAndSize(str, size);
free(str); VIR_FREE(str);
return (ret); return (ret);
} }
...@@ -100,7 +102,7 @@ libvirt_charPtrWrap(char *str) ...@@ -100,7 +102,7 @@ libvirt_charPtrWrap(char *str)
return (Py_None); return (Py_None);
} }
ret = PyString_FromString(str); ret = PyString_FromString(str);
free(str); VIR_FREE(str);
return (ret); return (ret);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册