home *** CD-ROM | disk | FTP | other *** search
/ InfoMagic Source Code 1993 July / THE_SOURCE_CODE_CD_ROM.iso / X / mit / lib / Xmu / UpdMapHint.c < prev    next >
Encoding:
C/C++ Source or Header  |  1989-09-22  |  1.8 KB  |  53 lines

  1. /*
  2.  * $XConsortium: UpdMapHint.c,v 1.1 89/09/22 12:07:37 jim Exp $
  3.  *
  4.  * Copyright 1989 Massachusetts Institute of Technology
  5.  *
  6.  * Permission to use, copy, modify, distribute, and sell this software and its
  7.  * documentation for any purpose is hereby granted without fee, provided that
  8.  * the above copyright notice appear in all copies and that both that
  9.  * copyright notice and this permission notice appear in supporting
  10.  * documentation, and that the name of M.I.T. not be used in advertising or
  11.  * publicity pertaining to distribution of the software without specific,
  12.  * written prior permission.  M.I.T. makes no representations about the
  13.  * suitability of this software for any purpose.  It is provided "as is"
  14.  * without express or implied warranty.
  15.  *
  16.  * M.I.T. DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING ALL
  17.  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL M.I.T.
  18.  * BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
  19.  * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION
  20.  * OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN 
  21.  * CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
  22.  *
  23.  * Author:  Jim Fulton, MIT X Consortium
  24.  */
  25.  
  26. #include <stdio.h>
  27. #include <X11/Xlib.h>
  28. #include <X11/Xutil.h>
  29.  
  30. Bool XmuUpdateMapHints (dpy, w, hints)
  31.     Display *dpy;
  32.     Window w;
  33.     XSizeHints *hints;
  34. {
  35.     static XSizeHints *shp = NULL;
  36.  
  37.     if (!hints) {                /* get them first */
  38.     long supp;
  39.  
  40.     if (!shp) {
  41.         shp = XAllocSizeHints();
  42.         if (!shp) return False;
  43.     }
  44.     if (!XGetWMNormalHints (dpy, w, shp, &supp)) return False;
  45.     hints = shp;
  46.     }
  47.     hints->flags &= ~(PPosition|PSize);
  48.     hints->flags |= (USPosition|USSize);
  49.     XSetWMNormalHints (dpy, w, hints);
  50.     return True;
  51. }
  52.     
  53.