diff options
| author | Philipp Stephani | 2019-04-24 19:35:36 +0200 |
|---|---|---|
| committer | Philipp Stephani | 2019-04-24 23:27:43 +0200 |
| commit | 4eb7f9ef595c10df1ea78518b2f0410a0e79ec70 (patch) | |
| tree | b5721d7166a2b7d7285879bcb06b3a122182f6ff /test | |
| parent | 553220fca670ec13180e0763bc9338fbf8ed4b30 (diff) | |
| download | emacs-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.in | 3 | ||||
| -rw-r--r-- | test/data/emacs-module/mod-test.c | 9 |
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 | |||
| 257 | HYBRID_MALLOC = @HYBRID_MALLOC@ | 257 | HYBRID_MALLOC = @HYBRID_MALLOC@ |
| 258 | LIBEGNU_ARCHIVE = ../lib/lib$(if $(HYBRID_MALLOC),e)gnu.a | 258 | LIBEGNU_ARCHIVE = ../lib/lib$(if $(HYBRID_MALLOC),e)gnu.a |
| 259 | GMP_LIB = @GMP_LIB@ | 259 | GMP_LIB = @GMP_LIB@ |
| 260 | GMP_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) |
| 273 | endif | 274 | endif |
| 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 | ||
| 37 | int plugin_is_GPL_compatible; | 42 | int plugin_is_GPL_compatible; |