diff options
Diffstat (limited to 'libX11')
39 files changed, 1303 insertions, 279 deletions
| diff --git a/libX11/cpprules.mak b/libX11/cpprules.mak new file mode 100644 index 000000000..25e6e259b --- /dev/null +++ b/libX11/cpprules.mak @@ -0,0 +1,18 @@ +
 +ifdef x11thislocaledir
 +
 +$(x11thislocaledir)\%: %.pre
 +	cl /nologo /EP $< -DXCOMM\#\# > $@
 +
 +$(x11thislocaledir):
 +	$(CREATEDIR)
 +
 +all: $(x11thislocaledir)
 +endif
 +
 +$(reparse $(locales:%=$(X11_LOCALEDATADIR)\%\XLC_LOCALE : %\XLC_LOCALE.pre;	cl /nologo /EP $$< -DXCOMM\#\# > $$@;; ))
 +
 +$(reparse $(locales:%=$(X11_LOCALEDATADIR)\%\Compose : %\Compose.pre;	cl /nologo /EP $$< -DXCOMM\#\# > $$@;; ))
 +
 +$(reparse $(locales:%=$(X11_LOCALEDATADIR)\%\XI18N_OBJS : %\XI18N_OBJS;	copy $$< $$@;; ))
 +
 diff --git a/libX11/include/X11/Xlib.h b/libX11/include/X11/Xlib.h index 3d22721e1..4c192d883 100644 --- a/libX11/include/X11/Xlib.h +++ b/libX11/include/X11/Xlib.h @@ -83,8 +83,8 @@ _Xmblen(  typedef char *XPointer;
 -#define Bool int
 -#define Status int
 +typedef int Bool;
 +typedef int Status;
  #define True 1
  #define False 0
 diff --git a/libX11/include/X11/Xregion.h b/libX11/include/X11/Xregion.h index b441312dc..1ae16c487 100644 --- a/libX11/include/X11/Xregion.h +++ b/libX11/include/X11/Xregion.h @@ -58,8 +58,10 @@ typedef struct {  #define TRUE 1
  #define FALSE 0
 +#ifndef MAXSHORT
  #define MAXSHORT 32767
  #define MINSHORT -MAXSHORT
 +#endif
  #ifndef MAX
  #define MAX(a,b) (((a) > (b)) ? (a) : (b))
  #endif
 diff --git a/libX11/modules/im/ximcp/imLcLkup.c b/libX11/modules/im/ximcp/imLcLkup.c index 80e4cfef1..22850a964 100644 --- a/libX11/modules/im/ximcp/imLcLkup.c +++ b/libX11/modules/im/ximcp/imLcLkup.c @@ -61,10 +61,11 @@ _XimLocalMbLookupString(XIC xic, XKeyEvent *ev, char *buffer, int bytes,  	    ||(ic->private.local.brl_committed != 0))) {  	if (ic->private.local.brl_committed != 0) { /* Braille Event */  	    unsigned char pattern = ic->private.local.brl_committed; -	    char mb[XLC_PUBLIC(ic->core.im->core.lcd, mb_cur_max)]; +	    char *mb=malloc(XLC_PUBLIC(ic->core.im->core.lcd, mb_cur_max));  	    ret = _Xlcwctomb(ic->core.im->core.lcd, mb, BRL_UC_ROW | pattern);  	    if(ret > bytes) {  		if(status) *status = XBufferOverflow; +            free(mb);  		return(ret);  	    }  	    if(keysym) { @@ -73,6 +74,7 @@ _XimLocalMbLookupString(XIC xic, XKeyEvent *ev, char *buffer, int bytes,  	    } else  		if(status) *status = XLookupChars;  	    memcpy(buffer, mb, ret); +            free(mb);  	} else { /* Composed Event */  	    ret = strlen(&mb[b[ic->private.local.composed].mb]);  	    if(ret > bytes) { diff --git a/libX11/modules/im/ximcp/imTrans.c b/libX11/modules/im/ximcp/imTrans.c index 7673279c6..d6c5fc6ad 100644 --- a/libX11/modules/im/ximcp/imTrans.c +++ b/libX11/modules/im/ximcp/imTrans.c @@ -56,6 +56,7 @@ PERFORMANCE OF THIS SOFTWARE.  #include <X11/Xatom.h>
  #include <X11/Xmd.h>
  #include "Xlibint.h"
 +#include <X11/Xwindows.h>
  #include <X11/Xtrans/Xtrans.h>
  #include "Xlcint.h"
  #include "Ximint.h"
 diff --git a/libX11/modules/im/ximcp/makefile b/libX11/modules/im/ximcp/makefile new file mode 100644 index 000000000..c1c40a1c7 --- /dev/null +++ b/libX11/modules/im/ximcp/makefile @@ -0,0 +1,35 @@ +DEFINES += XIM_t TRANS_CLIENT + +LIBRARY=libximcp + +CSRCS = \ +	imCallbk.c \ +	imDefFlt.c \ +	imDefIc.c \ +	imDefIm.c \ +	imDefLkup.c \ +	imDispch.c \ +	imEvToWire.c \ +	imExten.c \ +	imImSw.c \ +	imInsClbk.c \ +	imInt.c \ +	imLcFlt.c \ +	imLcGIc.c \ +	imLcIc.c \ +	imLcIm.c \ +	imLcLkup.c \ +	imLcPrs.c \ +	imLcSIc.c \ +	imRmAttr.c \ +	imRm.c \ +	imThaiFlt.c \ +	imThaiIc.c \ +	imThaiIm.c \ +	imTrans.c \ +	imTransR.c \ +	imTrX.c + +DEFINES += XKB_IN_SERVER +INCLUDES += ..\..\..\include\X11 ..\..\..\src\xlibi18n + diff --git a/libX11/modules/lc/Utf8/makefile b/libX11/modules/lc/Utf8/makefile new file mode 100644 index 000000000..6f814c760 --- /dev/null +++ b/libX11/modules/lc/Utf8/makefile @@ -0,0 +1,6 @@ +LIBRARY = libxlcUTF8Load + +CSRCS=lcUTF8Load.c + +INCLUDES += ..\..\..\include\X11 ..\..\..\src\xlibi18n ..\..\..\src + diff --git a/libX11/modules/lc/def/makefile b/libX11/modules/lc/def/makefile new file mode 100644 index 000000000..b89ce455d --- /dev/null +++ b/libX11/modules/lc/def/makefile @@ -0,0 +1,5 @@ +LIBRARY = libxlcDef +CSRCS = lcDefConv.c + +INCLUDES += ..\..\..\include\X11 ..\..\..\src\xlibi18n ..\..\..\src + diff --git a/libX11/modules/lc/gen/makefile b/libX11/modules/lc/gen/makefile new file mode 100644 index 000000000..8fe90a5e6 --- /dev/null +++ b/libX11/modules/lc/gen/makefile @@ -0,0 +1,6 @@ +LIBRARY = liblcGenConvLoad + +CSRCS=lcGenConv.c + +INCLUDES += ..\..\..\include\X11 ..\..\..\src\xlibi18n ..\..\..\src + diff --git a/libX11/modules/lc/xlocale/makefile b/libX11/modules/lc/xlocale/makefile new file mode 100644 index 000000000..9649982bd --- /dev/null +++ b/libX11/modules/lc/xlocale/makefile @@ -0,0 +1,8 @@ +LIBRARY = libxlocale + +CSRCS = \ +	lcEuc.c \ +	lcJis.c \ +	lcSjis.c + +INCLUDES += ..\..\..\include ..\..\..\include\X11 ..\..\..\src\xlibi18n  ..\..\..\src\xkb  ..\..\..\src\xcms ..\..\..\src diff --git a/libX11/modules/om/generic/makefile b/libX11/modules/om/generic/makefile new file mode 100644 index 000000000..88c68a68b --- /dev/null +++ b/libX11/modules/om/generic/makefile @@ -0,0 +1,16 @@ +LIBRARY = libxomGeneric + +CSRCS = \ +	omDefault.c \ +	omGeneric.c \ +	omImText.c \ +	omText.c \ +	omTextEsc.c \ +	omTextExt.c \ +	omTextPer.c \ +	omXChar.c + +DEFINES += XKB_IN_SERVER +INCLUDES += ..\..\..\include\X11 ..\..\..\src\xlibi18n ..\..\..\src ..\..\..\src\xlibi18n + + diff --git a/libX11/nls/makefile b/libX11/nls/makefile new file mode 100644 index 000000000..e6bf47297 --- /dev/null +++ b/libX11/nls/makefile @@ -0,0 +1,85 @@ +X11_LOCALEDATADIR = ..\..\xorg-server\locale
 +
 +x11localedir = $(X11_LOCALEDATADIR)
 +x11locale_DATA = locale.alias locale.dir compose.dir
 +locales = \
 +	am_ET.UTF-8		\
 +	armscii-8		\
 +	C			\
 +	el_GR.UTF-8		\
 +	en_US.UTF-8		\
 +	fi_FI.UTF-8		\
 +	georgian-academy	\
 +	georgian-ps		\
 +	ibm-cp1133		\
 +	iscii-dev		\
 +	isiri-3342		\
 +	iso8859-1		\
 +	iso8859-10		\
 +	iso8859-11		\
 +	iso8859-13		\
 +	iso8859-14		\
 +	iso8859-15		\
 +	iso8859-2		\
 +	iso8859-3		\
 +	iso8859-4		\
 +	iso8859-5		\
 +	iso8859-6		\
 +	iso8859-7		\
 +	iso8859-8		\
 +	iso8859-9		\
 +	iso8859-9e		\
 +	ja			\
 +	ja.JIS			\
 +	ja_JP.UTF-8		\
 +	ja.S90			\
 +	ja.SJIS			\
 +	ja.U90			\
 +	ko			\
 +	koi8-c			\
 +	koi8-r			\
 +	koi8-u			\
 +	ko_KR.UTF-8		\
 +	microsoft-cp1251	\
 +	microsoft-cp1255	\
 +	microsoft-cp1256	\
 +	mulelao-1		\
 +	nokhchi-1		\
 +	pt_BR.UTF-8		\
 +	ru_RU.UTF-8		\
 +	tatar-cyr		\
 +	th_TH			\
 +	th_TH.UTF-8		\
 +	tscii-0			\
 +	vi_VN.tcvn		\
 +	vi_VN.viscii		\
 +	zh_CN			\
 +	zh_CN.gb18030		\
 +	zh_CN.gbk		\
 +	zh_CN.UTF-8		\
 +	zh_HK.big5		\
 +	zh_HK.big5hkscs		\
 +	zh_HK.UTF-8		\
 +	zh_TW			\
 +	zh_TW.big5		\
 +	zh_TW.UTF-8
 +
 +include ../cpprules.mak
 +
 +
 +$(X11_LOCALEDATADIR)\%: %.pre
 +	cl /nologo /EP $< -DXCOMM\#\# > $<.l1
 +	sed -e "/^[^\#][^        ]*:/s/://" -e "/^[^\#].*[        ].*:/d" < $<.l1 > $<.l2
 +	type $<.l2 $<.l1 > $@
 +	del $<.l1
 +	del $<.l2
 +
 +# Per-locale data files
 +
 +nobase_dist_x11locale_DATA = $(locales:%=%\XI18N_OBJS)
 +
 +nobase_x11locale_DATA = $(locales:%=%\XLC_LOCALE) $(locales:%=%\Compose)
 +
 +all_DATA = $(nobase_dist_x11locale_DATA) $(nobase_x11locale_DATA) $(x11locale_DATA)
 +
 +all: $(all_DATA:%=$(X11_LOCALEDATADIR)\%)
 diff --git a/libX11/src/ConvSel.c b/libX11/src/ConvSel.c index fb6e8e338..2dece58b5 100644 --- a/libX11/src/ConvSel.c +++ b/libX11/src/ConvSel.c @@ -49,5 +49,5 @@ XConvertSelection(      req->time = time;      UnlockDisplay(dpy);      SyncHandle(); -    return 1; +    return Success;  } diff --git a/libX11/src/CrGlCur.c b/libX11/src/CrGlCur.c index 460660f81..4f332836b 100644 --- a/libX11/src/CrGlCur.c +++ b/libX11/src/CrGlCur.c @@ -1,260 +1,270 @@ -/* - -Copyright 1986, 1998  The Open Group - -Permission to use, copy, modify, distribute, and sell this software and its -documentation for any purpose is hereby granted without fee, provided that -the above copyright notice appear in all copies and that both that -copyright notice and this permission notice appear in supporting -documentation. - -The above copyright notice and this permission notice shall be included in -all copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, -FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE -OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN -AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. - -Except as contained in this notice, the name of The Open Group shall not be -used in advertising or otherwise to promote the sale, use or other dealings -in this Software without prior written authorization from The Open Group. - -*/ - -#ifdef HAVE_CONFIG_H -#include <config.h> -#endif -#include "Xlibint.h" - -#ifdef USE_DYNAMIC_XCURSOR - -#ifdef __UNIXOS2__ -#define RTLD_LAZY 1 -#define LIBXCURSOR "Xcursor.dll" -#endif -#include <stdio.h> -#include <string.h> -#if defined(hpux) -#include <dl.h> -#else -#include <dlfcn.h> -#endif -#include "Cr.h" - -#ifdef __CYGWIN__ -#define LIBXCURSOR "cygXcursor-1.dll" -#endif - -#if defined(hpux) -typedef shl_t	XModuleType; -#else -typedef void *XModuleType; -#endif - -#ifndef LIBXCURSOR -#define LIBXCURSOR "libXcursor.so.1" -#endif - -static char libraryName[] = LIBXCURSOR; - -static XModuleType -open_library (void) -{ -    char	*library = libraryName; -    char	*dot; -    XModuleType	module; -    for (;;) -    { -#if defined(hpux) -	module = shl_load(library, BIND_DEFERRED, 0L); -#else -	module =  dlopen(library, RTLD_LAZY); -#endif -	if (module) -	    return module; -	dot = strrchr (library, '.'); -	if (!dot) -	    break; -	*dot = '\0'; -    } -    return NULL; -} - -static void * -fetch_symbol (XModuleType module, const char *under_symbol) -{ -    void *result = NULL; -    const char *symbol = under_symbol + 1; -#if defined(hpux) -    int getsyms_cnt, i; -    struct shl_symbol *symbols; - -    getsyms_cnt = shl_getsymbols(module, TYPE_PROCEDURE, -				 EXPORT_SYMBOLS, malloc, &symbols); - -    for(i=0; i<getsyms_cnt; i++) { -        if(!strcmp(symbols[i].name, symbol)) { -	    result = symbols[i].value; -	    break; -         } -    } - -    if(getsyms_cnt > 0) { -        free(symbols); -    } -#else -    result = dlsym (module, symbol); -    if (!result) -	result = dlsym (module, under_symbol); -#endif -    return result; -} - -typedef void	(*NoticeCreateBitmapFunc) (Display	    *dpy, -					   Pixmap	    pid, -					   unsigned int width, -					   unsigned int height); - -typedef void	(*NoticePutBitmapFunc) (Display	    *dpy, -					Drawable    draw, -					XImage	    *image); - -typedef Cursor	(*TryShapeBitmapCursorFunc) (Display	    *dpy, -					     Pixmap	    source, -					     Pixmap	    mask, -					     XColor	    *foreground, -					     XColor	    *background, -					     unsigned int   x, -					     unsigned int   y); - -typedef Cursor	(*TryShapeCursorFunc) (Display	    *dpy, -				       Font	    source_font, -				       Font	    mask_font, -				       unsigned int source_char, -				       unsigned int mask_char, -				       XColor _Xconst *foreground, -				       XColor _Xconst *background); - -static XModuleType  _XcursorModule; -static Bool	    _XcursorModuleTried; - -#define GetFunc(type,name,ret) {\ -    static Bool	    been_here; \ -    static type	    staticFunc; \ -     \ -    _XLockMutex (_Xglobal_lock); \ -    if (!been_here) \ -    { \ -	been_here = True; \ -	if (!_XcursorModuleTried) \ -	{ \ -	    _XcursorModuleTried = True; \ -	    _XcursorModule = open_library (); \ -	} \ -	if (_XcursorModule) \ -	    staticFunc = (type) fetch_symbol (_XcursorModule, "_" name); \ -    } \ -    ret = staticFunc; \ -    _XUnlockMutex (_Xglobal_lock); \ -} - -static Cursor -_XTryShapeCursor (Display	    *dpy, -		  Font		    source_font, -		  Font		    mask_font, -		  unsigned int	    source_char, -		  unsigned int	    mask_char, -		  XColor _Xconst    *foreground, -		  XColor _Xconst    *background) -{ -    TryShapeCursorFunc		func; - -    GetFunc (TryShapeCursorFunc, "XcursorTryShapeCursor", func); -    if (func) -	return (*func) (dpy, source_font, mask_font, source_char, mask_char, -			foreground, background); -    return None; -} - -void -_XNoticeCreateBitmap (Display	    *dpy, -		      Pixmap	    pid, -		      unsigned int  width, -		      unsigned int  height) -{ -    NoticeCreateBitmapFunc  func; - -    GetFunc (NoticeCreateBitmapFunc, "XcursorNoticeCreateBitmap", func); -    if (func) -	(*func) (dpy, pid, width, height); -} - -void -_XNoticePutBitmap (Display	*dpy, -		   Drawable	draw, -		   XImage	*image) -{ -    NoticePutBitmapFunc	func; - -    GetFunc (NoticePutBitmapFunc, "XcursorNoticePutBitmap", func); -    if (func) -	(*func) (dpy, draw, image); -} - -Cursor -_XTryShapeBitmapCursor (Display		*dpy, -			Pixmap		source, -			Pixmap		mask, -			XColor		*foreground, -			XColor		*background, -			unsigned int	x, -			unsigned int	y) -{ -    TryShapeBitmapCursorFunc	func; - -    GetFunc (TryShapeBitmapCursorFunc, "XcursorTryShapeBitmapCursor", func); -    if (func) -	return (*func) (dpy, source, mask, foreground, background, x, y); -    return None; -} -#endif - -Cursor XCreateGlyphCursor( -     register Display *dpy, -     Font source_font, -     Font mask_font, -     unsigned int source_char, -     unsigned int mask_char, -     XColor _Xconst *foreground, -     XColor _Xconst *background) -{ -    Cursor cid; -    register xCreateGlyphCursorReq *req; - -#ifdef USE_DYNAMIC_XCURSOR -    cid = _XTryShapeCursor (dpy, source_font, mask_font, -			    source_char, mask_char, foreground, background); -    if (cid) -	return cid; -#endif -    LockDisplay(dpy); -    GetReq(CreateGlyphCursor, req); -    cid = req->cid = XAllocID(dpy); -    req->source = source_font; -    req->mask = mask_font; -    req->sourceChar = source_char; -    req->maskChar = mask_char; -    req->foreRed = foreground->red; -    req->foreGreen = foreground->green; -    req->foreBlue = foreground->blue; -    req->backRed = background->red; -    req->backGreen = background->green; -    req->backBlue = background->blue; -    UnlockDisplay(dpy); -    SyncHandle(); -    return (cid); -} - +/*
 +
 +Copyright 1986, 1998  The Open Group
 +
 +Permission to use, copy, modify, distribute, and sell this software and its
 +documentation for any purpose is hereby granted without fee, provided that
 +the above copyright notice appear in all copies and that both that
 +copyright notice and this permission notice appear in supporting
 +documentation.
 +
 +The above copyright notice and this permission notice shall be included in
 +all copies or substantial portions of the Software.
 +
 +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
 +OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
 +AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
 +CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 +
 +Except as contained in this notice, the name of The Open Group shall not be
 +used in advertising or otherwise to promote the sale, use or other dealings
 +in this Software without prior written authorization from The Open Group.
 +
 +*/
 +
 +#ifdef HAVE_CONFIG_H
 +#include <config.h>
 +#endif
 +#include "Xlibint.h"
 +
 +#ifdef USE_DYNAMIC_XCURSOR
 +
 +#ifdef __UNIXOS2__
 +#define RTLD_LAZY 1
 +#define LIBXCURSOR "Xcursor.dll"
 +#endif
 +#include <stdio.h>
 +#include <string.h>
 +#if defined(hpux)
 +#include <dl.h>
 +#else
 +#include <dlfcn.h>
 +#endif
 +#include "Cr.h"
 +
 +#ifdef __CYGWIN__
 +#define LIBXCURSOR "cygXcursor-1.dll"
 +#endif
 +
 +#if defined(hpux)
 +typedef shl_t	XModuleType;
 +#else
 +#ifdef _MSC_VER
 +#include <X11/XWindows.h>
 +typedef HANDLE XModuleType;
 +#define dlsym GetProcAddress
 +#else
 +typedef void *XModuleType;
 +#endif
 +#endif
 +
 +#ifndef LIBXCURSOR
 +#define LIBXCURSOR "libXcursor.so.1"
 +#endif
 +
 +static char libraryName[] = LIBXCURSOR;
 +
 +static XModuleType
 +open_library (void)
 +{
 +    char	*library = libraryName;
 +    char	*dot;
 +    XModuleType	module;
 +    for (;;)
 +    {
 +#if defined(hpux)
 +	module = shl_load(library, BIND_DEFERRED, 0L);
 +#else
 +#ifdef _MSC_VER
 +	module =  LoadLibrary(library);
 +#else
 +	module =  dlopen(library, RTLD_LAZY);
 +#endif
 +#endif
 +	if (module)
 +	    return module;
 +	dot = strrchr (library, '.');
 +	if (!dot)
 +	    break;
 +	*dot = '\0';
 +    }
 +    return NULL;
 +}
 +
 +static void *
 +fetch_symbol (XModuleType module, const char *under_symbol)
 +{
 +    void *result = NULL;
 +    const char *symbol = under_symbol + 1;
 +#if defined(hpux)
 +    int getsyms_cnt, i;
 +    struct shl_symbol *symbols;
 +
 +    getsyms_cnt = shl_getsymbols(module, TYPE_PROCEDURE,
 +				 EXPORT_SYMBOLS, malloc, &symbols);
 +
 +    for(i=0; i<getsyms_cnt; i++) {
 +        if(!strcmp(symbols[i].name, symbol)) {
 +	    result = symbols[i].value;
 +	    break;
 +         }
 +    }
 +
 +    if(getsyms_cnt > 0) {
 +        free(symbols);
 +    }
 +#else
 +    result = dlsym (module, symbol);
 +    if (!result)
 +	result = dlsym (module, under_symbol);
 +#endif
 +    return result;
 +}
 +
 +typedef void	(*NoticeCreateBitmapFunc) (Display	    *dpy,
 +					   Pixmap	    pid,
 +					   unsigned int width,
 +					   unsigned int height);
 +
 +typedef void	(*NoticePutBitmapFunc) (Display	    *dpy,
 +					Drawable    draw,
 +					XImage	    *image);
 +
 +typedef Cursor	(*TryShapeBitmapCursorFunc) (Display	    *dpy,
 +					     Pixmap	    source,
 +					     Pixmap	    mask,
 +					     XColor	    *foreground,
 +					     XColor	    *background,
 +					     unsigned int   x,
 +					     unsigned int   y);
 +
 +typedef Cursor	(*TryShapeCursorFunc) (Display	    *dpy,
 +				       Font	    source_font,
 +				       Font	    mask_font,
 +				       unsigned int source_char,
 +				       unsigned int mask_char,
 +				       XColor _Xconst *foreground,
 +				       XColor _Xconst *background);
 +
 +static XModuleType  _XcursorModule;
 +static Bool	    _XcursorModuleTried;
 +
 +#define GetFunc(type,name,ret) {\
 +    static Bool	    been_here; \
 +    static type	    staticFunc; \
 +     \
 +    _XLockMutex (_Xglobal_lock); \
 +    if (!been_here) \
 +    { \
 +	been_here = True; \
 +	if (!_XcursorModuleTried) \
 +	{ \
 +	    _XcursorModuleTried = True; \
 +	    _XcursorModule = open_library (); \
 +	} \
 +	if (_XcursorModule) \
 +	    staticFunc = (type) fetch_symbol (_XcursorModule, "_" name); \
 +    } \
 +    ret = staticFunc; \
 +    _XUnlockMutex (_Xglobal_lock); \
 +}
 +
 +static Cursor
 +_XTryShapeCursor (Display	    *dpy,
 +		  Font		    source_font,
 +		  Font		    mask_font,
 +		  unsigned int	    source_char,
 +		  unsigned int	    mask_char,
 +		  XColor _Xconst    *foreground,
 +		  XColor _Xconst    *background)
 +{
 +    TryShapeCursorFunc		func;
 +
 +    GetFunc (TryShapeCursorFunc, "XcursorTryShapeCursor", func);
 +    if (func)
 +	return (*func) (dpy, source_font, mask_font, source_char, mask_char,
 +			foreground, background);
 +    return None;
 +}
 +
 +void
 +_XNoticeCreateBitmap (Display	    *dpy,
 +		      Pixmap	    pid,
 +		      unsigned int  width,
 +		      unsigned int  height)
 +{
 +    NoticeCreateBitmapFunc  func;
 +
 +    GetFunc (NoticeCreateBitmapFunc, "XcursorNoticeCreateBitmap", func);
 +    if (func)
 +	(*func) (dpy, pid, width, height);
 +}
 +
 +void
 +_XNoticePutBitmap (Display	*dpy,
 +		   Drawable	draw,
 +		   XImage	*image)
 +{
 +    NoticePutBitmapFunc	func;
 +
 +    GetFunc (NoticePutBitmapFunc, "XcursorNoticePutBitmap", func);
 +    if (func)
 +	(*func) (dpy, draw, image);
 +}
 +
 +Cursor
 +_XTryShapeBitmapCursor (Display		*dpy,
 +			Pixmap		source,
 +			Pixmap		mask,
 +			XColor		*foreground,
 +			XColor		*background,
 +			unsigned int	x,
 +			unsigned int	y)
 +{
 +    TryShapeBitmapCursorFunc	func;
 +
 +    GetFunc (TryShapeBitmapCursorFunc, "XcursorTryShapeBitmapCursor", func);
 +    if (func)
 +	return (*func) (dpy, source, mask, foreground, background, x, y);
 +    return None;
 +}
 +#endif
 +
 +Cursor XCreateGlyphCursor(
 +     register Display *dpy,
 +     Font source_font,
 +     Font mask_font,
 +     unsigned int source_char,
 +     unsigned int mask_char,
 +     XColor _Xconst *foreground,
 +     XColor _Xconst *background)
 +{
 +    Cursor cid;
 +    register xCreateGlyphCursorReq *req;
 +
 +#ifdef USE_DYNAMIC_XCURSOR
 +    cid = _XTryShapeCursor (dpy, source_font, mask_font,
 +			    source_char, mask_char, foreground, background);
 +    if (cid)
 +	return cid;
 +#endif
 +    LockDisplay(dpy);
 +    GetReq(CreateGlyphCursor, req);
 +    cid = req->cid = XAllocID(dpy);
 +    req->source = source_font;
 +    req->mask = mask_font;
 +    req->sourceChar = source_char;
 +    req->maskChar = mask_char;
 +    req->foreRed = foreground->red;
 +    req->foreGreen = foreground->green;
 +    req->foreBlue = foreground->blue;
 +    req->backRed = background->red;
 +    req->backGreen = background->green;
 +    req->backBlue = background->blue;
 +    UnlockDisplay(dpy);
 +    SyncHandle();
 +    return (cid);
 +}
 +
 diff --git a/libX11/src/OpenDis.c b/libX11/src/OpenDis.c index 0b779b0ad..e5336a847 100644 --- a/libX11/src/OpenDis.c +++ b/libX11/src/OpenDis.c @@ -32,6 +32,7 @@ in this Software without prior written authorization from The Open Group.  #include <X11/Xatom.h>
  #include <X11/Xresource.h>
  #include <stdio.h>
 +#include <unistd.h>
  #include "Xintconn.h"
  #ifdef XKB
 diff --git a/libX11/src/RdBitF.c b/libX11/src/RdBitF.c index 07967aebe..07b47494b 100644 --- a/libX11/src/RdBitF.c +++ b/libX11/src/RdBitF.c @@ -54,6 +54,7 @@ from The Open Group.  #define MAX_SIZE 255  /* shared data for the image read/parse logic */ +/*  static const short hexTable[256] = {      ['0'] = 0,  ['1'] = 1,      ['2'] = 2,  ['3'] = 3, @@ -71,6 +72,23 @@ static const short hexTable[256] = {      ['}'] = -1, ['\n'] = -1,      ['\t'] = -1  }; +*/ +short hexTable(unsigned char Char) +{ +  if (Char<'0') +    return -1; +  if (Char<='9') +    return Char-'0'; + if (Char<'A') +    return -1; +  if (Char<='F') +    return Char-'A'+10; + if (Char<'a') +    return -1; +  if (Char<='f') +    return Char-'a'+10; +  return -1; +}  /*   *	read next hex value in the input stream, return -1 if EOF @@ -96,9 +114,9 @@ NextInt (  	    /* trim high bits, check type and accumulate */  	    ch &= 0xff;  	    if (isascii(ch) && isxdigit(ch)) { -		value = (value << 4) + hexTable[ch]; +		value = (value << 4) + hexTable(ch);  		gotone++; -	    } else if ((hexTable[ch]) < 0 && gotone) +	    } else if ((hexTable(ch)) < 0 && gotone)  	      done++;  	}      } diff --git a/libX11/src/StrKeysym.c b/libX11/src/StrKeysym.c index 6e9c427f8..907db507b 100644 --- a/libX11/src/StrKeysym.c +++ b/libX11/src/StrKeysym.c @@ -39,12 +39,14 @@ in this Software without prior written authorization from The Open Group.  #ifndef KEYSYMDB
  #ifndef XKEYSYMDB
 -#define KEYSYMDB "/usr/lib/X11/XKeysymDB"
 +#define KEYSYMDB "XKeysymDB"
  #else
  #define KEYSYMDB XKEYSYMDB
  #endif
  #endif
 +#include <unistd.h>
 +
  static Bool initialized;
  static XrmDatabase keysymdb;
  static XrmQuark Qkeysym[2];
 diff --git a/libX11/src/XlibInt.c b/libX11/src/XlibInt.c index a4adaa130..17a0bd0a4 100644 --- a/libX11/src/XlibInt.c +++ b/libX11/src/XlibInt.c @@ -33,6 +33,7 @@ from The Open Group.  #ifdef WIN32
  #define _XLIBINT_
 +#include <X11\Xw32defs.h>
  #endif
  #ifdef HAVE_CONFIG_H
  #include <config.h>
 @@ -198,6 +199,11 @@ void _XPollfdCacheDel(  #endif
  }
 +#ifdef _MSC_VER
 +#undef min
 +#define min __min
 +#endif
 +
  static int sync_hazard(Display *dpy)
  {
      unsigned long span = dpy->request - dpy->last_request_read;
 @@ -239,7 +245,7 @@ void _XSeqSyncFunction(  static int
  _XPrivSyncFunction (Display *dpy)
  {
 -#if XTHREADS
 +#ifdef XTHREADS
      assert(!dpy->lock_fns);
  #endif
      assert(dpy->synchandler == _XPrivSyncFunction);
 diff --git a/libX11/src/config.h b/libX11/src/config.h new file mode 100644 index 000000000..abbac6e3b --- /dev/null +++ b/libX11/src/config.h @@ -0,0 +1,243 @@ +/* src/config.h.in.  Generated from configure.ac by autoheader.  */ + +/* Define to 1 if `struct sockaddr_in' has a `sin_len' member */ +/* #undef BSD44SOCKETS */ + +/* Include compose table cache support */ +#define COMPOSECACHE 1 + +/* Has getresuid() & getresgid() functions */ +/* #undef HASGETRESUID */ + +/* Has issetugid() function */ +/* #undef HASSETUGID */ + +/* Has shm*() functions */ +//MH#define HAS_SHM 1 + +/* Define to 1 if you have the `authdes_create' function. */ +/* #undef HAVE_AUTHDES_CREATE */ + +/* Define to 1 if you have the `authdes_seccreate' function. */ +/* #undef HAVE_AUTHDES_SECCREATE */ + +/* Define to 1 if you have the <dlfcn.h> header file. */ +#define HAVE_DLFCN_H 1 + +/* Define to 1 if you have the <endian.h> header file. */ +#define HAVE_ENDIAN_H 1 + +/* Use dlopen to load shared libraries */ +#define HAVE_DLOPEN 1 + +/* Define to 1 if you have the <dl.h> header file. */ +/* #undef HAVE_DL_H */ + +/* Define to 1 if you have the `getpagesize' function. */ +#define HAVE_GETPAGESIZE 1 + +/* Define to 1 if you have the <inttypes.h> header file. */ +#define HAVE_INTTYPES_H 1 + +/* launchd support available */ +/* #undef HAVE_LAUNCHD */ + +/* Define to 1 if you have the <memory.h> header file. */ +#define HAVE_MEMORY_H 1 + +/* Define to 1 if you have the `poll' function. */ +#define HAVE_POLL 1 + +/* Define to 1 if you have a working `mmap' system call. */ +#define HAVE_MMAP 1 + +/* Use shl_load to load shared libraries */ +/* #undef HAVE_SHL_LOAD */ + +/* Define to 1 if the system has the type `socklen_t'. */ +#define HAVE_SOCKLEN_T 0 + +/* Define to 1 if you have the <stdint.h> header file. */ +#define HAVE_STDINT_H 1 + +/* Define to 1 if you have the <stdlib.h> header file. */ +#define HAVE_STDLIB_H 1 + +/* Define to 1 if you have the <strings.h> header file. */ +#define HAVE_STRINGS_H 1 + +/* Define to 1 if you have the <string.h> header file. */ +#define HAVE_STRING_H 1 + +/* Define to 1 if you have the <sys/poll.h> header file. */ +#define HAVE_SYS_POLL_H 1 + +/* Define to 1 if you have the `strtol' function. */ +#define HAVE_STRTOL 1 + +/* Define to 1 if you have the <sys/stat.h> header file. */ +#define HAVE_SYS_STAT_H 1 + +/* Define to 1 if you have the <sys/types.h> header file. */ +#define HAVE_SYS_TYPES_H 1 + +/* Define to 1 if you have the <unistd.h> header file. */ +#define HAVE_UNISTD_H 1 + +/* Support IPv6 for TCP connections */ +/* #undef IPv6 */ + +/* Support dynamically loaded font modules */ +#define LOADABLEFONTS 1 + +/* Support os-specific local connections */ +/* #undef LOCALCONN */ + +/* Define to the sub-directory in which libtool stores uninstalled libraries. +   */ +#define LT_OBJDIR ".libs/" + +/* Disable XLOCALEDIR environment variable */ +#define NO_XLOCALEDIR 1 + +/* Name of package */ +#define PACKAGE "libX11" + +/* Define to the address where bug reports for this package should be sent. */ +#define PACKAGE_BUGREPORT "https://bugs.freedesktop.org/enter_bug.cgi?product=xorg" + +/* Define to the full name of this package. */ +#define PACKAGE_NAME "libX11" + +/* Define to the full name and version of this package. */ +#define PACKAGE_STRING "libX11 1.1.5" + +/* Define to the one symbol short name of this package. */ +#define PACKAGE_TARNAME "libX11" + +/* Define to the version of this package. */ +#define PACKAGE_VERSION "1.1.5" + +/* Major version of this package */ +#define PACKAGE_VERSION_MAJOR 1 + +/* Minor version of this package */ +#define PACKAGE_VERSION_MINOR 1 + +/* Patch version of this package */ +#define PACKAGE_VERSION_PATCHLEVEL 5 + +/* Define as the return type of signal handlers (`int' or `void'). */ +/* #undef RETSIGTYPE */ + +/* Support Secure RPC ("SUN-DES-1") authentication for X11 clients */ +/* #undef SECURE_RPC */ + +/* Define to 1 if you have the ANSI C header files. */ +#define STDC_HEADERS 1 + +/* Support TCP socket connections */ +#define TCPCONN 1 + +/* launchd support available */ +/* #undef TRANS_REOPEN */ + +/* Support UNIX socket connections */ +#define UNIXCONN 1 + +/* Split some i18n functions into loadable modules */ +/* #undef USE_DYNAMIC_LC */ + +/* Use the X cursor library to load cursors */ +#define USE_DYNAMIC_XCURSOR 1 + +/* poll() function is available */ +#define USE_POLL 1 + +/* Use XCB for low-level protocol implementation */ +#define USE_XCB 1 + +/* Version number of package */ +#define VERSION "1.1.5" + +/* Support bdf format bitmap font files */ +#define XFONT_BDFFORMAT 1 + +/* Location of libX11 data */ +#define X11_DATADIR "/usr/share/X11" + +/* Location of libX11 library data */ +#define X11_LIBDIR "/usr/lib/X11" + +/* Include support for XCMS */ +#define XCMS 1 + +/* Location of error message database */ +#define XERRORDB "XErrorDB" + +/* Enable XF86BIGFONT extension */ +/* #undef XF86BIGFONT */ + +/* Use XKB */ +#define XKB 1 + +/* Location of keysym database */ +#define XKEYSYMDB "XKeysymDB" + +/* support for X Locales */ +#define XLOCALE 1 + +/* Location of libX11 locale data */ +#define XLOCALEDATADIR "locale" + +/* Location of libX11 locale data */ +#define XLOCALEDIR "locale" + +/* Location of libX11 locale libraries */ +#define XLOCALELIBDIR "locale" + +/* Whether libX11 is compiled with thread support */ +#define XTHREADS /**/ + +/* Whether libX11 needs to use MT safe API's */ +#define XUSE_MTSAFE_API /**/ + +/* Enable GNU and other extensions to the C environment for glibc */ +/* #undef _GNU_SOURCE */ + +/* Support bitmap font files */ +#define XFONT_BITMAP 1 + +/* Support built-in fonts */ +#define XFONT_BUILTINS 1 + +/* Support the X Font Services Protocol */ +#define XFONT_FC 1 + +/* Support fonts in files */ +#define XFONT_FONTFILE 1 + +/* Support FreeType rasterizer for nearly all font file formats */ +#define XFONT_FREETYPE 1 + +/* Support pcf format bitmap font files */ +#define XFONT_PCFFORMAT 1 + +/* Support snf format bitmap font files */ +#define XFONT_SNFFORMAT 1 + +/* Support Speedo font files */ +#define XFONT_SPEEDO 1 + +/* Support IBM Type 1 rasterizer for Type1 font files */ +#define XFONT_TYPE1 1 + +/* Support bzip2 for bitmap fonts */ +/* #undef X_BZIP2_FONT_COMPRESSION */ + +/* Support gzip for bitmap fonts */ +#define X_GZIP_FONT_COMPRESSION 1 + +#define INCL_WINSOCK_API_TYPEDEFS 1 +#include <X11/Xwinsock.h> +#include <X11/Xwindows.h> diff --git a/libX11/src/makefile b/libX11/src/makefile new file mode 100644 index 000000000..e89f573c7 --- /dev/null +++ b/libX11/src/makefile @@ -0,0 +1,278 @@ +LIBRARY=libx11 + +DEFINES += X11_t TRANS_CLIENT + +CSRCS = \ +                  AllCells.c \ +                  AllowEv.c \ +                  AllPlanes.c \ +                  AutoRep.c \ +                  Backgnd.c \ +                  BdrWidth.c \ +                  Bell.c \ +                  Border.c \ +                  ChAccCon.c \ +                  ChActPGb.c \ +                  ChClMode.c \ +                  ChCmap.c \ +                  ChGC.c \ +                  ChKeyCon.c \ +                  ChkIfEv.c \ +                  ChkMaskEv.c \ +                  ChkTypEv.c \ +                  ChkTypWEv.c \ +                  ChkWinEv.c \ +                  ChPntCon.c \ +                  ChProp.c \ +                  ChSaveSet.c \ +                  ChWAttrs.c \ +                  ChWindow.c \ +                  CirWin.c \ +                  CirWinDn.c \ +                  CirWinUp.c \ +                  ClDisplay.c \ +                  ClearArea.c \ +                  Clear.c \ +                  ConfWind.c \ +                  Context.c \ +                  ConvSel.c \ +                  CopyArea.c \ +                  CopyCmap.c \ +                  CopyGC.c \ +                  CopyPlane.c \ +                  CrBFData.c \ +                  CrCmap.c \ +                  CrCursor.c \ +                  CrGC.c \ +                  CrGlCur.c \ +                  CrPFBData.c \ +                  CrPixmap.c \ +                  CrWindow.c \ +                  Cursor.c \ +                  DefCursor.c \ +                  DelProp.c \ +                  Depths.c \ +                  DestSubs.c \ +                  DestWind.c \ +                  DisName.c \ +                  DrArc.c \ +                  DrArcs.c \ +                  DrLine.c \ +                  DrLines.c \ +                  DrPoint.c \ +                  DrPoints.c \ +                  DrRect.c \ +                  DrRects.c \ +                  DrSegs.c \ +                  ErrDes.c \ +                  ErrHndlr.c \ +                  evtomask.c \ +                  EvToWire.c \ +                  FetchName.c \ +                  FillArc.c \ +                  FillArcs.c \ +                  FillPoly.c \ +                  FillRct.c \ +                  FillRcts.c \ +                  FilterEv.c \ +                  Flush.c \ +                  Font.c \ +                  FontInfo.c \ +                  FontNames.c \ +                  FreeCmap.c \ +                  FreeCols.c \ +                  FreeCurs.c \ +                  FreeEData.c \ +                  FreeEventData.c \ +                  FreeGC.c \ +                  FreePix.c \ +                  FSSaver.c \ +                  FSWrap.c \ +                  GCMisc.c \ +                  Geom.c \ +                  GetAtomNm.c \ +                  GetColor.c \ +                  GetDflt.c \ +                  GetEventData.c \ +                  GetFPath.c \ +                  GetFProp.c \ +                  GetGCVals.c \ +                  GetGeom.c \ +                  GetHColor.c \ +                  GetHints.c \ +                  GetIFocus.c \ +                  GetImage.c \ +                  GetKCnt.c \ +                  GetMoEv.c \ +                  GetNrmHint.c \ +                  GetPCnt.c \ +                  GetPntMap.c \ +                  GetProp.c \ +                  GetRGBCMap.c \ +                  GetSOwner.c \ +                  GetSSaver.c \ +                  GetStCmap.c \ +                  GetTxtProp.c \ +                  GetWAttrs.c \ +                  GetWMCMapW.c \ +                  GetWMProto.c \ +                  globals.c \ +                  GrButton.c \ +                  GrKeybd.c \ +                  GrKey.c \ +                  GrPointer.c \ +                  GrServer.c \ +                  Host.c \ +                  Iconify.c \ +                  IfEvent.c \ +                  imConv.c \ +                  ImText16.c \ +                  ImText.c \ +                  ImUtil.c \ +                  InitExt.c \ +                  InsCmap.c \ +                  IntAtom.c \ +                  KeyBind.c \ +                  KeysymStr.c \ +                  KillCl.c \ +                  LiHosts.c \ +                  LiICmaps.c \ +                  LiProps.c \ +                  ListExt.c \ +                  LoadFont.c \ +                  LockDis.c \ +                  locking.c \ +                  LookupCol.c \ +                  LowerWin.c \ +                  Macros.c \ +                  MapRaised.c \ +                  MapSubs.c \ +                  MapWindow.c \ +                  MaskEvent.c \ +                  Misc.c \ +                  ModMap.c \ +                  MoveWin.c \ +                  NextEvent.c \ +                  OCWrap.c \ +                  OMWrap.c \ +                  OpenDis.c \ +                  ParseCmd.c \ +                  ParseCol.c \ +                  ParseGeom.c \ +                  PeekEvent.c \ +                  PeekIfEv.c \ +                  Pending.c \ +                  PixFormats.c \ +                  PmapBgnd.c \ +                  PmapBord.c \ +                  PolyReg.c \ +                  PolyTxt16.c \ +                  PolyTxt.c \ +                  PropAlloc.c \ +                  PutBEvent.c \ +                  PutImage.c \ +                  Quarks.c \ +                  QuBest.c \ +                  QuColor.c \ +                  QuColors.c \ +                  QuCurShp.c \ +                  QuExt.c \ +                  QuKeybd.c \ +                  QuPntr.c \ +                  QuStipShp.c \ +                  QuTextE16.c \ +                  QuTextExt.c \ +                  QuTileShp.c \ +                  QuTree.c \ +                  RaiseWin.c \ +                  RdBitF.c \ +                  RecolorC.c \ +                  ReconfWin.c \ +                  ReconfWM.c \ +                  Region.c \ +                  RegstFlt.c \ +                  RepWindow.c \ +                  RestackWs.c \ +                  RotProp.c \ +                  ScrResStr.c \ +                  SelInput.c \ +                  SendEvent.c \ +                  SetBack.c \ +                  SetClMask.c \ +                  SetClOrig.c \ +                  SetCRects.c \ +                  SetDashes.c \ +                  SetFont.c \ +                  SetFore.c \ +                  SetFPath.c \ +                  SetFunc.c \ +                  SetHints.c \ +                  SetIFocus.c \ +                  SetLocale.c \ +                  SetLStyle.c \ +                  SetNrmHint.c \ +                  SetPMask.c \ +                  SetPntMap.c \ +                  SetRGBCMap.c \ +                  SetSOwner.c \ +                  SetSSaver.c \ +                  SetState.c \ +                  SetStCmap.c \ +                  SetStip.c \ +                  SetTile.c \ +                  SetTSOrig.c \ +                  SetTxtProp.c \ +                  SetWMCMapW.c \ +                  SetWMProto.c \ +                  StBytes.c \ +                  StColor.c \ +                  StColors.c \ +                  StName.c \ +                  StNColor.c \ +                  StrKeysym.c \ +                  StrToText.c \ +                  Sync.c \ +                  Synchro.c \ +                  Text16.c \ +                  Text.c \ +                  TextExt16.c \ +                  TextExt.c \ +                  TextToStr.c \ +                  TrCoords.c \ +                  UndefCurs.c \ +                  UngrabBut.c \ +                  UngrabKbd.c \ +                  UngrabKey.c \ +                  UngrabPtr.c \ +                  UngrabSvr.c \ +                  UninsCmap.c \ +                  UnldFont.c \ +                  UnmapSubs.c \ +                  UnmapWin.c \ +                  VisUtil.c \ +                  WarpPtr.c \ +                  Window.c \ +                  WinEvent.c \ +                  Withdraw.c \ +                  WMGeom.c \ +                  WMProps.c \ +                  WrBitF.c \ +                  xcb_disp.c \ +                  xcb_io.c \ +                  XlibAsync.c \ +                  XlibInt.c \ +                  Xrm.c \ + + +INCLUDES := . xcms xlibi18n xkb $(MHMAKECONF)\X11 $(OBJDIR) $(INCLUDES) + +KEYSYMDEF = $(MHMAKECONF)/X11/keysymdef.h + +$(OBJDIR)\$(LIBRARY).lib: $(OBJDIR)\ks_tables.h + +load_makefile util\makefile MAKESERVER=$(MAKESERVER) DEBUG=$(DEBUG) + +$(OBJDIR)\ks_tables.h: $(KEYSYMDEF) util\$(OBJDIR)\makekeys.exe +	util\$(OBJDIR)\makekeys $(relpath $<) > $(relpath $@) + + diff --git a/libX11/src/util/makefile b/libX11/src/util/makefile new file mode 100644 index 000000000..27da68335 --- /dev/null +++ b/libX11/src/util/makefile @@ -0,0 +1,6 @@ +TTYAPP=makekeys + +DEFINES += X11_t TRANS_CLIENT + +CSRCS = makekeys.c + diff --git a/libX11/src/util/makekeys.c b/libX11/src/util/makekeys.c index 85ce75268..fb758b9cb 100644 --- a/libX11/src/util/makekeys.c +++ b/libX11/src/util/makekeys.c @@ -33,6 +33,7 @@ from The Open Group.  #include <X11/keysymdef.h>
  #include <stdio.h>
  #include <stdlib.h>
 +#include <unistd.h>
  typedef unsigned long Signature;
 @@ -157,7 +158,7 @@ main(int argc, char *argv[])      num_found = 0;
      for (z = ksnum; z < KTNUM; z++) {
  	max_rehash = 0;
 -	for (name = tab, i = z; --i >= 0;)
 +	for (name = &tab[0], i = z; --i >= 0;)
  		*name++ = 0;
  	for (i = 0; i < ksnum; i++) {
  	    name = info[i].name;
 diff --git a/libX11/src/xcb_io.c b/libX11/src/xcb_io.c index 13c709f2f..6a2172bdb 100644 --- a/libX11/src/xcb_io.c +++ b/libX11/src/xcb_io.c @@ -21,6 +21,9 @@  #ifdef HAVE_SYS_SELECT_H
  #include <sys/select.h>
  #endif
 +#include <sys/time.h>
 +
 +#include <X11/Xtrans/Xtrans.h>
  static void return_socket(void *closure)
  {
 diff --git a/libX11/src/xcms/config.h b/libX11/src/xcms/config.h new file mode 100644 index 000000000..a01921855 --- /dev/null +++ b/libX11/src/xcms/config.h @@ -0,0 +1,2 @@ +#include <string.h> +#include <unistd.h> diff --git a/libX11/src/xcms/makefile b/libX11/src/xcms/makefile new file mode 100644 index 000000000..00fab124a --- /dev/null +++ b/libX11/src/xcms/makefile @@ -0,0 +1,71 @@ +LIBRARY = libxcms + +DEFINES += HAVE_CONFIG_H + +CSRCS = \ +		  AddDIC.c \ +                  AddSF.c \ +                  CCC.c \ +                  CvColW.c \ +                  CvCols.c \ +                  HVC.c \ +                  HVCGcC.c \ +                  HVCGcV.c \ +                  HVCGcVC.c \ +                  HVCMnV.c \ +                  HVCMxC.c \ +                  HVCMxV.c \ +                  HVCMxVC.c \ +                  HVCMxVs.c \ +                  HVCWpAj.c \ +                  IdOfPr.c \ +                  LRGB.c \ +                  Lab.c \ +                  LabGcC.c \ +                  LabGcL.c \ +                  LabGcLC.c \ +                  LabMnL.c \ +                  LabMxC.c \ +                  LabMxL.c \ +                  LabMxLC.c \ +                  LabWpAj.c \ +                  Luv.c \ +                  LuvGcC.c \ +                  LuvGcL.c \ +                  LuvGcLC.c \ +                  LuvMnL.c \ +                  LuvMxC.c \ +                  LuvMxL.c \ +                  LuvMxLC.c \ +                  LuvWpAj.c \ +                  OfCCC.c \ +                  PrOfId.c \ +                  QBlack.c \ +                  QBlue.c \ +                  QGreen.c \ +                  QRed.c \ +                  QWhite.c \ +                  QuCol.c \ +                  QuCols.c \ +                  SetCCC.c \ +                  SetGetCols.c \ +                  StCol.c \ +                  StCols.c \ +                  UNDEFINED.c \ +                  XRGB.c \ +                  XYZ.c \ +                  cmsAllCol.c \ +                  cmsAllNCol.c \ +                  cmsCmap.c \ +                  cmsColNm.c \ +                  cmsGlobls.c \ +                  cmsInt.c \ +                  cmsLkCol.c \ +                  cmsMath.c \ +                  cmsProp.c \ +                  cmsTrig.c \ +                  uvY.c \ +                  xyY.c + +INCLUDES += ..\..\include\X11 ..\..\src\xlibi18n ..\..\src + diff --git a/libX11/src/xkb/Makefile b/libX11/src/xkb/Makefile new file mode 100644 index 000000000..0f6b7e859 --- /dev/null +++ b/libX11/src/xkb/Makefile @@ -0,0 +1,27 @@ +LIBRARY = libxkb + +CSRCS = \ +	XKB.c \ +	XKBBind.c \ +	XKBCompat.c \ +	XKBCtrls.c \ +	XKBCvt.c \ +	XKBGetMap.c \ +	XKBGetByName.c \ +	XKBNames.c \ +	XKBRdBuf.c \ +	XKBSetMap.c \ +	XKBUse.c \ +	XKBleds.c \ +	XKBBell.c \ +	XKBGeom.c \ +	XKBSetGeom.c \ +	XKBExtDev.c \ +	XKBList.c \ +	XKBMisc.c \ +	XKBMAlloc.c \ +	XKBGAlloc.c \ +	XKBAlloc.c + +INCLUDES += ..\..\include\X11 ..\..\src\xlibi18n + diff --git a/libX11/src/xkb/XKB.c b/libX11/src/xkb/XKB.c index 43b3ef95a..fea57870b 100644 --- a/libX11/src/xkb/XKB.c +++ b/libX11/src/xkb/XKB.c @@ -28,6 +28,11 @@ THE USE OR PERFORMANCE OF THIS SOFTWARE.  #include <config.h>
  #endif
  #include <stdio.h>
 +
 +#ifdef XKB_IN_SERVER
 +#define XkbVirtualModsToReal    SrvXkbVirtualModsToReal
 +#endif
 +
  #include "Xlibint.h"
  #include <X11/extensions/XKBproto.h>
  #include "XKBlibint.h"
 diff --git a/libX11/src/xkb/XKBBind.c b/libX11/src/xkb/XKBBind.c index 2e4b1fe68..4904b461f 100644 --- a/libX11/src/xkb/XKBBind.c +++ b/libX11/src/xkb/XKBBind.c @@ -31,6 +31,34 @@ from The Open Group.  #ifdef HAVE_CONFIG_H
  #include <config.h>
  #endif
 +
 +#ifdef XKB_IN_SERVER
 +#define XkbAllocClientMap   SrvXkbAllocClientMap
 +#define XkbAllocServerMap   SrvXkbAllocServerMap
 +#define XkbChangeTypesOfKey   SrvXkbChangeTypesOfKey
 +#define XkbCopyKeyTypes     SrvXkbCopyKeyTypes
 +#define XkbFreeClientMap    SrvXkbFreeClientMap
 +#define XkbFreeServerMap    SrvXkbFreeServerMap
 +#define XkbKeyTypesForCoreSymbols SrvXkbKeyTypesForCoreSymbols
 +#define XkbApplyCompatMapToKey    SrvXkbApplyCompatMapToKey
 +#define XkbResizeKeyActions   SrvXkbResizeKeyActions
 +#define XkbResizeKeySyms    SrvXkbResizeKeySyms
 +#define XkbResizeKeyType    SrvXkbResizeKeyType
 +#define XkbAllocCompatMap   SrvXkbAllocCompatMap
 +#define XkbAllocControls    SrvXkbAllocControls
 +#define XkbAllocIndicatorMaps   SrvXkbAllocIndicatorMaps
 +#define XkbAllocKeyboard    SrvXkbAllocKeyboard
 +#define XkbAllocNames     SrvXkbAllocNames
 +#define XkbFreeCompatMap    SrvXkbFreeCompatMap
 +#define XkbFreeKeyboard     SrvXkbFreeKeyboard
 +#define XkbFreeNames      SrvXkbFreeNames
 +#define XkbLatchModifiers   SrvXkbLatchModifiers
 +#define XkbLatchGroup     SrvXkbLatchGroup
 +#define XkbVirtualModsToReal    SrvXkbVirtualModsToReal
 +#define XkbChangeKeycodeRange   SrvXkbChangeKeycodeRange
 +#define XkbApplyVirtualModChanges SrvXkbApplyVirtualModChanges
 +#endif
 +
  #include "XKBlib.h"
  #include <X11/Xlibint.h>
  #include <X11/Xutil.h>
 diff --git a/libX11/src/xkb/XKBGeom.c b/libX11/src/xkb/XKBGeom.c index 2572b9964..065285fcb 100644 --- a/libX11/src/xkb/XKBGeom.c +++ b/libX11/src/xkb/XKBGeom.c @@ -37,12 +37,8 @@ THE USE OR PERFORMANCE OF THIS SOFTWARE.  #include <X11/extensions/XKBproto.h>
  #include "XKBlibint.h"
 -#ifndef MINSHORT
  #define	MINSHORT	-32768
 -#endif
 -#ifndef MAXSHORT
  #define	MAXSHORT	32767
 -#endif
  /***====================================================================***/
 diff --git a/libX11/src/xkb/XKBGetMap.c b/libX11/src/xkb/XKBGetMap.c index eff088341..96370c6d3 100644 --- a/libX11/src/xkb/XKBGetMap.c +++ b/libX11/src/xkb/XKBGetMap.c @@ -28,6 +28,34 @@ THE USE OR PERFORMANCE OF THIS SOFTWARE.  #ifdef HAVE_CONFIG_H
  #include <config.h>
  #endif
 +
 +#ifdef XKB_IN_SERVER
 +#define XkbAllocClientMap   SrvXkbAllocClientMap
 +#define XkbAllocServerMap   SrvXkbAllocServerMap
 +#define XkbChangeTypesOfKey   SrvXkbChangeTypesOfKey
 +#define XkbCopyKeyTypes     SrvXkbCopyKeyTypes
 +#define XkbFreeClientMap    SrvXkbFreeClientMap
 +#define XkbFreeServerMap    SrvXkbFreeServerMap
 +#define XkbKeyTypesForCoreSymbols SrvXkbKeyTypesForCoreSymbols
 +#define XkbApplyCompatMapToKey    SrvXkbApplyCompatMapToKey
 +#define XkbResizeKeyActions   SrvXkbResizeKeyActions
 +#define XkbResizeKeySyms    SrvXkbResizeKeySyms
 +#define XkbResizeKeyType    SrvXkbResizeKeyType
 +#define XkbAllocCompatMap   SrvXkbAllocCompatMap
 +#define XkbAllocControls    SrvXkbAllocControls
 +#define XkbAllocIndicatorMaps   SrvXkbAllocIndicatorMaps
 +#define XkbAllocKeyboard    SrvXkbAllocKeyboard
 +#define XkbAllocNames     SrvXkbAllocNames
 +#define XkbFreeCompatMap    SrvXkbFreeCompatMap
 +#define XkbFreeKeyboard     SrvXkbFreeKeyboard
 +#define XkbFreeNames      SrvXkbFreeNames
 +#define XkbLatchModifiers   SrvXkbLatchModifiers
 +#define XkbLatchGroup     SrvXkbLatchGroup
 +#define XkbVirtualModsToReal    SrvXkbVirtualModsToReal
 +#define XkbChangeKeycodeRange   SrvXkbChangeKeycodeRange
 +#define XkbApplyVirtualModChanges SrvXkbApplyVirtualModChanges
 +#endif
 +
  #include "Xlibint.h"
  #include <X11/extensions/XKBproto.h>
  #include "XKBlibint.h"
 diff --git a/libX11/src/xkb/XKBMisc.c b/libX11/src/xkb/XKBMisc.c index f3d1d1f1b..f736d1851 100644 --- a/libX11/src/xkb/XKBMisc.c +++ b/libX11/src/xkb/XKBMisc.c @@ -42,6 +42,7 @@ THE USE OR PERFORMANCE OF THIS SOFTWARE.  #include <stdio.h>
  #include <X11/X.h>
 +#define XkbVirtualModsToReal    SrvXkbVirtualModsToReal
  #include <X11/Xproto.h>
  #include "misc.h"
  #include "inputstr.h"
 diff --git a/libX11/src/xkb/XKBSetGeom.c b/libX11/src/xkb/XKBSetGeom.c index 439b75e01..5b9f5887c 100644 --- a/libX11/src/xkb/XKBSetGeom.c +++ b/libX11/src/xkb/XKBSetGeom.c @@ -36,12 +36,8 @@ THE USE OR PERFORMANCE OF THIS SOFTWARE.  #include <X11/extensions/XKBgeom.h>
  #include <X11/extensions/XKBproto.h>
 -#ifndef MINSHORT
  #define	MINSHORT	-32768
 -#endif
 -#ifndef MAXSHORT
  #define	MAXSHORT	32767
 -#endif
  /***====================================================================***/
 diff --git a/libX11/src/xkb/XKBUse.c b/libX11/src/xkb/XKBUse.c index efca018f6..a16d6963a 100644 --- a/libX11/src/xkb/XKBUse.c +++ b/libX11/src/xkb/XKBUse.c @@ -29,6 +29,34 @@ THE USE OR PERFORMANCE OF THIS SOFTWARE.  #endif
  #include <stdio.h>
  #include <ctype.h>
 +
 +#ifdef XKB_IN_SERVER
 +#define XkbAllocClientMap   SrvXkbAllocClientMap
 +#define XkbAllocServerMap   SrvXkbAllocServerMap
 +#define XkbChangeTypesOfKey   SrvXkbChangeTypesOfKey
 +#define XkbCopyKeyTypes     SrvXkbCopyKeyTypes
 +#define XkbFreeClientMap    SrvXkbFreeClientMap
 +#define XkbFreeServerMap    SrvXkbFreeServerMap
 +#define XkbKeyTypesForCoreSymbols SrvXkbKeyTypesForCoreSymbols
 +#define XkbApplyCompatMapToKey    SrvXkbApplyCompatMapToKey
 +#define XkbResizeKeyActions   SrvXkbResizeKeyActions
 +#define XkbResizeKeySyms    SrvXkbResizeKeySyms
 +#define XkbResizeKeyType    SrvXkbResizeKeyType
 +#define XkbAllocCompatMap   SrvXkbAllocCompatMap
 +#define XkbAllocControls    SrvXkbAllocControls
 +#define XkbAllocIndicatorMaps   SrvXkbAllocIndicatorMaps
 +#define XkbAllocKeyboard    SrvXkbAllocKeyboard
 +#define XkbAllocNames     SrvXkbAllocNames
 +#define XkbFreeCompatMap    SrvXkbFreeCompatMap
 +#define XkbFreeKeyboard     SrvXkbFreeKeyboard
 +#define XkbFreeNames      SrvXkbFreeNames
 +#define XkbLatchModifiers   SrvXkbLatchModifiers
 +#define XkbLatchGroup     SrvXkbLatchGroup
 +#define XkbVirtualModsToReal    SrvXkbVirtualModsToReal
 +#define XkbChangeKeycodeRange   SrvXkbChangeKeycodeRange
 +#define XkbApplyVirtualModChanges SrvXkbApplyVirtualModChanges
 +#endif
 +
  #include "Xlibint.h"
  #include <X11/extensions/XKBproto.h>
  #include "XKBlibint.h"
 diff --git a/libX11/src/xlibi18n/XDefaultOMIF.c b/libX11/src/xlibi18n/XDefaultOMIF.c index c7511e608..d209d8f49 100644 --- a/libX11/src/xlibi18n/XDefaultOMIF.c +++ b/libX11/src/xlibi18n/XDefaultOMIF.c @@ -69,6 +69,7 @@ Sun Microsystems, Inc. or its licensors is granted.  #include <X11/Xos.h>
  #include <X11/Xatom.h>
  #include <stdio.h>
 +#include <stdint.h>
  #define MAXFONTS		100
 diff --git a/libX11/src/xlibi18n/XimProto.h b/libX11/src/xlibi18n/XimProto.h index 6b0096dd6..9551301a2 100644 --- a/libX11/src/xlibi18n/XimProto.h +++ b/libX11/src/xlibi18n/XimProto.h @@ -143,6 +143,13 @@ PERFORMANCE OF THIS SOFTWARE.  /*   * byte order   */ +#ifdef BIGENDIAN +#undef BIGENDIAN +#endif +#ifdef LITTLEENDIAN +#undef LITTLEENDIAN +#endif +  #define BIGENDIAN	(CARD8)0x42	/* MSB first */  #define LITTLEENDIAN	(CARD8)0x6c	/* LSB first */ diff --git a/libX11/src/xlibi18n/lcDB.c b/libX11/src/xlibi18n/lcDB.c index afff17455..4a25ae69d 100644 --- a/libX11/src/xlibi18n/lcDB.c +++ b/libX11/src/xlibi18n/lcDB.c @@ -48,6 +48,8 @@  #endif	/* NOT_X_ENV */ +#include <stdint.h> +  /* specifying NOT_X_ENV allows users to just use     the database parsing routine. */  /* For UDC/VW */ diff --git a/libX11/src/xlibi18n/lcDynamic.c b/libX11/src/xlibi18n/lcDynamic.c index f6df94cbb..8d022d885 100644 --- a/libX11/src/xlibi18n/lcDynamic.c +++ b/libX11/src/xlibi18n/lcDynamic.c @@ -51,7 +51,7 @@ from The Open Group.  #include "Xlcint.h"  #ifndef XLOCALEDIR -#define XLOCALEDIR "/usr/lib/X11/locale" +#define XLOCALEDIR "locale"  #endif  #define LCLIBNAME    "xi18n.so" diff --git a/libX11/src/xlibi18n/lcFile.c b/libX11/src/xlibi18n/lcFile.c index 21a546d8f..4bab0217c 100644 --- a/libX11/src/xlibi18n/lcFile.c +++ b/libX11/src/xlibi18n/lcFile.c @@ -214,7 +214,7 @@ _XlcParsePath(  }  #ifndef XLOCALEDIR -#define XLOCALEDIR "/usr/lib/X11/locale" +#define XLOCALEDIR "locale"  #endif  void diff --git a/libX11/src/xlibi18n/makefile b/libX11/src/xlibi18n/makefile new file mode 100644 index 000000000..5be81d350 --- /dev/null +++ b/libX11/src/xlibi18n/makefile @@ -0,0 +1,80 @@ +#AM_CFLAGS= \ +#	-I$(top_srcdir)/include \ +#	-I$(top_srcdir)/include/X11 \ +#	-I$(top_builddir)/include \ +#	-I$(top_builddir)/include/X11 \ +#	-I$(top_srcdir)/src/xcms \ +#	-I$(top_srcdir)/src/xkb \ +#	-I$(top_srcdir)/src/xlibi18n \ +#	-I$(top_srcdir)/src \ +#	$(X11_CFLAGS) \ +#	$(BIGFONT_CFLAGS) \ +#	$(XDMCP_CFLAGS) \ +#	-D_BSD_SOURCE \ +#	$(XMALLOC_ZERO_CFLAGS) + +LIBRARY = libi18n + + +# +# Dynamic loading code for i18n modules +# +#if XLIB_LOADABLE_I18N +#XI18N_DL_SOURCES = \ +#                  XlcDL.c \ +#                  XlcSL.c +#else +# +# Static interfaces to input/output methods +# +#IM_LIBS = \ +#	${top_builddir}/modules/im/ximcp/libximcp.la + +#LC_LIBS = \ +#	${top_builddir}/modules/lc/def/libxlcDef.la \ +#	${top_builddir}/modules/lc/gen/libxlibi18n.la \ +#	${top_builddir}/modules/lc/Utf8/libxlcUTF8Load.la \ +#	${top_builddir}/modules/lc/xlocale/libxlocale.la + +#OM_LIBS = \ +#	${top_builddir}/modules/om/generic/libxomGeneric.la +#endif + +#libi18n_la_LIBADD = \ +#	 $(IM_LIBS) $(LC_LIBS) $(OM_LIBS) + +INCLUDES += ..\..\include\X11 +DEFINES += XLOCALELIBDIR="\".\"" + +CSRCS = \ +	$(XI18N_DL_SOURCES) \ +	XDefaultIMIF.c \ +	XDefaultOMIF.c \ +	xim_trans.c\ +	ICWrap.c\ +	IMWrap.c\ +	imKStoUCS.c\ +	lcCT.c\ +	lcCharSet.c\ +	lcConv.c\ +	lcDB.c\ +	lcDynamic.c\ +	lcFile.c\ +	lcGeneric.c\ +	lcInit.c\ +	lcPrTxt.c\ +	lcPubWrap.c\ +	lcPublic.c\ +	lcRM.c\ +	lcStd.c\ +	lcTxtPr.c\ +	lcUTF8.c\ +	lcUtil.c\ +	lcWrap.c\ +	mbWMProps.c\ +	mbWrap.c\ +	utf8WMProps.c\ +	utf8Wrap.c\ +	wcWrap.c +	 + | 
