]> git.eshelyaron.com Git - emacs.git/commitdiff
Define get_proc_addr in Cygwin-w32 build
authorAndy Moreton <andrewjmoreton@gmail.com>
Mon, 20 Aug 2018 21:00:27 +0000 (17:00 -0400)
committerKen Brown <kbrown@cornell.edu>
Mon, 20 Aug 2018 21:04:24 +0000 (17:04 -0400)
* src/w32common.h (get_proc_addr, DEF_DLL_FN, LOAD_DLL_FN): Move
definitions here from src/w32.h.
* src/decompress.c [WINDOWSNT]:
* src/gnutls.c [WINDOWSNT]:
* src/image.c [WINDOWSNT]:
* src/json.c [WINDOWSNT]:
* src/lcms.c [WINDOWSNT]:
* src/w32font.c [WINDOWSNT]:
* src/w32uniscribe.c:
* src/xml.c [WINDOWSNT]: Include w32common.h.

src/decompress.c
src/gnutls.c
src/image.c
src/json.c
src/lcms.c
src/w32.h
src/w32common.h
src/w32font.c
src/w32uniscribe.c
src/xml.c

index 9f7fbe41952d16efa7555986b5ec3f7272b9467d..283633821689b240ac519c0d1e040a1e044849ac 100644 (file)
@@ -30,6 +30,7 @@ along with GNU Emacs.  If not, see <https://www.gnu.org/licenses/>.  */
 
 #ifdef WINDOWSNT
 # include <windows.h>
+# include "w32common.h"
 # include "w32.h"
 
 DEF_DLL_FN (int, inflateInit2_,
index 2d455ea1ba12b5923f82b02af5d201b4b1cf552f..aa5c97532f076408be509866b43c741bbf7be95f 100644 (file)
@@ -58,6 +58,7 @@ along with GNU Emacs.  If not, see <https://www.gnu.org/licenses/>.  */
 
 # ifdef WINDOWSNT
 #  include <windows.h>
+#  include "w32common.h"
 #  include "w32.h"
 # endif
 
index 7866b9cc46368188df674cf2c4ff795f9cf6e930..b9ff3f25c43f2d3e916c9af2ff67dfc63ccf40cc 100644 (file)
@@ -77,6 +77,7 @@ typedef struct x_bitmap_record Bitmap_Record;
 
 /* We need (or want) w32.h only when we're _not_ compiling for Cygwin.  */
 #ifdef WINDOWSNT
+# include "w32common.h"
 # include "w32.h"
 #endif
 
index 4e413a2bd5184d67d0c6a1707ba140e8bf2cd027..4e46640a0c631352e439db44677e4b0f6725720b 100644 (file)
@@ -34,6 +34,7 @@ along with GNU Emacs.  If not, see <https://www.gnu.org/licenses/>.  */
 
 #ifdef WINDOWSNT
 # include <windows.h>
+# include "w32common.h"
 # include "w32.h"
 
 DEF_DLL_FN (void, json_set_alloc_funcs,
index a3a98223060ebd0cef827a1e6f313d8976eec2bb..f37f843e5005e523f88af98f83d253f8f2cfc8e2 100644 (file)
@@ -34,6 +34,7 @@ typedef struct
 
 #ifdef WINDOWSNT
 # include <windows.h>
+# include "w32common.h"
 # include "w32.h"
 
 DEF_DLL_FN (cmsFloat64Number, cmsCIE2000DeltaE,
index a053ee0fc4b7b11e79fcabb2a71a65bd1be3d221..9c219cdda620d76f631875b3f965b423fdd9093d 100644 (file)
--- a/src/w32.h
+++ b/src/w32.h
@@ -164,10 +164,6 @@ extern void reset_standard_handles (int in, int out,
 /* Return the string resource associated with KEY of type TYPE.  */
 extern LPBYTE w32_get_resource (const char * key, LPDWORD type);
 
-/* Load a function from a DLL.  Defined in this file.  */
-typedef void (* VOIDFNPTR) (void);
-INLINE VOIDFNPTR get_proc_addr (HINSTANCE handle, LPCSTR fname);
-
 extern void release_listen_threads (void);
 extern void init_ntproc (int);
 extern void term_ntproc (int);
@@ -245,33 +241,4 @@ extern ssize_t emacs_gnutls_push (gnutls_transport_ptr_t p,
                                   const void* buf, size_t sz);
 #endif /* HAVE_GNUTLS */
 
-
-
-/* Load a function address from a DLL. Cast the result via "VOIDFNPTR"
-   to pacify -Wcast-function-type in GCC 8.1.  */
-INLINE VOIDFNPTR
-get_proc_addr (HINSTANCE handle, LPCSTR fname)
-{
-  return (VOIDFNPTR) GetProcAddress (handle, fname);
-}
-
-/* Define a function that will be loaded from a DLL.  The variable
-   arguments should contain the argument list for the function, and
-   optionally be followed by function attributes.  For example:
-   DEF_DLL_FN (void, png_longjmp, (png_structp, int) PNG_NORETURN);
-  */
-#define DEF_DLL_FN(type, func, ...)                     \
-  typedef type (CDECL *W32_PFN_##func) __VA_ARGS__;     \
-  static W32_PFN_##func fn_##func
-
-/* Load a function from the DLL.  */
-#define LOAD_DLL_FN(lib, func)                                         \
-  do                                                                   \
-    {                                                                  \
-      fn_##func = (W32_PFN_##func) get_proc_addr (lib, #func);   \
-      if (!fn_##func)                                                  \
-       return false;                                                   \
-    }                                                                  \
-  while (false)
-
 #endif /* EMACS_W32_H */
index af548dd8ea1b318c465f1c9520d51bba7b80ca8d..4981bdfd89ac9ee86dbf623d6ffb45dcca8d4bfe 100644 (file)
@@ -50,4 +50,34 @@ extern int os_subtype;
 /* Cache system info, e.g., the NT page size.  */
 extern void cache_system_info (void);
 
+typedef void (* VOIDFNPTR) (void);
+
+/* Load a function address from a DLL.  Cast the result via VOIDFNPTR
+   to pacify -Wcast-function-type in GCC 8.1.  The return value must
+   be cast to the correct function pointer type.  */
+INLINE VOIDFNPTR
+get_proc_addr (HINSTANCE handle, LPCSTR fname)
+{
+  return (VOIDFNPTR) GetProcAddress (handle, fname);
+}
+
+/* Define a function that will be loaded from a DLL.  The variable
+   arguments should contain the argument list for the function, and
+   optionally be followed by function attributes.  For example:
+   DEF_DLL_FN (void, png_longjmp, (png_structp, int) PNG_NORETURN);
+  */
+#define DEF_DLL_FN(type, func, ...)                     \
+  typedef type (CDECL *W32_PFN_##func) __VA_ARGS__;     \
+  static W32_PFN_##func fn_##func
+
+/* Load a function from the DLL.  */
+#define LOAD_DLL_FN(lib, func)                                         \
+  do                                                                   \
+    {                                                                  \
+      fn_##func = (W32_PFN_##func) get_proc_addr (lib, #func);         \
+      if (!fn_##func)                                                  \
+       return false;                                                   \
+    }                                                                  \
+  while (false)
+
 #endif /* W32COMMON_H */
index f6130618323560c70499b53076fd5b10ba8ec4dd..798869b5cafa1ad94455ad30ac3295d357c8ed39 100644 (file)
@@ -29,6 +29,7 @@ along with GNU Emacs.  If not, see <https://www.gnu.org/licenses/>.  */
 #include "coding.h"    /* for ENCODE_SYSTEM, DECODE_SYSTEM */
 #include "w32font.h"
 #ifdef WINDOWSNT
+#include "w32common.h"
 #include "w32.h"
 #endif
 
index 54f161690b7d0a404380608b1ee632e5619c7b69..29c9c7a0bd19e76e58eee4aa2bcf5f5527745af7 100644 (file)
@@ -36,6 +36,7 @@ along with GNU Emacs.  If not, see <https://www.gnu.org/licenses/>.  */
 #include "composite.h"
 #include "font.h"
 #include "w32font.h"
+#include "w32common.h"
 
 struct uniscribe_font_info
 {
index 5f3ccc85c86489fa8429db233358d845701fefc8..e85891d2a292edd789c05097c143badf0e11d6ba 100644 (file)
--- a/src/xml.c
+++ b/src/xml.c
@@ -31,6 +31,7 @@ along with GNU Emacs.  If not, see <https://www.gnu.org/licenses/>.  */
 #ifdef WINDOWSNT
 
 # include <windows.h>
+# include "w32common.h"
 # include "w32.h"
 
 DEF_DLL_FN (htmlDocPtr, htmlReadMemory,