Mercurial > hg > xemacs-beta
diff src/syswindows.h @ 442:abe6d1db359e r21-2-36
Import from CVS: tag r21-2-36
author | cvs |
---|---|
date | Mon, 13 Aug 2007 11:35:02 +0200 |
parents | |
children | 0493e9f3c27f |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/syswindows.h Mon Aug 13 11:35:02 2007 +0200 @@ -0,0 +1,292 @@ +/* Copyright (C) 2000 Free Software Foundation, Inc. + Copyright (C) 2000 Ben Wing. + +This file is part of XEmacs. + +XEmacs is free software; you can redistribute it and/or modify it +under the terms of the GNU General Public License as published by the +Free Software Foundation; either version 2, or (at your option) any +later version. + +XEmacs is distributed in the hope that it will be useful, but WITHOUT +ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or +FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License +for more details. + +You should have received a copy of the GNU General Public License +along with XEmacs; see the file COPYING. If not, write to +the Free Software Foundation, Inc., 59 Temple Place - Suite 330, +Boston, MA 02111-1307, USA. */ + +/* Synched up with: Not in FSF. */ + +/* Authorship: + + Created May 2000 by Andy Piper. + Windows-Mule stuff added by Ben Wing. +*/ + +#ifndef INCLUDED_syswindows_h_ +#define INCLUDED_syswindows_h_ + +/* Note that there are currently FOUR different general + Windows-related include files in src! + + Uses are approximately: + + syswindows.h: Mostly a wrapper around <windows.h>, including missing + defines as necessary. Also includes stuff needed on both Cygwin and + native Windows, regardless of window system chosen. + + console-msw.h: Used on both Cygwin and native Windows, but only when + native window system (as opposed to X) chosen. + + nt.h: [will be renamed to win32.h] Used only on native Windows, and + regardless of window system chosen -- but used on both purely native + Windows (s/windowsnt.h) and MinGW (s/mingw32.h). + + ntheap.h: Used only on native Windows and only when standard dumping + mechanism (unexnt.c) used. + + All of the last three files include the first. +*/ + +#ifndef WIN32_LEAN_AND_MEAN +#define WIN32_LEAN_AND_MEAN +#endif + +#include <windows.h> + +#if (defined (CYGWIN) || defined(MINGW)) && \ + CYGWIN_VERSION_DLL_MAJOR < 21 +extern BOOL WINAPI DdeFreeStringHandle(DWORD,HSZ); +extern BOOL WINAPI PlaySound(LPCSTR,HMODULE,DWORD); +#define stricmp strcasecmp +#define FONTENUMPROC FONTENUMEXPROC +#define ntmTm ntmentm +#elif defined (WIN32_LEAN_AND_MEAN) +#ifdef HAVE_X_WINDOWS +/* Christ almighty. The problems you get when combining two large code bases, + neither with any respect for namespace purity. */ +#undef Status +#endif +#include <winspool.h> +#ifdef HAVE_X_WINDOWS +#define Status int +#endif +#include <mmsystem.h> +#include <shellapi.h> +#include <ddeml.h> +#endif + +/* mmsystem.h defines. */ +#ifndef SND_ASYNC +#define SND_ASYNC 1 +#endif +#ifndef SND_NODEFAULT +#define SND_NODEFAULT 2 +#endif +#ifndef SND_MEMORY +#define SND_MEMORY 4 +#endif +#ifndef SND_FILENAME +#define SND_FILENAME 0x2000L +#endif + +/* winspool.h defines. */ +#ifndef PHYSICALWIDTH +#define PHYSICALWIDTH 110 +#endif +#ifndef PHYSICALHEIGHT +#define PHYSICALHEIGHT 111 +#endif +#ifndef PHYSICALOFFSETX +#define PHYSICALOFFSETX 112 +#endif +#ifndef PHYSICALOFFSETY +#define PHYSICALOFFSETY 113 +#endif + +/* windows.h defines. */ +#if defined (CYGWIN) && (CYGWIN_VERSION_DLL_MAJOR < 20) +typedef NMHDR *LPNMHDR; +#endif + +#ifndef SPI_GETWHEELSCROLLLINES +#define SPI_GETWHEELSCROLLLINES 104 +#endif +#ifndef WHEEL_PAGESCROLL +#define WHEEL_PAGESCROLL (UINT_MAX) +#endif +#ifndef WHEEL_DELTA +#define WHEEL_DELTA 120 +#endif +#ifndef WM_MOUSEWHEEL +#define WM_MOUSEWHEEL 0x20A +#endif +#ifndef VK_APPS +#define VK_APPS 0x5D +#endif +#ifndef SIF_TRACKPOS +#define SIF_TRACKPOS 0x0010 +#endif +#ifndef FW_BLACK +#define FW_BLACK FW_HEAVY +#endif +#ifndef FW_ULTRABOLD +#define FW_ULTRABOLD FW_EXTRABOLD +#endif +#ifndef FW_DEMIBOLD +#define FW_DEMIBOLD FW_SEMIBOLD +#endif +#ifndef FW_ULTRALIGHT +#define FW_ULTRALIGHT FW_EXTRALIGHT +#endif +#ifndef APPCMD_FILTERINITS +#define APPCMD_FILTERINITS 0x20L +#endif +#ifndef CBF_FAIL_SELFCONNECTIONS +#define CBF_FAIL_SELFCONNECTIONS 0x1000 +#endif +#ifndef CBF_SKIP_ALLNOTIFICATIONS +#define CBF_SKIP_ALLNOTIFICATIONS 0x3C0000 +#endif +#ifndef CBF_FAIL_ADVISES +#define CBF_FAIL_ADVISES 0x4000 +#endif +#ifndef CBF_FAIL_POKES +#define CBF_FAIL_POKES 0x10000 +#endif +#ifndef CBF_FAIL_REQUESTS +#define CBF_FAIL_REQUESTS 0x20000 +#endif +#ifndef SZDDESYS_TOPIC +#define SZDDESYS_TOPIC "System" +#endif +#ifndef JOHAB_CHARSET +#define JOHAB_CHARSET 130 +#endif +#ifndef MAC_CHARSET +#define MAC_CHARSET 77 +#endif + +/***************************************************************/ + +/* Definitions for Mule under MS Windows */ + +#include <wchar.h> + +#ifdef CYGWIN + +/* All but wcscmp and wcslen left out of Cygwin headers -- but present + in /usr/include/mingw32/string.h! */ +wchar_t* wcscat (wchar_t*, const wchar_t*); +wchar_t* wcschr (const wchar_t*, wchar_t); +int wcscoll (const wchar_t*, const wchar_t*); +wchar_t* wcscpy (wchar_t*, const wchar_t*); +size_t wcscspn (const wchar_t*, const wchar_t*); +/* Note: No wcserror in CRTDLL. */ +wchar_t* wcsncat (wchar_t*, const wchar_t*, size_t); +int wcsncmp(const wchar_t*, const wchar_t*, size_t); +wchar_t* wcsncpy(wchar_t*, const wchar_t*, size_t); +wchar_t* wcspbrk(const wchar_t*, const wchar_t*); +wchar_t* wcsrchr(const wchar_t*, wchar_t); +size_t wcsspn(const wchar_t*, const wchar_t*); +wchar_t* wcsstr(const wchar_t*, const wchar_t*); +wchar_t* wcstok(wchar_t*, const wchar_t*); +size_t wcsxfrm(wchar_t*, const wchar_t*, size_t); + +#endif /* CYGWIN */ + +// extern int mswindows_windows9x_p; +/* #define XEUNICODE_P (!mswindows_windows9x_p) */ +#define XEUNICODE_P 0 + +#define XETCHAR_SIZE (XEUNICODE_P ? sizeof (WCHAR) : sizeof (CHAR)) +#define MAX_XETCHAR_SIZE sizeof (WCHAR) +#define XETEXT1(arg) (XEUNICODE_P ? ((char *) (L##arg)) : (arg)) +/* We need to do this indirection in case ARG is also a manifest constant. + I don't really understand why. --ben */ +#define XETEXT(arg) XETEXT1(arg) +#define XECOPY_TCHAR(ptr, ch) \ + (XEUNICODE_P ? (* (LPWSTR) (ptr) = L##ch) : (* (LPSTR) (ptr) = (ch))) +#define xetcslen(arg) (XEUNICODE_P ? wcslen ((wchar_t *) arg) : strlen (arg)) +#define xetcscmp(s1, s2) \ + (XEUNICODE_P ? wcscmp ((wchar_t *) s1, (wchar_t *) s2) \ + : strcmp (s1, s2)) +#define xetcscpy(s1, s2) \ + (XEUNICODE_P ? (char *) wcscpy ((wchar_t *) s1, (wchar_t *) s2) \ + : strcpy (s1, s2)) +#define xetcschr(s, ch) \ + (XEUNICODE_P ? (char *) wcschr ((wchar_t *) s, (WCHAR) ch) \ + : strchr (s, ch)) +#define xetcsrchr(s, ch) \ + (XEUNICODE_P ? (char *) wcsrchr ((wchar_t *) s, (WCHAR) ch) \ + : strrchr (s, ch)) + + +#define LOCAL_FILE_FORMAT_TO_TSTR(path, out) \ +do { \ + Bufbyte *lttff; \ + \ + LOCAL_TO_WIN32_FILE_FORMAT (path, lttff); \ + C_STRING_TO_EXTERNAL (lttff, out, Qmswindows_tstr); \ +} while (0) + +Lisp_Object tstr_to_local_file_format (Extbyte *pathout); + +#ifdef CYGWIN +#define LOCAL_TO_WIN32_FILE_FORMAT(path, pathout) \ +do { \ + Lisp_Object ltwff1 = (path); \ + int ltwff2 = \ + cygwin_posix_to_win32_path_list_buf_size (XSTRING_DATA (ltwff1)); \ + pathout = (Bufbyte *) alloca (ltwff2); \ + cygwin_posix_to_win32_path_list (XSTRING_DATA (ltwff1), pathout); \ +} while (0) +#else +#define LOCAL_TO_WIN32_FILE_FORMAT(path, pathout) \ +do { \ + (pathout) = XSTRING_DATA (path); \ +} while (0) +#endif + +#ifdef CYGWIN +#define WIN32_TO_LOCAL_FILE_FORMAT(path, pathout) \ +do { \ + Bufbyte *wtlff1 = (path); \ + int wtlff2 = \ + cygwin_win32_to_posix_path_list_buf_size (wtlff1); \ + Bufbyte *wtlff3 = (Bufbyte *) alloca (wtlff2); \ + cygwin_win32_to_posix_path_list (wtlff1, wtlff3); \ + (pathout) = build_string (wtlff3); \ +} while (0) +#else +#define WIN32_TO_LOCAL_FILE_FORMAT(path, pathout) \ +do { \ + (pathout) = build_string (path); \ +} while (0) +#endif + +extern BOOL (WINAPI *xSwitchToThread) (VOID); + +extern HKL (WINAPI *xGetKeyboardLayout) (DWORD); +extern BOOL (WINAPI *xSetMenuDefaultItem) (HMENU, UINT, UINT); +extern BOOL (WINAPI *xInsertMenuItemA) (HMENU, UINT, BOOL, LPCMENUITEMINFOA); +extern BOOL (WINAPI *xInsertMenuItemW) (HMENU, UINT, BOOL, LPCMENUITEMINFOW); +extern HANDLE (WINAPI *xLoadImageA) (HINSTANCE, LPCSTR, UINT, int, int, UINT); +extern HANDLE (WINAPI *xLoadImageW) (HINSTANCE, LPCWSTR, UINT, int, int, UINT); +extern ATOM (WINAPI *xRegisterClassExA) (CONST WNDCLASSEXA *); +extern ATOM (WINAPI *xRegisterClassExW) (CONST WNDCLASSEXW *); + +extern int (WINAPI *xEnumFontFamiliesExA) (HDC, LPLOGFONTA, FONTENUMPROCA, + LPARAM, DWORD); +extern int (WINAPI *xEnumFontFamiliesExW) (HDC, LPLOGFONTW, FONTENUMPROCW, + LPARAM, DWORD); + +extern DWORD (WINAPI *xSHGetFileInfoA) (LPCSTR, DWORD, SHFILEINFOA FAR *, UINT, + UINT); +extern DWORD (WINAPI *xSHGetFileInfoW) (LPCWSTR, DWORD, SHFILEINFOW FAR *, + UINT, UINT); + +#endif /* INCLUDED_syswindows_h_ */