aboutsummaryrefslogtreecommitdiffstats
path: root/test
diff options
context:
space:
mode:
authorPhilipp Stephani2019-04-24 19:35:36 +0200
committerPhilipp Stephani2019-04-24 23:27:43 +0200
commit4eb7f9ef595c10df1ea78518b2f0410a0e79ec70 (patch)
treeb5721d7166a2b7d7285879bcb06b3a122182f6ff /test
parent553220fca670ec13180e0763bc9338fbf8ed4b30 (diff)
downloademacs-4eb7f9ef595c10df1ea78518b2f0410a0e79ec70.tar.gz
emacs-4eb7f9ef595c10df1ea78518b2f0410a0e79ec70.zip
Unbreak build when building without GMP support.
Add support for a new preprocessor macro EMACS_MODULE_HAVE_MPZ_T to emacs-module.h. If this macro is defined, assume that mpz_t is already defined and don’t include gmp.h. Don’t document the new macro for now, as it’s unclear whether we want to support this in modules outside the Emacs tree. * src/emacs-module.h.in: Allow user to prevent inclusion of gmp.h. * src/emacs-module.c: Use mini-gmp if GMP is unavailable. Don’t include gmp.h. * src/lisp.h: Don’t require gmp.h. It’s not needed for lisp.h. * test/Makefile.in (GMP_LIB, GMP_OBJ): New variables. ($(test_module)): Use them. * test/data/emacs-module/mod-test.c: Use mini-gmp if GMP is unavailable.
Diffstat (limited to 'test')
-rw-r--r--test/Makefile.in3
-rw-r--r--test/data/emacs-module/mod-test.c9
2 files changed, 9 insertions, 3 deletions
diff --git a/test/Makefile.in b/test/Makefile.in
index 2282ccd951c..ec20a427ba5 100644
--- a/test/Makefile.in
+++ b/test/Makefile.in
@@ -257,6 +257,7 @@ endif
257HYBRID_MALLOC = @HYBRID_MALLOC@ 257HYBRID_MALLOC = @HYBRID_MALLOC@
258LIBEGNU_ARCHIVE = ../lib/lib$(if $(HYBRID_MALLOC),e)gnu.a 258LIBEGNU_ARCHIVE = ../lib/lib$(if $(HYBRID_MALLOC),e)gnu.a
259GMP_LIB = @GMP_LIB@ 259GMP_LIB = @GMP_LIB@
260GMP_OBJ = $(if @GMP_OBJ@, ../src/@GMP_OBJ@)
260 261
261# Note: emacs-module.h is generated from emacs-module.h.in, hence we 262# Note: emacs-module.h is generated from emacs-module.h.in, hence we
262# look in ../src, not $(srcdir)/../src. 263# look in ../src, not $(srcdir)/../src.
@@ -269,7 +270,7 @@ src/emacs-module-tests.log: $(test_module)
269$(test_module): $(test_module:${SO}=.c) ../src/emacs-module.h $(LIBEGNU_ARCHIVE) 270$(test_module): $(test_module:${SO}=.c) ../src/emacs-module.h $(LIBEGNU_ARCHIVE)
270 $(AM_V_at)${MKDIR_P} $(dir $@) 271 $(AM_V_at)${MKDIR_P} $(dir $@)
271 $(AM_V_CCLD)$(CC) -shared $(CPPFLAGS) $(MODULE_CFLAGS) $(LDFLAGS) \ 272 $(AM_V_CCLD)$(CC) -shared $(CPPFLAGS) $(MODULE_CFLAGS) $(LDFLAGS) \
272 -o $@ $< $(LIBEGNU_ARCHIVE) $(GMP_LIB) 273 -o $@ $< $(LIBEGNU_ARCHIVE) $(GMP_LIB) $(GMP_OBJ)
273endif 274endif
274 275
275## Check that there is no 'automated' subdirectory, which would 276## Check that there is no 'automated' subdirectory, which would
diff --git a/test/data/emacs-module/mod-test.c b/test/data/emacs-module/mod-test.c
index 8ac08f71534..b7007bd80ff 100644
--- a/test/data/emacs-module/mod-test.c
+++ b/test/data/emacs-module/mod-test.c
@@ -27,11 +27,16 @@ along with GNU Emacs. If not, see <https://www.gnu.org/licenses/>. */
27#include <string.h> 27#include <string.h>
28#include <time.h> 28#include <time.h>
29 29
30#ifdef HAVE_GMP
31#include <gmp.h>
32#else
33#include "mini-gmp.h"
34#define EMACS_MODULE_HAVE_MPZ_T
35#endif
36
30#define EMACS_MODULE_GMP 37#define EMACS_MODULE_GMP
31#include <emacs-module.h> 38#include <emacs-module.h>
32 39
33#include <gmp.h>
34
35#include "timespec.h" 40#include "timespec.h"
36 41
37int plugin_is_GPL_compatible; 42int plugin_is_GPL_compatible;